Предпосылки
Завершите настройку пользовательских событий .
Запросить объявление с вознаграждением
При достижении элемента строки пользовательского события в каскадной цепочке медиации вызывается метод loadRewardedAd()
для имени класса, указанного вами при создании пользовательского события . В данном случае этот метод находится в SampleCustomEvent
, который затем вызывает метод loadRewardedAd()
в SampleRewardedCustomEventLoader
.
Чтобы запросить рекламу с вознаграждением, создайте или измените класс, расширяющий Adapter
для реализации loadRewardedAd()
. Кроме того, создайте новый класс для реализации MediationRewardedAd
.
В нашем примере пользовательского события SampleCustomEvent
расширяет класс Adapter
, а затем делегирует полномочия SampleRewardedCustomEventLoader
.
Ява
package com.google.ads.mediation.sample.customevent; import com.google.android.gms.ads.mediation.Adapter; import com.google.android.gms.ads.mediation.MediationRewardedAdConfiguration; import com.google.android.gms.ads.mediation.MediationAdConfiguration; import com.google.android.gms.ads.mediation.MediationAdLoadCallback; import com.google.android.gms.ads.mediation.MediationRewardedAd; import com.google.android.gms.ads.mediation.MediationRewardedAdCallback; ... public class SampleCustomEvent extends Adapter { private SampleNativeCustomEventLoader nativeLoader; @Override public void loadRewardedAd( @NonNull MediationRewardedAdConfiguration mediationRewardedAdConfiguration, @NonNull MediationAdLoadCallback<MediationRewardedAd, MediationRewardedAdCallback> mediationAdLoadCallback) { rewardedLoader = new SampleRewardedCustomEventLoader( mediationRewardedAdConfiguration, mediationAdLoadCallback); rewardedLoader.loadAd(); } }
SampleRewardedCustomEventLoader
отвечает за следующие задачи:
Загрузка вознагражденной рекламы
Реализация интерфейса
MediationRewardedAd
.Получение и отправка отчетов об обратных вызовах рекламных событий в Google Mobile Ads SDK (бета-версия).
Необязательный параметр, определенный в пользовательском интерфейсе AdMob, включен в конфигурацию объявления. Доступ к нему можно получить через adConfiguration.getServerParameters().getString(MediationConfiguration.CUSTOM_EVENT_SERVER_PARAMETER_FIELD)
. Обычно этот параметр представляет собой идентификатор рекламного блока, который SDK рекламной сети требует при создании экземпляра объекта объявления.
Ява
package com.google.ads.mediation.sample.customevent; import com.google.android.gms.ads.mediation.Adapter; import com.google.android.gms.ads.mediation.MediationRewardedAdConfiguration; import com.google.android.gms.ads.mediation.MediationAdLoadCallback; import com.google.android.gms.ads.mediation.MediationRewardedAd; import com.google.android.gms.ads.mediation.MediationRewardedAdCallback; ... public class SampleRewardedCustomEventLoader extends SampleRewardedAdListener implements MediationRewardedAd { /** Configuration for requesting the rewarded ad from the third-party network. */ private final MediationRewardedAdConfiguration mediationRewardedAdConfiguration; /** * A {@link MediationAdLoadCallback} that handles any callback when a Sample * rewarded ad finishes loading. */ private final MediationAdLoadCallback<MediationRewardedAd, MediationRewardedAdCallback> mediationAdLoadCallback; /** Callback for rewarded ad events. */ private MediationRewardedAdCallback rewardedAdCallback; /** Constructor. */ public SampleRewardedCustomEventLoader( @NonNull MediationRewardedAdConfiguration mediationRewardedAdConfiguration, @NonNull MediationAdLoadCallback<MediationRewardedAd, MediationRewardedAdCallback> mediationAdLoadCallback) { this.mediationRewardedAdConfiguration = mediationRewardedAdConfiguration; this.mediationAdLoadCallback = mediationAdLoadCallback; } /** Loads the rewarded ad from the third-party ad network. */ public void loadAd() { // All custom events have a server parameter named "parameter" that returns // back the parameter entered into the AdMob UI when defining the custom event. Log.i("RewardedCustomEvent", "Begin loading rewarded ad."); String serverParameter = mediationRewardedAdConfiguration .getServerParameters() .getString(MediationConfiguration .CUSTOM_EVENT_SERVER_PARAMETER_FIELD); Log.d("RewardedCustomEvent", "Received server parameter."); SampleAdRequest request = createSampleRequest(mediationRewardedAdConfiguration); sampleRewardedAd = new SampleRewardedAd(serverParameter); sampleRewardedAd.setListener(this); Log.i("RewardedCustomEvent", "Start fetching rewarded ad."); sampleRewardedAd.loadAd(request); } public SampleAdRequest createSampleRequest( MediationAdConfiguration mediationAdConfiguration) { SampleAdRequest request = new SampleAdRequest(); request.setTestMode(mediationAdConfiguration.isTestRequest()); request.setKeywords(mediationAdConfiguration.getMediationExtras().keySet()); return request; } }
В зависимости от того, было ли объявление успешно загружено или возникла ошибка, вы должны вызвать либо onSuccess()
, либо onFailure()
. onSuccess()
вызывается путем передачи экземпляра класса, реализующего MediationRewardedAd
.
Обычно эти методы реализуются внутри обратных вызовов стороннего SDK, который реализует ваш адаптер. В данном примере в Sample SDK есть SampleAdListener
с соответствующими обратными вызовами:
Ява
@Override public void onRewardedAdLoaded() { rewardedAdCallback = mediationAdLoadCallback.onSuccess(this); } @Override public void onRewardedAdFailedToLoad(SampleErrorCode errorCode) { mediationAdLoadCallback.onFailure(SampleCustomEventError.createSampleSdkError(errorCode)); }
MediationRewardedAd
требует реализации метода showAd()
для отображения рекламы:
Ява
@Override public void showAd(Context context) { if (!(context instanceof Activity)) { rewardedAdCallback.onAdFailedToShow( SampleCustomEventError.createCustomEventNoActivityContextError()); return; } Activity activity = (Activity) context; if (!sampleRewardedAd.isAdAvailable()) { rewardedAdCallback.onAdFailedToShow( SampleCustomEventError.createCustomEventAdNotAvailableError()); return; } sampleRewardedAd.showAd(activity); }
Пересылка событий медиации в Google Mobile Ads SDK (бета)
После вызова метода onSuccess()
возвращаемый объект MediationRewardedAdCallback
может быть использован адаптером для пересылки событий презентации из стороннего SDK в Google Mobile Ads SDK (бета). Класс SampleRewardedCustomEventLoader
расширяет интерфейс SampleAdListener
для пересылки обратных вызовов из рекламной сети-образца в Google Mobile Ads SDK.
Важно, чтобы ваше пользовательское событие пересылало как можно больше таких обратных вызовов, чтобы ваше приложение получало эквивалентные события из Google Mobile Ads SDK (бета-версия). Вот пример использования обратных вызовов:
Ява
@Override public void onAdRewarded(final String rewardType, final int amount) { RewardItem rewardItem = new RewardItem() { @Override public String getType() { return rewardType; } @Override public int getAmount() { return amount; } }; rewardedAdCallback.onUserEarnedReward(rewardItem); } @Override public void onAdClicked() { rewardedAdCallback.reportAdClicked(); } @Override public void onAdFullScreen() { rewardedAdCallback.onAdOpened(); rewardedAdCallback.onVideoStart(); rewardedAdCallback.reportAdImpression(); } @Override public void onAdClosed() { rewardedAdCallback.onAdClosed(); } @Override public void onAdCompleted() { rewardedAdCallback.onVideoComplete(); }
На этом реализация настраиваемых событий для рекламы с вознаграждением завершена. Полный пример доступен на GitHub . Вы можете использовать его с уже поддерживаемой рекламной сетью или модифицировать для показа настраиваемых событий для рекламы с вознаграждением.