الإعلانات المدمجة مع المحتوى هي مواد عرض إعلانية يتم عرضها للمستخدمين من خلال مكوّنات واجهة مستخدم متوافقة مع النظام الأساسي. يتم عرضها باستخدام الفئات نفسها التي تستخدمها حاليًا في لوحات العرض، ويمكن تنسيقها لتتطابق مع التصميم المرئي لتطبيقك.
عند تحميل إعلان مدمج مع المحتوى، يتلقّى تطبيقك عنصر إعلان يحتوي على مواد عرضه، ويكون التطبيق، وليس Google Mobile Ads SDK، مسؤولاً بعد ذلك عن عرضها.
بشكل عام، يتألف عرض الإعلانات المدمجة مع المحتوى بنجاح من جزأين: تحميل إعلان باستخدام حزمة تطوير البرامج (SDK)، ثم عرض محتوى الإعلان في تطبيقك.
توضّح هذه الصفحة كيفية استخدام حزمة تطوير البرامج (SDK) لتحميل الإعلانات المدمجة مع المحتوى.
المتطلبات الأساسية
قبل المتابعة، عليك إعداد Google Mobile Ads SDK.
الاختبار دائمًا باستخدام الإعلانات الاختبارية
عند إنشاء تطبيقاتك واختبارها، احرص على استخدام الإعلانات الاختبارية بدلاً من الإعلانات الفعلية.
أسهل طريقة لتحميل الإعلانات الاختبارية هي استخدام رقم تعريف الوحدة الإعلانية الاختبارية المخصّص للإعلانات المدمجة مع المحتوى على أجهزة iOS:
ca-app-pub-3940256099942544/3986624511
تم إعداد هذا الرقم خصيصًا لعرض إعلانات اختبارية لكل طلب، ويمكنك استخدامه في تطبيقاتك الخاصة أثناء الترميز والاختبار وتحديد الأخطاء وحلّها. ما عليك سوى استبداله برقم تعريف الوحدة الإعلانية الخاص بك قبل نشر تطبيقك.
للاطّلاع على تفاصيل الإعلانات الاختبارية في Google Mobile Ads SDK، يُرجى مراجعة مقالة تفعيل الإعلانات الاختبارية.
تحميل الإعلانات
يتم تحميل الإعلانات المدمجة مع المحتوى باستخدام فئة
GADAdLoader
، التي ترسل رسائل إلى مفوّضيها وفقًا لبروتوكول
GADAdLoaderDelegate.
إعداد أداة تحميل الإعلانات
قبل أن تتمكّن من تحميل إعلان، عليك إعداد أداة تحميل الإعلانات.
يوضّح الرمز التالي كيفية إعداد GADAdLoader:
Swift
استبدِل nativeAdUnitID برقم تعريف الوحدة الإعلانية.
Objective-C
استبدِل kNativeAdUnitID برقم تعريف الوحدة الإعلانية.
ستحتاج إلى رقم تعريف وحدة إعلانية (يمكنك استخدام رقم تعريف الاختبار)، وثوابت لتمريرها في مصفوفة adTypes لتحديد تنسيقات الإعلانات المدمجة مع المحتوى التي تريد طلبها، وأي خيارات تريد ضبطها في المَعلمة options. يمكنك الاطّلاع على قائمة القيم المحتمَلة للمَعلمة options في صفحة ضبط خيارات الإعلانات المدمجة مع المحتوى.
يجب أن تحتوي مصفوفة adTypes على
هذا الثابت :
تنفيذ مفوّض أداة تحميل الإعلانات
على مفوّض أداة تحميل الإعلانات تنفيذ البروتوكولات الخاصة بنوع إعلانك.
بالنسبة إلى الإعلانات المدمجة مع المحتوى، يتضمّن بروتوكول GADNativeAdLoaderDelegate رسالة يتم إرسالها إلى المفوّض عند تحميل إعلان مدمج مع المحتوى.
Swift
func adLoader(_ adLoader: AdLoader, didReceive nativeAd: NativeAd) {
// Set the delegate to receive notifications for interactions with the native ad.
nativeAd.delegate = self
// TODO: Display the native ad.
}
Objective-C
- (void)adLoader:(GADAdLoader *)adLoader didReceiveNativeAd:(GADNativeAd *)nativeAd {
// Set the delegate to receive notifications for interactions with the native ad.
nativeAd.delegate = self;
// TODO: Display the native ad.
}
طلب إدراج الإعلانات
بعد إعداد GADAdLoader، استخدِم الطريقة loadRequest: لطلب إعلان:
Swift
adLoader.load(Request())
Objective-C
[self.adLoader loadRequest:[GADRequest request]];
تقبل الطريقة
loadRequest:
في
GADAdLoader
كائنات
GADRequest
نفسها التي تقبلها إعلانات البانر والإعلانات البينية. يمكنك استخدام كائنات الطلبات لإضافة معلومات الاستهداف، تمامًا كما تفعل مع أنواع الإعلانات الأخرى.
تحميل إعلانات متعدّدة (اختياري)
لتحميل إعلانات متعدّدة في طلب واحد، اضبط الـ
GADMultipleAdsAdLoaderOptions
عند إعداد GADAdLoader.
Swift
Objective-C
يبلغ الحدّ الأقصى لعدد الإعلانات لكل طلب خمسة إعلانات، وليس من المضمون أن تعرض حزمة تطوير البرامج (SDK) العدد المطلوب تمامًا من الإعلانات.
ستكون جميع إعلانات Google المعروضة مختلفة عن بعضها البعض، ولكن ليس من المضمون أن تكون الإعلانات من المخزون المحجوز أو من المشترين التابعين لجهات خارجية فريدة.
لا تستخدِم فئة GADMultipleAdsAdLoaderOptions إذا كنت تستخدم التوسّط، لأنّ طلبات الإعلانات المدمجة مع المحتوى المتعدّدة لا تعمل مع أرقام تعريف الوحدات الإعلانية التي تم إعدادها للتوسّط.
تحديد وقت انتهاء التحميل
بعد أن يستدعي أحد التطبيقات loadRequest:، يمكنه الحصول على نتائج الطلب باستخدام استدعاءات:
adLoader:didFailToReceiveAdWithError:فيGADAdLoaderDelegateadLoader:didReceiveNativeAd:فيGADNativeAdLoaderDelegate
سيؤدي طلب إعلان واحد إلى استدعاء أحد هذين الإجراءَين مرة واحدة.
سيؤدي طلب إعلانات متعدّدة إلى استدعاء واحد على الأقل للإجراءَين أعلاه، ولكن ليس أكثر من الحدّ الأقصى لعدد الإعلانات المطلوبة.
بالإضافة إلى ذلك، يقدّم GADAdLoaderDelegate معاودة الاتصال adLoaderDidFinishLoading. يشير إجراء المفوّض هذا إلى أنّ أداة تحميل الإعلانات قد انتهت من تحميل الإعلانات ولن يتم الإبلاغ عن أي إعلانات أو أخطاء أخرى للطلب. في ما يلي مثال على كيفية استخدامه عند تحميل عدّة إعلانات مدمجة مع المحتوى في آنٍ واحد:
Swift
func adLoaderDidFinishLoading(_ adLoader: AdLoader) {
// The adLoader has finished loading ads.
}
Objective-C
- (void)adLoaderDidFinishLoading:(GADAdLoader *)adLoader {
// The adLoader has finished loading ads.
}
التعامل مع الطلبات التي تعذّر تنفيذها
توسّع البروتوكولات بروتوكول GADAdLoaderDelegate، الذي يحدّد رسالة يتم إرسالها عندما يتعذّر تحميل الإعلانات.
Swift
func adLoader(_ adLoader: AdLoader, didFailToReceiveAdWithError error: any Error) {
// The adLoader failed to receive an ad.
}
Objective-C
- (void)adLoader:(GADAdLoader *)adLoader didFailToReceiveAdWithError:(NSError *)error {
// The adLoader failed to receive an ad.
}
تلقّي إشعارات بشأن أحداث الإعلانات المدمجة مع المحتوى
لتلقّي إشعارات بشأن الأحداث المتعلّقة بتفاعلات الإعلانات المدمجة مع المحتوى، اضبط السمة delegate للإعلان المدمج مع المحتوى:
Swift
nativeAd.delegate = self
Objective-C
nativeAd.delegate = self;
بعد ذلك، نفِّذ
GADNativeAdDelegate
لتلقّي استدعاءات المفوّض التالية:
Swift
func nativeAdDidRecordImpression(_ nativeAd: NativeAd) {
// The native ad was shown.
}
func nativeAdDidRecordClick(_ nativeAd: NativeAd) {
// The native ad was clicked on.
}
func nativeAdWillPresentScreen(_ nativeAd: NativeAd) {
// The native ad will present a full screen view.
}
func nativeAdWillDismissScreen(_ nativeAd: NativeAd) {
// The native ad will dismiss a full screen view.
}
func nativeAdDidDismissScreen(_ nativeAd: NativeAd) {
// The native ad did dismiss a full screen view.
}
func nativeAdWillLeaveApplication(_ nativeAd: NativeAd) {
// The native ad will cause the app to become inactive and
// open a new app.
}
Objective-C
- (void)nativeAdDidRecordImpression:(GADNativeAd *)nativeAd {
// The native ad was shown.
}
- (void)nativeAdDidRecordClick:(GADNativeAd *)nativeAd {
// The native ad was clicked on.
}
- (void)nativeAdWillPresentScreen:(GADNativeAd *)nativeAd {
// The native ad will present a full screen view.
}
- (void)nativeAdWillDismissScreen:(GADNativeAd *)nativeAd {
// The native ad will dismiss a full screen view.
}
- (void)nativeAdDidDismissScreen:(GADNativeAd *)nativeAd {
// The native ad did dismiss a full screen view.
}
- (void)nativeAdWillLeaveApplication:(GADNativeAd *)nativeAd {
// The native ad will cause the app to become inactive and
// open a new app.
}
أفضل الممارسات
اتّبِع هذه القواعد عند تحميل الإعلانات.
يجب أن تخزّن التطبيقات التي تستخدم الإعلانات المدمجة مع المحتوى في قائمة مؤقتًا قائمة الإعلانات.
عند التخزين المؤقت للإعلانات، امحُ ذاكرة التخزين المؤقت وأعِد التحميل بعد ساعة واحدة.
لا تستدعِ
loadRequest:مرة أخرى علىGADAdLoaderإلى أن ينتهي تحميل الطلب السابق ، كما هو موضّح فيadLoaderDidFinishLoading:.اقتصر على تخزين الإعلانات المدمجة مع المحتوى مؤقتًا على ما هو مطلوب فقط. على سبيل المثال، عند التخزين المؤقت، لا تخزِّن مؤقتًا إلا الإعلانات التي تظهر على الشاشة على الفور. تستهلك الإعلانات المدمجة مع المحتوى مساحة كبيرة من الذاكرة، ويؤدي تخزينها مؤقتًا بدون إزالتها إلى استخدام مفرط للذاكرة.
أزِل الإعلانات المدمجة مع المحتوى عندما لا تعود قيد الاستخدام.
عرض إعلانك
بعد تحميل إعلان، ما عليك سوى عرضه للمستخدمين. انتقِل إلى دليل الإعلانات المدمجة مع المحتوى (متقدم) لمعرفة كيفية القيام بذلك.