تسهّل حِزم تطوير البرامج (SDK) لإعلانات الوسائط التفاعلية دمج إعلانات الوسائط المتعددة في مواقعك الإلكترونية وتطبيقاتك. يمكن لحِزم تطوير البرامج لإعلانات الوسائط التفاعلية طلب الإعلانات من أي خادم إعلانات متوافق مع VAST وإدارة تشغيل الإعلانات في تطبيقاتك. باستخدام حِزم تطوير البرامج لإدراج الإعلانات الديناميكي في "إعلانات الوسائط التفاعلية"، تقدّم التطبيقات طلب بث لإعلان وفيديو محتوى، سواء كان فيديو عند الطلب أو محتوى مباشر. بعد ذلك، تعرض حزمة SDK بث فيديو مدمجًا، ما يغنيك عن إدارة التبديل بين الفيديو الإعلاني وفيديو المحتوى داخل تطبيقك.
اختيار حلّ "الإعلانات الديناميكية أثناء عرض الفيديو" الذي يهمّك
إدراج إعلان ديناميكي شامل
يوضّح هذا الدليل كيفية دمج حزمة تطوير البرامج (SDK) الخاصة بـ "إعلانات الوسائط التفاعلية" (IMA) في تطبيق بسيط لمشغّل فيديو. إذا أردت الاطّلاع على نموذج تكامل مكتمل أو اتّباعه، يمكنك تنزيل BasicExample من GitHub.
نظرة عامة على ميزة "إدراج الإعلان الديناميكي" في IMA
يتضمّن تنفيذ "إعلانات البث المباشر" في "إعلانات الوسائط التفاعلية" أربعة مكوّنات رئيسية في حزمة SDK كما هو موضّح في هذا الدليل:
-
StreamDisplayContainer: هو عنصر حاوٍ يقع في أعلى عنصر تشغيل الفيديو ويحتوي على عناصر واجهة مستخدم الإعلان. -
AdsLoader: عنصر يطلب بث المحتوى ويتعامل مع الأحداث التي يتم تشغيلها بواسطة عناصر الرد على طلب بث المحتوى. يجب إنشاء أداة تحميل إعلانات واحدة فقط، ويمكن إعادة استخدامها طوال مدة تشغيل التطبيق. -
StreamRequest: كائن يحدّد طلب بث. يمكن أن تكون طلبات البث المباشر لفيديوهات عند الطلب أو أحداث بث مباشر. تحدّد طلبات البث المباشر مفتاح مادة عرض، بينما تحدّد طلبات الفيديو عند الطلب معرّفًا في "نظام إدارة المحتوى" ومعرّف فيديو. يمكن أن يتضمّن كلا نوعَي الطلبات اختياريًا مفتاح واجهة برمجة التطبيقات اللازم للوصول إلى عمليات البث المحدّدة، ومعرِّف شبكة "إدارة إعلانات Google" لكي تتعامل حزمة تطوير البرامج للإعلانات التفاعلية مع معرّفات الإعلانات على النحو المحدّد في إعدادات "إدارة إعلانات Google". StreamManager: عنصر يعالج عمليات بث "إدراج الإعلان الديناميكي" والتفاعلات مع الخلفية البرمجية لميزة "إدراج الإعلان الديناميكي". يتولّى مدير البث أيضًا معالجة طلبات اختبار الاتصال الخاصة بالتتبُّع وإعادة توجيه أحداث البث والإعلانات إلى الناشر.
المتطلبات الأساسية
- استوديو Android
- تطبيق مشغّل فيديو نموذجي لدمج حزمة تطوير البرامج (SDK)
تنزيل تطبيق مشغّل الفيديو النموذجي وتشغيله
يوفّر نموذج التطبيق مشغّل فيديو يعمل على تشغيل فيديو HLS. استخدِم هذا كنقطة بداية لدمج إمكانات "الإعلانات الديناميكية أثناء البث" في حزمة تطوير البرامج (SDK) الخاصة بـ "الإعلانات الديناميكية أثناء البث" من "إعلانات الوسائط التفاعلية".
نزِّل تطبيق مشغّل الفيديو التجريبي واستخرِجه.
ابدأ تشغيل "استوديو Android" وانقر على فتح مشروع حالي في "استوديو Android"، أو إذا كان "استوديو Android" قيد التشغيل، انقر على ملف > جديد > استيراد مشروع. بعد ذلك، انقر على
SampleVideoPlayer/build.gradle.أجرِ عملية مزامنة Gradle من خلال النقر على أدوات > Android > مزامنة المشروع مع ملفات Gradle.
تأكَّد من أنّ تطبيق المشغّل يتم تجميعه وتشغيله على جهاز Android فعلي أو الجهاز الافتراضي المتوافق مع Android باستخدام تشغيل > تشغيل "التطبيق". من الطبيعي أن يستغرق تحميل بث الفيديو بضع ثوانٍ قبل تشغيله.
فحص مشغّل الفيديو النموذجي
لا يحتوي مشغّل الفيديو النموذجي على أي رمز دمج لحزمة تطوير البرامج (SDK) الخاصة بـ "الإعلانات الديناميكية أثناء عرض الفيديو" حتى الآن. يتألف نموذج التطبيق من جزأين رئيسيَّين:
samplevideoplayer/SampleVideoPlayer.java: مشغّل HLS مستند إلى ExoPlayer يشكّل الأساس لدمج "الإعلانات الديناميكية أثناء البث" من "إعلانات الوسائط التفاعلية".videoplayerapp/MyActivity.java: ينشئ هذا النشاط مشغّل الفيديو ويُمرّر إليهContextوmedia3.ui.PlayerView.
إضافة حزمة تطوير البرامج (SDK) الخاصة بـ "الإعلانات الديناميكية أثناء البث" من "الإعلانات التفاعلية" إلى تطبيق المشغّل
يجب أيضًا تضمين إشارة إلى حزمة تطوير البرامج لإعلانات الوسائط التفاعلية (DAI). في "استوديو Android"، أضِف ما يلي إلى ملف build.gradle على مستوى التطبيق، والذي يقع في app/build.gradle. تتطلّب حزمة تطوير البرامج لإعلانات الوسائط التفاعلية تفعيل ميزة إزالة التجميل اللغوي في المكتبة، ويجب إجراء ذلك من خلال ضبط coreLibraryDesugaringEnabled true وإضافة 'com.android.tools:desugar_jdk_libs' كاعتمادية في ملف build.gradle. لمزيد من التفاصيل، يُرجى الاطّلاع على
واجهات برمجة التطبيقات Java 11 والإصدارات الأحدث المتاحة من خلال إزالة التجميل اللغوي باستخدام مواصفات nio.
دمج "حزمة تطوير البرامج للإعلانات التفاعلية" (IMA) الخاصة بـ "الإعلانات الديناميكية أثناء البث" (DAI)
أنشئ فئة جديدة باسم
SampleAdsWrapperفي حزمةvideoplayerapp(فيapp/java/com.google.ads.interactivemedia.v3.samples/videoplayerapp/) لتضمينSampleVideoPlayerالحالي وإضافة منطق لتنفيذ IMA DAI. لإجراء ذلك، يجب أولاً إنشاءAdsLoaderيُستخدَم لطلب بث "إدراج الإعلان الديناميكي".يتضمّن هذا المقتطف مَعلمات نموذجية لبروتوكولَي HLS وDASH، ولأحداث البث المباشر والفيديوهات عند الطلب. لضبط مصدر البيانات الذي يتم تشغيله، عدِّل المتغيّر
CONTENT_TYPE.أنشئ طريقة مساعدة
createSampleVideoPlayerCallback()للتعامل مع إنشاء مثيل واجهةSampleVideoPlayerCallbackالذي يوسّعVideoStreamPlayer.VideoStreamPlayerCallback.لإتاحة استخدام "الإعلانات الديناميكية أثناء عرض الفيديو"، يجب أن يمرِّر مشغّل الفيديو أحداث ID3 إلى حزمة تطوير البرامج "الإعلانات الديناميكية أثناء عرض الفيديو" من "إعلانات الوسائط التفاعلية". تنفّذ الطريقة
callback.onUserTextReceived()هذه العملية، كما هو موضّح في نموذج الرمز البرمجي التالي.أضِف طريقة
buildStreamRequest()لإنشاءSteamRequest. تتيح هذه الطريقة التبديل بين تدفقات مختلفة استنادًا إلى كيفية ضبط المتغيّرCONTENT_TYPE. إنّ البث التلقائي المستخدَم في هذا الدليل هو عيّنة بث HLS عند الطلب من IMA.تحتاج أيضًا إلى
VideoStreamPlayerلتشغيل البث، لذا أضِف طريقةcreateVideoStreamPlayer()تنشئ فئة مجهولة الهوية تنفّذVideoStreamPlayer.نفِّذ أدوات معالجة الأحداث المطلوبة وأضِف إمكانية معالجة الأخطاء.
لاحظ تنفيذ
AdErrorListener، لأنّه يستدعي عنوان URL احتياطيًا في حال تعذّر تشغيل الإعلانات. بما أنّ المحتوى والإعلانات مضمّنة في بث واحد، يجب أن تكون مستعدًا لطلب بث احتياطي في حال حدوث خطأ في بث "الإعلانات الديناميكية أثناء عرض الفيديو".أضِف رمزًا لتسجيل الدخول.
عدِّل
MyActivityفيvideoplayerappلإنشاء مثيل واستدعاءSampleAdsWrapper. يمكنك أيضًا إجراء مكالمة إلىImaSdkFactory.initialize()هنا باستخدام طريقة مساعدة لإنشاء مثيلImaSdkSettings.أضِف طريقة المساعد
getImaSdkSettings()لإنشاء مثيلImaSdkSettings.عدِّل ملف تصميم النشاط
activity_my.xmlلإضافة عناصر واجهة المستخدم الخاصة بالتسجيل.
تهانينا! أنت الآن بصدد طلب إعلانات الفيديو وعرضها في تطبيق Android. ولتحسين عملية التنفيذ، راجِع الإشارات المرجعية وSnapback ومستندات واجهة برمجة التطبيقات.
تحديد المشاكل وحلّها
إذا كنت تواجه مشاكل في تشغيل إعلان فيديو، جرِّب تنزيل BasicExample المكتمل. إذا كان يعمل بشكل صحيح في BasicExample، من المحتمل أن تكون هناك مشكلة في رمز دمج "إعلانات الوسائط التفاعلية" في تطبيقك.
إذا استمرّت المشاكل، يُرجى الانتقال إلى منتدى حزمة تطوير البرامج للإعلانات التفاعلية.