Я пытаюсь реализовать Android-биллинг внутри приложения.
Что я сделал до сих пор:
- Добавлен файл
aidl
.
- Добавлены файлы
util-helper
.
- Создано приложение на игровой консоли
- Загрузил
signed APK
и добавил продукт в игровую консоль.
- Добавлен некоторый код в файл
Shop.java
. Это работает нормально, пока я не попытаюсь получить цену товара (см. Код между: //THIS IS WHERE THE APP CRASHES
ниже).
Вот код, который я использую внутри onCreate()
в Shop.java
onCreate() {
//In App Billing
key = "XXX";
mHelper = new IabHelper(this, key);
mHelper.startSetup(new IabHelper.OnIabSetupFinishedListener() {
public void onIabSetupFinished(IabResult result) {
if (!result.isSuccess()) {
Log.d(TAG, "In-app Billing setup failed: " + result);
return;
}
if (mHelper == null) return;
Log.d(TAG, "Setup successful. Querying inventory.");
try {
mHelper.queryInventoryAsync(mGotInventoryListener);
} catch (IabHelper.IabAsyncInProgressException e) {
}
}
});
}
А потом mGotInventoryListener
:
IabHelper.QueryInventoryFinishedListener mGotInventoryListener = new IabHelper.QueryInventoryFinishedListener() {
public void onQueryInventoryFinished(IabResult result, Inventory inventory) {
// Have we been disposed of in the meantime? If so, quit.
if (mHelper == null) return;
if (result.isFailure()) {
// handle error
return;
}
Log.d(TAG, "Query inventory was successful.");
// Do we have the premium upgrade?
Purchase premiumPurchase = inventory.getPurchase(ITEM_SKU);
boolean mIsPremium = (premiumPurchase != null);
Log.d(TAG, "User is " + (mIsPremium ? "PREMIUM" : "NOT PREMIUM"));
//THIS IS WHERE THE APP CRASHES
String price = inventory.getSkuDetails(ITEM_SKU).getPrice();
//THIS IS WHERE THE APP CRASHES
updateUI();
}
};
СООБЩЕНИЕ ОБ ОШИБКЕ:
E/AndroidRuntime: FATAL EXCEPTION: main
Process: example.com.app, PID: 4270
java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String example.com.app.util.SkuDetails.getPrice()' on a null object reference
at example.com.app.Shop$2.onQueryInventoryFinished(Shop.java:234)
at example.com.app.util.IabHelper$2$1.run(IabHelper.java:711)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6692)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1468)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1358)