تتيح لك الأحداث المخصّصة إضافة توسّط العرض الإعلاني بدون انقطاع لشبكة مواقع إعلانية ليست شبكة مواقع إعلانية متوافقة. ويمكنك إجراء ذلك من خلال تنفيذ محوِّل حدث مخصّص لشبكة المواقع الإعلانية التي تريد دمجها.
يمكنك العثور على نموذج كامل لمشروع الفعاليات المخصّصة في مستودع 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)
}
}
طلب إعلان
لطلب إعلان، يُرجى الرجوع إلى التعليمات الخاصة بشكل الإعلان: