2012-12-16 11 views
7

Androidのアプリ請求v3でテストするには、単一選択項目のアダプターを追加するダイアログを実装しました。テストSkusを追加しました。 "android.test.purchased"、 "android.test.canceled"、 "android.test.refunded"、 "android.test.item_unavailable"です。アプリの請求v3 NullPointerException

購入フローを起動するためにダイアログを使用すると、すべての項目が正常に購入できるようになり、商品を購入することが確実になります。しかし、私のアプリケーションがUIをリフレッシュしようとすると、私はnullpointerexceptionを取得します。私はリフレッシュの仕事を知っています。

12-16 01:06:06.706: I/Running inventory query with(20846): android.test.purchased 
12-16 01:06:06.706: I/Running details query with(20846): SkuDetails:{"title":"Sample Title","price":"£0.61","type":"inapp","description":"Sample description for product: android.test.purchased.","productId":"android.test.purchased"} 
12-16 01:06:06.706: I/Running details query with(20846): SkuDetails:{"title":"Sample Title","price":"£0.61","type":"inapp","description":"Sample description for product: android.test.purchased.","productId":"android.test.purchased"} 
12-16 01:06:06.706: I/Running inventory query with(20846): android.test.canceled 
12-16 01:06:06.706: I/Running details query with(20846): null 
12-16 01:06:06.706: I/Running details query with(20846): null 
12-16 01:06:06.706: D/AndroidRuntime(20846): Shutting down VM 
12-16 01:06:06.706: W/dalvikvm(20846): threadid=1: thread exiting with uncaught exception (group=0x40d12930) 
12-16 01:06:06.706: E/AndroidRuntime(20846): FATAL EXCEPTION: main 
12-16 01:06:06.706: E/AndroidRuntime(20846): java.lang.NullPointerException 
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.example.test.MainActivity$1.onQueryInventoryFinished(MainActivity.java:201) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.example.test.util.IabHelper$2$1.run(IabHelper.java:536) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Handler.handleCallback(Handler.java:725) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Handler.dispatchMessage(Handler.java:92) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.os.Looper.loop(Looper.java:137) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at android.app.ActivityThread.main(ActivityThread.java:5039) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at java.lang.reflect.Method.invokeNative(Native Method) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at java.lang.reflect.Method.invoke(Method.java:511) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 
12-16 01:06:06.706: E/AndroidRuntime(20846): at dalvik.system.NativeStart.main(Native Method) 

for (String s : allSkus) { 
Log.i("Running inventory query with", "" + s); 
SkuDetails c = inv.getSkuDetails(s); 
Log.i("Running details query with", "" + c); 
if (inv.hasPurchase(s)) { 
    purchaseArray.add(c.getTitle()); 
} else { 
    **LINE 201** objects.add(c.getPrice() + " T:" + c.getSku()); 
} 

allSkusは、上記4つのSKUを保持しているのArrayListです:

は、ここに私のlogcatです。

nullpointerは です。SkuDetails c = inv.getSkuDetails(s);

これは、UIの更新時にnullを返します。しかし、問題は、最初のsku(android.test.purchased)では動作するようですが、2番目のsku(android.test.canceled)ではnullで、別のアイテムを購入した後に実行するとnullになります払い戻されたか購入された)。しかし、後でそれを再び開くと、問題なくnullpointerexceptionがスローされます。私は、ArrayListのオブジェクトに追加する前にヌルチェックを追加する場合は買った項目はinv.getSkuDetailsにヌルを返した後または前に、何らのアイテムはすべての項目として追加されていない

(S)

+0

私は自分のような初心者にとってはとてもシンプルです。まずSDKをダウンロードした場所(Eclipseを使用していると仮定します)で、アプリ内課金の追加情報を調べます。一度それを行うと、アンドロイド-sdkフォルダに移動すると、app> v3 - >サンプルのextras> google>に表示されます。 http://developer.android.com/training/in-app-billing/preparing-iab-app.html#GetSample – AndroidPenguin

+0

ここで説明するように、インポートしてutilファイルをコピーしていくつかのクエリとリスナーを追加するだけですちょっとAndroidPenguin、 ありがとうございました。ほとんど実装されて、ちょうど単一の混乱を持っているか、Googleのリンクからトランザクションを復元する方法を理解していないと言うことができます。すべての製品をもう一度購入できない場合は、既に製品を購入しているという情報を取得する方法。 ありがとう.. :) – LuminiousAndroid

+1

私の喜び! upvoteを忘れないでください。セットアップ直後に発生するクエリの購入がこれを行います。限り、あなたはもちろんあなたの購入を消費しない限り。 – AndroidPenguin

答えて

4

は残して、それを考え出しましたこれは私と同じ問題を抱えている人のためのものです。 UIのリフレッシュで、Skusの詳細を照会せずにIabHelperクエリーを呼び出していました。このように、精緻化されたスキューは細部を持っていたが、そうでなかったスキューは失敗した。

+0

説明できますか? –

5

これは私を困惑させ、受け入れられた答えには関連する詳細が含まれていませんでした。

あなたがしなければならないことは、startSetupを呼び出した後に照会するSKUを持つリスト(購入したかどうか)を渡すことです。したがって、(不十分な)定型的なTrivialDriveの例ではなく、以下のコードのようになります。

mHelper.queryInventoryAsync(true, skuList, mGotInventoryListener); 

(も不正確で、まだ、まだコメントでクリーンアップされていない、)いくつかのファントム方法があるようにまた、それがここに...そのバグの詳細を検索します:

http://code.google.com/p/marketbilling/issues/detail?id=98

+0

これは受け入れられる回答である必要があります。主なポイントは、スキューの詳細を取得するskuListに渡すことです。 skuListを渡さないと、コールバックメソッドは購入した製品のskuの詳細を返すだけです! – Bruce

関連する問題