2012-12-16 56 views
7

要在Android应用程序结算v3中进行测试,我实现了一个对话框,其中添加了一个选项适配器。我已经添加了测试Skus,“android.test.purchased”,“android.test.canceled”,“android.test.refunded”,“android.test.item_unavailable”。在应用程序结算v3 NullPointerException

当我使用对话框启动采购流程时,一切都很好,我可以购买该物品并确定购买该物品。但是,当我的应用程序尝试刷新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个单品的ArrayList。

空指针是 SkuDetails c = inv.getSkuDetails(s);

它在UI刷新上返回null。但问题是它似乎适用于第一个sku(android.test.purchased),但对于第二个sku(android.test.canceled)为null,并且它也仅在购买另一个项目(退还或购买)。但是,如果我随后再次打开它,那就没有问题,并且不会抛出nullpointerexception。

如果我加入到ArrayList对象,那么没有项目被添加为每一个项目后,或购买项目之前前添加一个空检查在inv.getSkuDetails(S)返回null

+0

对于像我这样的新手来说,这其实很简单。首先(假设你使用eclipse)就在你下载SDK的地方,查看应用程序结算的附加内容。一旦你这样做了,如果你导航到你的android-sdk文件夹,它就在应用程序结算v3 - >示例中,在extras> google>下。你所要做的就是导入它并复制实用程序文件并添加一些查询和监听器,如http://developer.android.com/training/in-app-billing/preparing-iab-app.html#GetSample – AndroidPenguin

+0

嗨AndroidPenguin, 感谢您的帮助。几乎实施,只是有一个单一的困惑,或可以说从谷歌的链接不知道如何恢复交易。如果每件产品都不能再次购买,那么如何获得我已经购买该产品的信息。 谢谢.. :) – LuminiousAndroid

+1

我的荣幸!不要忘记注册。在设置后立即进行的查询购买完成此操作。只要你不消费你的购买当然。 – AndroidPenguin

回答

4

想通了,留下这对任何与我有同样问题的人来说都是如此。在UI刷新中,我调用IabHelper查询而不查询skus的详细信息。因此,预先得到的skus有详细信息,但那些没有的,失败了。

+0

你能解释一下吗? –

5

这让我难住,接受的答案没有包含相关的细节。

你需要做的是在调用startSetup之后,将一个List与要查询的SKU(不管它们是否被购买)进行传递。所以它看起来像下面的代码,而不是TrivialDrive样板(不足)中提供的内容。

mHelper.queryInventoryAsync(true, skuList, mGotInventoryListener); 

此外,它看起来像有一些幻象的方法(即仍尚未清理的意见,这也是不准确的)......该错误的详细信息,在这里:

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

+0

这应该是被接受的答案。重点是传入skuList以获取您寻求的sku细节。如果您未通过skuList,则回调方法将仅返回您购买产品的sku详细信息! – Bruce