تتيح لك الأحداث المخصّصة إمكانية إضافة توسّط العرض الإعلاني بدون انقطاع لشبكة إعلانات غير متوافقة . يمكنك إجراء ذلك من خلال تنفيذ محوّل حدث مخصّص لشبكة إعلانات تريد دمجها.
يمكنك العثور على نموذج كامل لمشروع حدث مخصّص في مستودع GitHub repo.
المتطلبات الأساسية
قبل أن تتمكّن من إنشاء أحداث مخصّصة، عليك أولاً دمج أحد أشكال الإعلانات التالية في تطبيقك:
إنشاء حدث مخصّص في واجهة المستخدم
يجب أولاً إنشاء حدث مخصّص في واجهة مستخدم AdMob. يمكنك الاطّلاع على التعليمات في مقالة إضافة حدث مخصّص.
عليك تقديم ما يلي:
- اسم الفئة
الاسم المؤهّل بالكامل للفئة التي تنفّذ محوّل الحدث المخصّص ، مثلاً
com.google.ads.mediation.sample.customevent.SampleCustomEventكأفضل ممارسة، ننصحك باستخدام فئة محوّل واحدة لجميع أشكال إعلانات الحدث المخصص.- التصنيف
اسم فريد يحدّد مصدر الإعلان
- المَعلمة
وسيطة سلسلة اختيارية يتم تمريرها إلى محوّل الحدث المخصّص
إعداد المحوّل
عند إعداد GMA Next-Gen SDK، يتم استدعاء
initialize()
على جميع المحوّلات التابعة لجهات خارجية المتوافقة والأحداث المخصّصة التي تم إعدادها
للتطبيق ضمن واجهة مستخدم AdMob. استخدِم هذه الطريقة لإجراء أي إعداد أو تهيئة ضرورية على حزمة تطوير البرامج (SDK) المطلوبة التابعة لجهة خارجية من أجل الحدث المخصّص.
جافا
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()
}
}
الإبلاغ عن أرقام الإصدارات
يجب أن تُبلغ جميع الأحداث المخصّصة GMA Next-Gen SDK عن إصدار
محوّل الحدث المخصّص نفسه وإصدار حزمة تطوير البرامج (SDK) التابعة لجهة خارجية التي يتفاعل معها الحدث المخصّص. يتم الإبلاغ عن الإصدارات كـ
VersionInfo
كائنات:
جافا
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)
}
}
طلب إعلان
لطلب إعلان، يُرجى الرجوع إلى التعليمات الخاصة بشكل الإعلان: