6

onIabPurchaseFinishedListener从来没有被调用过,即使我在应用程序对话框中单击立即购买,logcat 也不会打印任何内容。

public class CreateAlbumActivity extends Activity {
IabHelper mHelper;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_create_album);
        mHelper = new IabHelper(this, Global.inapp);

    mHelper.startSetup(new IabHelper.OnIabSetupFinishedListener() {
           public void onIabSetupFinished(IabResult result) {
              if (!result.isSuccess()) {
                 // Oh noes, there was a problem.
                 // AlertDialogHelper.CreateNormalDialog(context, "Failed to set In-App Billing: " +result);
                 Log.d(Global.TAG, "Problem setting up In-app Billing: " + result);
                 return;
              }            
                 // Hooray, IAB is fully set up!  

           }
        });
    }
 public void createAlbumEvent(){

                    mHelper.launchPurchaseFlow(CreateAlbumActivity.this, "android.test.purchased", 10001,   
                           mPurchaseFinishedListener, "bGoa+V7g/yqDXvKRqq");


    }
    IabHelper.OnIabPurchaseFinishedListener mPurchaseFinishedListener 
     = new IabHelper.OnIabPurchaseFinishedListener() {
     public void onIabPurchaseFinished(IabResult result, Purchase purchase) 
     {
        if (result.isFailure()) {
           Log.d(Global.TAG, "Error purchasing: " + result);
           return;
        }      
        Log.d(Global.TAG, "SUCCESS PURCHASE!");
     }
     };
     @Override
     protected void onActivityResult(int requestCode, int resultCode, Intent data) {
         Log.d(Global.TAG, "onActivityResult(" + requestCode + "," + resultCode + "," + data);

         // Pass on the activity result to the helper for handling
         if (!mHelper.handleActivityResult(requestCode, resultCode, data)) {
             // not handled, so handle it ourselves (here's where you'd
             // perform any handling of activity results not related to in-app
             // billing...
             super.onActivityResult(requestCode, resultCode, data);
         }
         else {
             Log.d(Global.TAG, "onActivityResult handled by IABUtil.");
         }
     }
}
4

3 回答 3

9

好吧,所以在花了几个小时试图解决这个问题之后,我遇到了以下答案:https ://stackoverflow.com/a/17411617/1203043

问题是我的活动有一个“没有历史”的标志。如果我从活动中删除此标志,它就可以正常工作。我真的不知道它为什么会发生,但它就在这里。

希望你们永远不会经历我经历过的噩梦。

于 2013-08-20T23:34:29.663 回答
5

我发现以下链接很有帮助: onIabPurchaseFinished 从未调用过。

问题是 Activity 没有正确处理 onActivityResult 并且在 In App Purchasing 教程中没有提到它。

于 2014-02-12T00:31:31.250 回答
2

我面临的问题是因为我使用了片段并且在我从父活动手动调用它之前没有调用onActivityResult 。如果有人遇到同样的问题,我在这里提供了答案!

于 2018-04-09T14:58:20.250 回答