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