Во второй части статьи про свою новогоднюю игрушку я расскажу про внутри игровые покупки. Я совсем не люблю рекламу в приложениях, по этому вопрос встраивания рекламы в своё приложение, для меня отпал сразу. Мой опыт выкладывания в Gooogle Play платных игр говорит о том, что резко падает количество желающих эту игру скачать, по этому вариант продажи игры, тоже отпал. И так как я не стремлюсь заработать на игре состояние, а делаю это больше в своё удовольствие, то решил что пусть пользователи сами решают, платить что-нибудь или нет.
Да, я решил использовать в игре донаты. Если потом вдруг будет интересная статистика по донатам в игре, то обязательно ею поделюсь в следующей статье.
Для работы со встраиваемыми покупками я остановился на очень простой, на мой взгляд, но вполне функциональной библиотеке Anjlab (ссылка на GitHub).
В Google play существуют два типа товаров:
Покупка товаров работает асинхронно, то есть сначала делаете запрос на покупку, потом получаете ответ об успешной покупке или коде ошибки.
Для подключения библиотеки в наше приложение необходимо в файле build.gradle (Module: app)
Добавить строку compile 'com.anjlab.android.iab.v3:library:1.0.44' в раздел dependencies (Не забываем после внесения изменений, нажать Sync Now в верхнем правом углу окна.)
Добавляем в файл с Activity две библиотеки:
Снабжаем нашу Activity функционалом BillingProcessor.IBillingHandler:
Для работы с покупками создаём объект класса BillingProcessor и добавляем требуемые методы:
В методе onCreate инициализируем переменную:
Заполняем кодом переопределённые методы:
Со стороны приложения всё сделали, теперь надо выполнить ряд действий в консоли Google Play.
Сначала необходимо получить «ЛИЦЕНЗИОННЫЙ КЛЮЧ ИЗ Google Play». Этот ключ уникальный для каждого приложения, по этому, чтобы его получить, приложение необходимо опубликовать, например, как бета-версию.
После того как приложение будет опубликовано, заходим в раздел управления приложением (просто щёлкнув на него в списке приложений), затем в левом меню раскрываем раздел «Инструменты разработки» и переходим в подраздел «Службы и API», там в панели «Лицензирование и продажа контента» и есть необходимый ключ, который имеет вид «MIIBIjANBgkqhkiG9w0BAQEFAAOCA......................................................................................»
Этот ключ используется при вызове метода:
Теперь нам необходимо создать контент, который будем продавать. Для этого в левом меню переходим в раздел «Настройки страницы приложения» и подраздел «Контент для продажи».
Далее нам необходимо определить какой тип контента нам нужен — продукт или подписка, определившись с типом, переходим на соответствующую вкладку и создаём необходимый контент, заполняя требуемые поля. В приложении может быть как продукты, так и подписки одновременно.
Стоит обратить внимание на именование идентификатора продукта, именно он будет использоваться в нашем приложении.
Например, создаём продукт с идентификатором one_dollar_donate, и для покупки в приложении будем использовать следующий вызов функции:
С Наступающим Новым Годом! и пусть он будет интереснее предыдущих!
Да, я решил использовать в игре донаты. Если потом вдруг будет интересная статистика по донатам в игре, то обязательно ею поделюсь в следующей статье.
Для работы со встраиваемыми покупками я остановился на очень простой, на мой взгляд, но вполне функциональной библиотеке Anjlab (ссылка на GitHub).
В Google play существуют два типа товаров:
- Продукт — приобретается разово, до реализации, не имеет срока действия
- Подписка — может приобретаться регулярно, имеет срок действия
Покупка товаров работает асинхронно, то есть сначала делаете запрос на покупку, потом получаете ответ об успешной покупке или коде ошибки.
Для подключения библиотеки в наше приложение необходимо в файле build.gradle (Module: app)
Добавить строку compile 'com.anjlab.android.iab.v3:library:1.0.44' в раздел dependencies (Не забываем после внесения изменений, нажать Sync Now в верхнем правом углу окна.)
apply plugin: 'com.android.application'
android {
compileSdkVersion 26
defaultConfig {
applicationId "ru.crazyprojects.android.newyeartree"
minSdkVersion 14
targetSdkVersion 26
versionCode 8
versionName '1.8'
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
productFlavors {
}
}
dependencies {
implementation fileTree(include: ['*.jar'], dir: 'libs')
implementation 'com.android.support:appcompat-v7:26.1.0'
implementation 'com.android.support.constraint:constraint-layout:1.0.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:0.5'
androidTestImplementation 'com.android.support.test.espresso:espresso-core:2.2.2'
compile 'com.anjlab.android.iab.v3:library:1.0.44'
}
Добавляем в файл с Activity две библиотеки:
import com.anjlab.android.iab.v3.BillingProcessor;
import com.anjlab.android.iab.v3.TransactionDetails;
Снабжаем нашу Activity функционалом BillingProcessor.IBillingHandler:
public class NewYearTree extends AppCompatActivity implements BillingProcessor.IBillingHandler { ... }
Для работы с покупками создаём объект класса BillingProcessor и добавляем требуемые методы:
public class NewYearTree extends AppCompatActivity implements BillingProcessor.IBillingHandler {
BillingProcessor bp;
...........
@Override
public void onBillingInitialized() {
/*
* Вызывается, когда объект инициализирован и можно совершать покупки
*/
}
@Override
public void onProductPurchased(String productId, TransactionDetails details) {
/*
* Вызывается когда покупка совершена
*/
}
@Override
public void onBillingError(int errorCode, Throwable error) {
/*
* Вызывается при возникновении каких-либо ошибок при совершении покупки
*/
}
@Override
public void onPurchaseHistoryRestored() {
/*
* Вызывается один раз при первом запуске после установки или переустановки приложения.
* Служит для получения приобретённых ранее покупок, например, на другом устройстве
*/
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
// Тут не совсем разобрался, если кто подскажет, буду благодарен
if (!bp.handleActivityResult(requestCode, resultCode, data)) {
super.onActivityResult(requestCode, resultCode, data);
}
}
}
В методе onCreate инициализируем переменную:
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
........
if(!BillingProcessor.isIabServiceAvailable(this)) {
Toast.makeText(this, "In-app billing service is unavailable.", Toast.LENGTH_LONG).show();
}
bp = new BillingProcessor(this, "ЛИЦЕНЗИОННЫЙ КЛЮЧ ИЗ Google Play", this); // где взять этот ключ расскажу чуть ниже.
bp.initialize();
}
Заполняем кодом переопределённые методы:
@Override
public void onBillingInitialized() {
Log.d("LOG", "On Billing Initialaized"); // Просто пишем в лог
}
@Override
public void onProductPurchased(String productId, TransactionDetails details) {
Toast.makeText(this, "Thanks for Your donate. "+productId, Toast.LENGTH_LONG).show(); // Благодарим за пожертвование
bp.consumePurchase(productId); // И сразу после успешного завершения покупки сразу реализуем приобретённый товар, чтобы его можно было купить снова.
}
@Override
public void onBillingError(int errorCode, Throwable error) {
Log.d("LOG", "On Billing Error"+Integer.toString(errorCode)); // Пишем ошибку в лог
}
@Override
public void onPurchaseHistoryRestored() {
// Так как информация о ранее приобретённых товарах в моём приложении не нужна, то данный метод оставляю пустым.
// при необходимости, тут должен быть код для получения ранее купленных товаров и сохранения их в приложении на устройстве
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
//Toast.makeText(this, "On Activity Result", Toast.LENGTH_LONG).show();
Log.d("LOG", "On Activity Result");
if (!bp.handleActivityResult(requestCode, resultCode, data)) {
super.onActivityResult(requestCode, resultCode, data);
}
}
// Добавляю дополнительный метод, который буду вызывать для инициации процесса покупки
public void donate(String ProductID) {
bp.purchase(this, ProductID); // Отправляем запрос на покупку товара
}
Со стороны приложения всё сделали, теперь надо выполнить ряд действий в консоли Google Play.
Сначала необходимо получить «ЛИЦЕНЗИОННЫЙ КЛЮЧ ИЗ Google Play». Этот ключ уникальный для каждого приложения, по этому, чтобы его получить, приложение необходимо опубликовать, например, как бета-версию.
После того как приложение будет опубликовано, заходим в раздел управления приложением (просто щёлкнув на него в списке приложений), затем в левом меню раскрываем раздел «Инструменты разработки» и переходим в подраздел «Службы и API», там в панели «Лицензирование и продажа контента» и есть необходимый ключ, который имеет вид «MIIBIjANBgkqhkiG9w0BAQEFAAOCA......................................................................................»
Этот ключ используется при вызове метода:
bp = new BillingProcessor(this, "MIIBIjANBgkqhkiG9w0BAQEFAAOCA......................................................................................", this);
Теперь нам необходимо создать контент, который будем продавать. Для этого в левом меню переходим в раздел «Настройки страницы приложения» и подраздел «Контент для продажи».
Далее нам необходимо определить какой тип контента нам нужен — продукт или подписка, определившись с типом, переходим на соответствующую вкладку и создаём необходимый контент, заполняя требуемые поля. В приложении может быть как продукты, так и подписки одновременно.
Стоит обратить внимание на именование идентификатора продукта, именно он будет использоваться в нашем приложении.
Например, создаём продукт с идентификатором one_dollar_donate, и для покупки в приложении будем использовать следующий вызов функции:
bp.purchase(this, "one_dollar_donate");
С Наступающим Новым Годом! и пусть он будет интереснее предыдущих!
KuSu
Если к экрану вернулись с результатом после startActivityWithResult(), сначала пробуем передать данные для обработки в BillingProcessor. Если он сообщит, что это не его — то идет обработка дальше.
Как правило, в этом методе можно перестраховаться на случай, если покупка была успешно оплачена, но по каким-либо причинам приложение не успело это обработать. Например, если система успела убить приложение, или приложение упало с ошибкой.