About AndroidInAppPurchase is an Adobe AIR native extension (ANE) for Android to purchase virtual items.
It uses Google Play In-app Billing version 3 API.
Supported functionality:
- purchase of items;
- restoration of previously purchased items;
- consumption of items;
- subscriptions (not tested).
DocsPlease, read docs and try ANE before asking any questions.
http://developer.android.com/google/play/billing/index.html
http://help.adobe.com/en_US/air/extensions/index.html
InstallationExtension ID: com.pozirk.AndroidInAppPurchase
Add "InAppPurchase.ane" and "air\InAppPurchase\bin\InAppPurchase.swc" to your AIR project.
Add the following lines to your AIR Aplication-app.xml file inside <manifestAdditions> section:
- <uses-permission android:name="com.android.vending.BILLING" />
- <application android:enabled="true">
- <activity android:name="com.pozirk.payment.BillingActivity" android:theme="@android:style/Theme.Translucent.NoTitleBar.Fullscreen" android:background="#30000000" />
- </application>
复制代码 Examples- import com.pozirk.payment.android.InAppPurchase;
- import com.pozirk.payment.android.InAppPurchaseEvent;
- import com.pozirk.payment.android.InAppPurchaseDetails;
- ...
- protected var _iap:InAppPurchase = new InAppPurchase();
- ...
- //> initialization of InAppPurchase
- _iap.addEventListener(InAppPurchaseEvent.INIT_SUCCESS, onInitSuccess);
- _iap.addEventListener(InAppPurchaseEvent.INIT_ERROR, onInitError);
- _iap.init("YOUR_LICENSE_KEY_FOR_THE_APPLICATION");
- ...
- protected function onInitSuccess(event:InAppPurchaseEvent):void
- {
- //you can restore previously purchased items here
- }
- protected function onInitError(event:InAppPurchaseEvent):void
- {
- trace(event.data); //trace error message
- }
- //<
- //> making the purchase, _iap should be initialized first
- _iap.addEventListener(InAppPurchaseEvent.PURCHASE_SUCCESS, onPurchaseSuccess);
- _iap.addEventListener(InAppPurchaseEvent.PURCHASE_ALREADY_OWNED, onPurchaseSuccess);
- _iap.addEventListener(InAppPurchaseEvent.PURCHASE_ERROR, onPurchaseError);
- _iap.purchase("my.product.id", InAppPurchaseDetails.TYPE_INAPP);
- protected function onPurchaseSuccess(event:InAppPurchaseEvent):void
- {
- trace(event.data); //product id
- }
- protected function onPurchaseError(event:InAppPurchaseEvent):void
- {
- trace(event.data); //trace error message
- }
- //<
- //> getting purchased product details, _iap should be initialized first
- _iap.addEventListener(InAppPurchaseEvent.RESTORE_SUCCESS, onRestoreSuccess);
- _iap.addEventListener(InAppPurchaseEvent.RESTORE_ERROR, onRestoreError);
- _iap.restore(); //restoring purchased in-app items and subscriptions
- ...
- protected function onRestoreSuccess(event:InAppPurchaseEvent):void
- {
- //getting details of purchase: time, etc.
- var purchase:InAppPurchaseDetails = _iap.getPurchaseDetails("my.product.id");
- }
- protected function onRestoreError(event:InAppPurchaseEvent):void
- {
- trace(event.data); //trace error message
- }
- //<
- //> getting purchased and not purchased product details
- _iap.addEventListener(InAppPurchaseEvent.RESTORE_SUCCESS, onRestoreSuccess);
- _iap.addEventListener(InAppPurchaseEvent.RESTORE_ERROR, onRestoreError);
- var items:Array<String> = ["my.product.id1", "my.product.id2", "my.product.id3"];
- var subs:Array<String> = ["my.subs.id1", "my.subs.id2", "my.subs.id3"];
- _iap.restore(items, subs); //restoring purchased + not purchased in-app items and subscriptions
- ...
- protected function onRestoreSuccess(event:InAppPurchaseEvent):void
- {
- //getting details of product: time, etc.
- var skuDetails1:InAppSkuDetails = _iap.getSkuDetails("my.product.id1");
- //getting details of product: time, etc.
- var skuDetails2:InAppSkuDetails = _iap.getSkuDetails("my.subs.id1");
- //getting details of purchase: time, etc.
- var purchase:InAppPurchaseDetails = _iap.getPurchaseDetails("my.purchased.product.id");
- }
- protected function onRestoreError(event:InAppPurchaseEvent):void
- {
- trace(event.data); //trace error message
- }
- //<
- //> consuming purchased item
- //>> need to retrieve purchased items first
- _iap.addEventListener(InAppPurchaseEvent.RESTORE_SUCCESS, onRestoreSuccess);
- _iap.addEventListener(InAppPurchaseEvent.RESTORE_ERROR, onRestoreError);
- _iap.restore();
- //<<
- ...
- protected function onRestoreSuccess(event:InAppPurchaseEvent):void
- {
- _iap.addEventListener(InAppPurchaseEvent.CONSUME_SUCCESS, onConsumeSuccess);
- _iap.addEventListener(InAppPurchaseEvent.CONSUME_ERROR, onConsumeError);
- _iap.consume("my.product.id");
- }
- //<
复制代码 Testinghttp://developer.android.com/google/play/billing/billing_testing.htmlMiscANE is build for AIR3.6+, in order to rebuild for another version do the following:
- edit "air\extension.xml" and change 3.6 in very first line to any 3.X you need;
- edit "build.bat" and in the very last line change path from AIR3.X SDK to any AIR3.X SDK you need;
- execute "build.bat" to repack the ANE.
相关链接:
https://github.com/pozirk/AndroidInAppPurchase
|