تتيح لك الأحداث المخصّصة إضافة توسّط العرض الإعلاني بدون انقطاع لشبكة إعلانية لا تمثّل شبكة إعلانية متوافقة. يمكنك إجراء ذلك من خلال تنفيذ محوّل حدث مخصّص لشبكة الإعلانات التي تريد دمجها.
يمكنك العثور على نموذج كامل لمشروع حدث مخصّص في مستودع GitHub.
المتطلبات الأساسية
قبل أن تتمكّن من إنشاء أحداث مخصّصة، عليك أولاً دمج أحد أشكال الإعلانات التالية في تطبيقك:
إنشاء حدث مخصّص في واجهة المستخدم
يجب أولاً إنشاء حدث مخصّص في واجهة مستخدم AdMob. اطّلِع على التعليمات في مقالة إضافة حدث مخصّص.
يجب تقديم ما يلي:
- اسم الفئة
الاسم المؤهَّل بالكامل للفئة التي تنفّذ محوّل الحدث المخصّص، مثل
com.google.ads.mediation.sample.customevent.SampleCustomEvent
. كأفضل ممارسة، ننصح باستخدام فئة محوّل واحدة لجميع أشكال الإعلانات المخصّصة التي تستخدم أحداثًا مخصّصة.- التصنيف
اسم فريد يحدّد مصدر الإعلان.
- المَعلمة
وسيط سلسلة اختياري يتم تمريره إلى محوّل الأحداث المخصّصة.
إعداد المحوّل
عندما يتم إعداد حزمة "SDK لإعلانات Google على الأجهزة الجوّالة"، يتم استدعاء initialize()
على جميع برامج التكييف التابعة لجهات خارجية المتوافقة والأحداث المخصّصة التي تم إعدادها للتطبيق ضمن واجهة مستخدم AdMob. استخدِم هذه الطريقة لتنفيذ أي عملية إعداد أو تهيئة ضرورية لحزمة تطوير البرامج (SDK) المطلوبة التابعة لجهة خارجية من أجل الحدث المخصّص.
Java
package com.google.ads.mediation.sample.customevent;
import com.google.android.gms.ads.mediation.Adapter;
import com.google.android.gms.ads.mediation.InitializationCompleteCallback;
import com.google.android.gms.ads.mediation.MediationConfiguration;
public class SampleAdNetworkCustomEvent extends Adapter {
private static final String SAMPLE_AD_UNIT_KEY = "parameter";
@Override
public void initialize(Context context,
InitializationCompleteCallback initializationCompleteCallback,
List<MediationConfiguration> mediationConfigurations) {
// This is where you will initialize the SDK that this custom
// event is built for. Upon finishing the SDK initialization,
// call the completion handler with success.
initializationCompleteCallback.onInitializationSucceeded();
}
}
Kotlin
package com.google.ads.mediation.sample.customevent
import com.google.android.gms.ads.mediation.Adapter
import com.google.android.gms.ads.mediation.InitializationCompleteCallback
import com.google.android.gms.ads.mediation.MediationConfiguration
class SampleCustomEvent : Adapter() {
private val SAMPLE_AD_UNIT_KEY = "parameter"
override fun initialize(
context: Context,
initializationCompleteCallback: InitializationCompleteCallback,
mediationConfigurations: List<MediationConfiguration>
) {
// This is where you will initialize the SDK that this custom
// event is built for. Upon finishing the SDK initialization,
// call the completion handler with success.
initializationCompleteCallback.onInitializationSucceeded()
}
}
أرقام إصدارات التقارير
يجب أن تُبلغ جميع الأحداث المخصّصة حزمة تطوير البرامج (SDK) لإعلانات Google على الأجهزة الجوّالة عن إصدار كلّ من مهايئ الأحداث المخصّصة نفسه وإصدار حزمة تطوير البرامج (SDK) التابعة للجهة الخارجية التي تتوافق معها واجهات الأحداث المخصّصة. يتم الإبلاغ عن الإصدارات كعناصر VersionInfo
:
Java
package com.google.ads.mediation.sample.customevent;
public class SampleCustomEvent extends Adapter {
@Override
public VersionInfo getVersionInfo() {
String versionString = new VersionInfo(1, 2, 3);
String[] splits = versionString.split("\\.");
if (splits.length >= 4) {
int major = Integer.parseInt(splits[0]);
int minor = Integer.parseInt(splits[1]);
int micro = Integer.parseInt(splits[2]) * 100 + Integer.parseInt(splits[3]);
return new VersionInfo(major, minor, micro);
}
return new VersionInfo(0, 0, 0);
}
@Override
public VersionInfo getSDKVersionInfo() {
String versionString = SampleAdRequest.getSDKVersion();
String[] splits = versionString.split("\\.");
if (splits.length >= 3) {
int major = Integer.parseInt(splits[0]);
int minor = Integer.parseInt(splits[1]);
int micro = Integer.parseInt(splits[2]);
return new VersionInfo(major, minor, micro);
}
return new VersionInfo(0, 0, 0);
}
}
Kotlin
package com.google.ads.mediation.sample.customevent
class SampleCustomEvent : Adapter() {
override fun getVersionInfo(): VersionInfo {
val versionString = VersionInfo(1,2,3).toString()
val splits: List<String> = versionString.split("\\.")
if (splits.count() >= 4) {
val major = splits[0].toInt()
val minor = splits[1].toInt()
val micro = (splits[2].toInt() * 100) + splits[3].toInt()
return VersionInfo(major, minor, micro)
}
return VersionInfo(0, 0, 0)
}
override fun getSDKVersionInfo(): VersionInfo {
val versionString = VersionInfo(1,2,3).toString()
val splits: List<String> = versionString.split("\\.")
if (splits.count() >= 3) {
val major = splits[0].toInt()
val minor = splits[1].toInt()
val micro = splits[2].toInt()
return VersionInfo(major, minor, micro)
}
return VersionInfo(0, 0, 0)
}
}
طلب عرض إعلان
لطلب إعلان، يُرجى الرجوع إلى التعليمات الخاصة بشكل الإعلان: