Prasyarat
Selesaikan penyiapan peristiwa kustom.
Meminta iklan interstisial
Saat item baris peristiwa kustom dijangkau dalam rantai mediasi waterfall,
Metode loadInterstitialAd()
dipanggil pada nama class yang Anda berikan saat
membuat
peristiwa. Dalam kasus ini,
metode tersebut berada di SampleCustomEvent
, yang kemudian memanggil metode
Metode loadInterstitialAd()
di SampleInterstitialCustomEventLoader
.
Untuk meminta iklan interstisial, buat atau ubah kelas yang memperluas Adapter
untuk menerapkan loadInterstitialAd()
. Selain itu, buat class baru untuk
mengimplementasikan MediationInterstitialAd
.
Dalam contoh peristiwa kustom kami,
SampleCustomEvent
memperluas class Adapter
lalu didelegasikan ke
SampleInterstitialCustomEventLoader
.
Java
package com.google.ads.mediation.sample.customevent; import com.google.android.gms.ads.mediation.Adapter; import com.google.android.gms.ads.mediation.MediationAdConfiguration; import com.google.android.gms.ads.mediation.MediationAdLoadCallback; import com.google.android.gms.ads.mediation.MediationInterstitialAd; import com.google.android.gms.ads.mediation.MediationInterstitialAdCallback; ... public class SampleCustomEvent extends Adapter { private SampleInterstitialCustomEventLoader interstitialLoader; @Override public void loadInterstitialAd( @NonNull MediationInterstitialAdConfiguration adConfiguration, @NonNull MediationAdLoadCallback<MediationInterstitialAd, MediationInterstitialAdCallback> callback) { interstitialLoader = new SampleInterstitialCustomEventLoader(adConfiguration, callback); interstitialLoader.loadAd(); } }
SampleInterstitialCustomEventLoader
bertanggung jawab atas tugas berikut:
Memuat iklan interstisial dan memanggil
MediationAdLoadCallback
setelah pemuatan selesai.Mengimplementasikan antarmuka
MediationInterstitialAd
.Menerima dan melaporkan callback peristiwa iklan ke Google Mobile Ads SDK
Parameter opsional yang ditetapkan di UI AdMob adalah
disertakan dalam konfigurasi iklan. Parameter ini dapat diakses melalui
adConfiguration.getServerParameters().getString(MediationConfiguration.CUSTOM_EVENT_SERVER_PARAMETER_FIELD)
.
Parameter ini biasanya merupakan ID unit iklan yang digunakan SDK jaringan iklan
saat membuat instance objek iklan.
Java
package com.google.ads.mediation.sample.customevent; import com.google.android.gms.ads.mediation.Adapter; import com.google.android.gms.ads.mediation.MediationInterstitialAdConfiguration; import com.google.android.gms.ads.mediation.MediationAdLoadCallback; import com.google.android.gms.ads.mediation.MediationInterstitialAd; import com.google.android.gms.ads.mediation.MediationInterstitialAdCallback; ... public class SampleInterstitialCustomEventLoader extends SampleAdListener implements MediationInterstitialAd { /** A sample third-party SDK interstitial ad. */ private SampleInterstitial sampleInterstitialAd; /** Configuration for requesting the interstitial ad from the third-party network. */ private final MediationInterstitialAdConfiguration mediationInterstitialAdConfiguration; /** Callback for interstitial ad events. */ private MediationInterstitialAdCallback interstitialAdCallback; /** Callback that fires on loading success or failure. */ private final MediationAdLoadCallback<MediationInterstitialAd, MediationInterstitialAdCallback> mediationAdLoadCallback; /** Constructor. */ public SampleInterstitialCustomEventLoader( @NonNull MediationInterstitialAdConfiguration mediationInterstitialAdConfiguration, @NonNull MediationAdLoadCallback<MediationInterstitialAd, MediationInterstitialAdCallback> mediationAdLoadCallback) { this.mediationInterstitialAdConfiguration = mediationInterstitialAdConfiguration; this.mediationAdLoadCallback = mediationAdLoadCallback; } /** Loads the interstitial 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 UI when defining the custom event. Log.i("InterstitialCustomEvent", "Begin loading interstitial ad."); String serverParameter = mediationInterstitialAdConfiguration.getServerParameters().getString( MediationConfiguration.CUSTOM_EVENT_SERVER_PARAMETER_FIELD); Log.d("InterstitialCustomEvent", "Received server parameter."); sampleInterstitialAd = new SampleInterstitial(mediationInterstitialAdConfiguration.getContext()); sampleInterstitialAd.setAdUnit(serverParameter); // Implement a SampleAdListener and forward callbacks to mediation. sampleInterstitialAd.setAdListener(this); // Make an ad request. Log.i("InterstitialCustomEvent", "start fetching interstitial ad."); sampleInterstitialAd.fetchAd( SampleCustomEvent.createSampleRequest(mediationInterstitialAdConfiguration)); } public SampleAdRequest createSampleRequest( MediationAdConfiguration mediationAdConfiguration) { SampleAdRequest request = new SampleAdRequest(); request.setTestMode(mediationAdConfiguration.isTestRequest()); request.setKeywords(mediationAdConfiguration.getMediationExtras().keySet()); return request; } }
Bergantung pada apakah iklan berhasil diambil atau mengalami error, Anda
akan memanggil
onSuccess()
atau
onFailure()
onSuccess()
dipanggil dengan meneruskan instance class yang mengimplementasikan
MediationInterstitialAd
.
Biasanya, metode ini diimplementasikan dalam callback dari
SDK pihak ketiga yang diterapkan adaptor Anda. Untuk contoh ini, SDK Sampel
memiliki SampleAdListener
dengan callback yang relevan:
Java
@Override public void onAdFetchSucceeded() { interstitialAdCallback = mediationAdLoadCallback.onSuccess(this); } @Override public void onAdFetchFailed(SampleErrorCode errorCode) { mediationAdLoadCallback.onFailure(SampleCustomEventError.createSampleSdkError(errorCode)); }
MediationInterstitialAd
memerlukan penerapan metode showAd()
agar dapat ditampilkan
iklan:
Java
@Override public void showAd(@NonNull Context context) { sampleInterstitialAd.show(); }
Meneruskan peristiwa mediasi ke Google Mobile Ads SDK
Setelah onSuccess()
dipanggil, MediationInterstitialAdCallback
yang ditampilkan
kemudian dapat digunakan oleh adaptor untuk meneruskan kejadian presentasi dari
SDK pihak ketiga ke Google Mobile Ads SDK. Tujuan
Class SampleInterstitialCustomEventLoader
memperluas SampleAdListener
antarmuka untuk meneruskan callback dari jaringan iklan contoh ke Google Seluler
SDK Iklan.
Peristiwa kustom harus meneruskan callback ini sebanyak mungkin memungkinkan, sehingga aplikasi Anda menerima peristiwa yang setara ini dari SDK Iklan Seluler. Berikut adalah contoh penggunaan callback:
Java
@Override public void onAdFullScreen() { interstitialAdCallback.reportAdImpression(); interstitialAdCallback.onAdOpened(); } @Override public void onAdClosed() { interstitialAdCallback.onAdClosed(); }
Ini menyelesaikan penerapan peristiwa kustom untuk iklan interstisial. Lengkap contoh tersedia di GitHub. Anda dapat menggunakannya dengan jaringan iklan yang sudah didukung atau mengubahnya untuk menampilkan iklan interstisial peristiwa kustom.