پیشنیازها
تنظیمات رویدادهای سفارشی را تکمیل کنید.
درخواست تبلیغ جایزهدار
وقتی به ردیف رویداد سفارشی در زنجیره میانجی آبشاری (waterfall mediation chain) میرسید، متد 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.دریافت و گزارش فراخوانیهای رویداد تبلیغاتی به GMA Next Gen 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); }
رویدادهای میانجیگری را به GMA Next Gen SDK ارسال کنید
پس از فراخوانی onSuccess() ، شیء MediationRewardedAdCallback برگردانده شده میتواند توسط آداپتور برای ارسال رویدادهای ارائه از SDK شخص ثالث به GMA Next Gen SDK استفاده شود. کلاس SampleRewardedCustomEventLoader رابط SampleAdListener را برای ارسال تماسهای برگشتی از شبکه تبلیغاتی نمونه به SDK تبلیغات موبایل گوگل (Google Mobile Ads SDK) بسط میدهد.
مهم است که رویداد سفارشی شما تا حد امکان این فراخوانیهای برگشتی را ارسال کند، به طوری که برنامه شما این رویدادهای معادل را از GMA Next Gen 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 موجود است. میتوانید از آن با یک شبکه تبلیغاتی که از قبل پشتیبانی میشود استفاده کنید یا آن را برای نمایش تبلیغات جایزهدار رویداد سفارشی تغییر دهید.