7

Android 用のアプリ課金 v3 でテストするために、単一選択項目アダプターを追加するダイアログを実装しました。テスト Sku、「android.test.purchased」、「android.test.canceled」、「android.test.refunded」、「android.test.item_unavailable」を追加しました。

ダイアログを使用して購入フローを開始すると、すべて問題なく、アイテムを購入することができ、アイテムは間違いなく購入されます。ただし、アプリが UI を更新しようとすると、nullpointerexception が発生します。私はリフレッシュが機能することを知っています。

これが私のlogcatです:

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 です。

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

UI の更新時に null を返します。しかし、問題は、最初の sku (android.test.purchased) では機能しているように見えますが、2 番目の sku (android.test.canceled) では null であり、別のアイテムを購入した後に実行したときにのみ null になることです (返金または購入済み)。ただし、後でもう一度開いた場合は問題なく、nullpointerexception はスローされません。

ArrayList オブジェクトに追加する前に null チェックを追加すると、購入したアイテムが inv.getSkuDetails(s) で null を返す前後にすべてのアイテムが追加されるため、アイテムは追加されません。

4

2 に答える 2

5

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

startSetupを呼び出した後、クエリするSKU(購入されているかどうかに関係なく)を含むリストを渡す必要があります。したがって、(不適切な)定型的なTrivialDriveの例で提供されているものではなく、以下のコードのようになります。

mHelper.queryInventoryAsync(true, skuList, mGotInventoryListener);

また、いくつかのファントムメソッドがあるようです(コメントではまだクリーンアップされておらず、これも不正確です)...そのバグの詳細はここにあります:

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

于 2013-02-22T19:24:21.373 に答える
4

私と同じ問題を抱えている人のためにこれを残して、それを理解しました。UI の更新では、sku の詳細を照会せずに IabHelper クエリを呼び出していました。したがって、事前キャッシュされた sku には詳細が含まれていましたが、そうでないものは失敗しました。

于 2012-12-16T01:36:49.217 に答える