Prerequisiti
Completa la configurazione degli eventi personalizzati.
Richiedere un annuncio interstitial
Quando l'elemento pubblicitario dell'evento personalizzato viene raggiunto nella catena di mediazione a cascata,
il metodo loadInterstitialAd()
viene chiamato in base al nome della classe che hai fornito
creando un'immagine personalizzata
. In questo caso,
questo metodo è in SampleCustomEvent
, che quindi chiama
Metodo loadInterstitialAd()
in SampleInterstitialCustomEventLoader
.
Per richiedere un annuncio interstitial, crea o modifica una classe che espanda Adapter
per implementare loadInterstitialAd()
. Inoltre, crea un nuovo corso per
implementare MediationInterstitialAd
.
Nel nostro esempio di evento personalizzato,
SampleCustomEvent
estende la classe Adapter
e poi delega a
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
è responsabile delle seguenti attività:
Caricare l'annuncio interstitial e richiamare un
MediationAdLoadCallback
al termine del caricamento.Implementazione dell'interfaccia
MediationInterstitialAd
.Ricezione e generazione di report dai callback di eventi di annuncio all'SDK Google Mobile Ads
Il parametro facoltativo definito nell'interfaccia utente di AdMob è
incluse nella configurazione dell'annuncio. È possibile accedere al parametro tramite
adConfiguration.getServerParameters().getString(MediationConfiguration.CUSTOM_EVENT_SERVER_PARAMETER_FIELD)
.
In genere, questo parametro è un identificatore di unità pubblicitaria
che un SDK della rete pubblicitaria
richiede quando si crea un'istanza di un oggetto annuncio.
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; } }
A seconda che l'annuncio sia stato recuperato correttamente o che abbia riscontrato un errore,
chiamerebbe
onSuccess()
o
onFailure()
.
onSuccess()
viene chiamato passando un'istanza della classe che implementa
MediationInterstitialAd
.
In genere, questi metodi sono implementati all'interno dei callback
SDK di terze parti implementato
dall'adattatore. Per questo esempio, l'SDK di esempio
ha un SampleAdListener
con callback pertinenti:
Java
@Override public void onAdFetchSucceeded() { interstitialAdCallback = mediationAdLoadCallback.onSuccess(this); } @Override public void onAdFetchFailed(SampleErrorCode errorCode) { mediationAdLoadCallback.onFailure(SampleCustomEventError.createSampleSdkError(errorCode)); }
MediationInterstitialAd
richiede l'implementazione di un metodo showAd()
per essere visualizzata
dell'annuncio:
Java
@Override public void showAd(@NonNull Context context) { sampleInterstitialAd.show(); }
Inoltrare gli eventi di mediazione all'SDK Google Mobile Ads
Una volta chiamato onSuccess()
, il valore MediationInterstitialAdCallback
restituito
può quindi essere utilizzato dall'adattatore per inoltrare gli eventi di presentazione
di terze parti all'SDK Google Mobile Ads. La
La classe SampleInterstitialCustomEventLoader
estende la SampleAdListener
per inoltrare i callback dalla rete pubblicitaria di esempio all'interfaccia
SDK Ads.
È importante che l'evento personalizzato inoltri il maggior numero di questi callback possibile, in modo che la tua app riceva questi eventi equivalenti dall'account Google l'SDK Mobile Ads. Ecco un esempio di utilizzo delle richiamate:
Java
@Override public void onAdFullScreen() { interstitialAdCallback.reportAdImpression(); interstitialAdCallback.onAdOpened(); } @Override public void onAdClosed() { interstitialAdCallback.onAdClosed(); }
L'implementazione degli eventi personalizzati per gli annunci interstitial è completata. L'intero è disponibile GitHub. Puoi utilizzarlo con una rete pubblicitaria già supportata o modificarlo in visualizzare annunci interstitial con eventi personalizzati.