الإعلانات البينية

اختيار النظام الأساسي: Android جديد Android iOS Unity Flutter

"الإعلانات البينية" هي إعلانات بملء الشاشة تغطي واجهة التطبيق المضيف. وعادةً ما تظهر في نقاط الانتقال العادية في تدفق التطبيقات، مثلاً بين الأنشطة أو أثناء فترة الإيقاف المؤقت بين المستويات في الألعاب. عندما يعرض أحد التطبيقات "إعلانًا بينيًا"، يكون لدى المستخدم خيار النقر على الإعلان والانتقال إلى وجهته أو إغلاقه والعودة إلى التطبيق. يمكنك الاطّلاع على إحدى دراسات الحالة.

يشرح هذا الدليل كيفية دمج "الإعلانات البينية" في تطبيق Android.

المتطلبات الأساسية

الاختبار دائمًا باستخدام "الإعلانات الاختبارية"

عند إنشاء تطبيقاتك واختبارها، تأكَّد من استخدام "الإعلانات الاختبارية" بدلاً من الإعلانات الفعلية المعروضة للمستخدمين. وإلا قد يتم تعليق حسابك.

أسهل طريقة لتحميل "الإعلانات الاختبارية" هي استخدام رقم تعريف الوحدة الإعلانية الاختبارية المخصّص "للإعلانات البينية" على Android:

ca-app-pub-3940256099942544/1033173712

تم إعداد هذا الرقم خصيصًا لعرض "الإعلانات الاختبارية" لكل طلب، ويمكنك استخدامه في تطبيقاتك أثناء الترميز والاختبار وتحديد الأخطاء وحلّها. ما عليك سوى استبداله برقم تعريف الوحدة الإعلانية الخاص بك قبل نشر تطبيقك.

للحصول على تفاصيل عن Google Mobile Ads SDK الإعلانات الاختبارية، يُرجى الاطّلاع على مقالة تفعيل "الإعلانات الاختبارية".

تحميل إعلان

لتحميل "إعلان بيني"، استخدِم طريقة InterstitialAd static load() وأدخِل InterstitialAdLoadCallback لتلقّي الإعلانات التي تم تحميلها أو أي أخطاء محتمَلة. يُرجى العِلم أنّ InterstitialAdLoadCallback، مثل عمليات معاودة الاتصال الأخرى لتحميل أشكال الإعلانات، تستخدِم LoadAdError لتقديم تفاصيل أكثر دقة عن الخطأ.

جافا

InterstitialAd.load(
    this,
    AD_UNIT_ID,
    new AdRequest.Builder().build(),
    new InterstitialAdLoadCallback() {
      @Override
      public void onAdLoaded(@NonNull InterstitialAd interstitialAd) {
        Log.d(TAG, "Ad was loaded.");
        MyActivity.this.interstitialAd = interstitialAd;
      }

      @Override
      public void onAdFailedToLoad(@NonNull LoadAdError loadAdError) {
        Log.d(TAG, loadAdError.getMessage());
        interstitialAd = null;
      }
    });

Kotlin

InterstitialAd.load(
  this,
  AD_UNIT_ID,
  AdRequest.Builder().build(),
  object : InterstitialAdLoadCallback() {
    override fun onAdLoaded(ad: InterstitialAd) {
      Log.d(TAG, "Ad was loaded.")
      interstitialAd = ad
    }

    override fun onAdFailedToLoad(adError: LoadAdError) {
      Log.d(TAG, adError.message)
      interstitialAd = null
    }
  },
)

ضبط FullScreenContentCallback

تعالج FullScreenContentCallback الأحداث المرتبطة بعرض InterstitialAd. قبل عرض InterstitialAd، تأكَّد من ضبط معاودة الاتصال:

جافا

interstitialAd.setFullScreenContentCallback(
    new FullScreenContentCallback() {
      @Override
      public void onAdDismissedFullScreenContent() {
        // Called when fullscreen content is dismissed.
        Log.d(TAG, "The ad was dismissed.");
        // Make sure to set your reference to null so you don't
        // show it a second time.
        MyActivity.this.interstitialAd = null;
      }

      @Override
      public void onAdFailedToShowFullScreenContent(AdError adError) {
        // Called when fullscreen content failed to show.
        Log.d(TAG, "The ad failed to show.");
        // Make sure to set your reference to null so you don't
        // show it a second time.
        MyActivity.this.interstitialAd = null;
      }

      @Override
      public void onAdShowedFullScreenContent() {
        // Called when fullscreen content is shown.
        Log.d(TAG, "The ad was shown.");
      }

      @Override
      public void onAdImpression() {
        // Called when an impression is recorded for an ad.
        Log.d(TAG, "The ad recorded an impression.");
      }

      @Override
      public void onAdClicked() {
        // Called when ad is clicked.
        Log.d(TAG, "The ad was clicked.");
      }
    });

Kotlin

interstitialAd?.fullScreenContentCallback =
  object : FullScreenContentCallback() {
    override fun onAdDismissedFullScreenContent() {
      // Called when fullscreen content is dismissed.
      Log.d(TAG, "Ad was dismissed.")
      // Don't forget to set the ad reference to null so you
      // don't show the ad a second time.
      interstitialAd = null
    }

    override fun onAdFailedToShowFullScreenContent(adError: AdError) {
      // Called when fullscreen content failed to show.
      Log.d(TAG, "Ad failed to show.")
      // Don't forget to set the ad reference to null so you
      // don't show the ad a second time.
      interstitialAd = null
    }

    override fun onAdShowedFullScreenContent() {
      // Called when fullscreen content is shown.
      Log.d(TAG, "Ad showed fullscreen content.")
    }

    override fun onAdImpression() {
      // Called when an impression is recorded for an ad.
      Log.d(TAG, "Ad recorded an impression.")
    }

    override fun onAdClicked() {
      // Called when ad is clicked.
      Log.d(TAG, "Ad was clicked.")
    }
  }

عرض الإعلان

يجب عرض "الإعلانات البينية" أثناء فترات الإيقاف المؤقت العادية في تدفق التطبيق. ومن الأمثلة الجيدة على ذلك بين مستويات اللعبة أو بعد أن يُكمل المستخدم مهمة. لعرض "إعلان بيني"، استخدِم طريقة show().

جافا

if (interstitialAd != null) {
  interstitialAd.show(this);
} else {
  Log.d(TAG, "The interstitial ad is still loading.");
}

Kotlin

interstitialAd?.show(this)

بعض أفضل الممارسات

حدِّد ما إذا كانت "الإعلانات البينية" هي نوع الإعلان المناسب لتطبيقك.
تحقّق "الإعلانات البينية" أفضل أداء في التطبيقات التي تتضمّن نقاط انتقال عادية. ويُنشئ إكمال مهمة في التطبيق، مثل مشاركة صورة أو إنهاء مستوى في اللعبة، نقطة انتقال من هذا النوع. تأكَّد من تحديد النقاط في سير عمل تطبيقك التي ستعرض فيها "الإعلانات البينية" وكيف من المرجّح أن يتفاعل المستخدم معها.
تذكَّر إيقاف الإجراء مؤقتًا عند عرض "إعلان بيني".
هناك العديد من أنواع "الإعلانات البينية" المختلفة: الإعلانات النصية والإعلانات المصوّرة وإعلانات الفيديو وغيرها. من المهم التأكّد من أنّ تطبيقك يعلّق أيضًا استخدام بعض الموارد عندما يعرض "إعلانًا بينيًا" للسماح للإعلان بالاستفادة منها. على سبيل المثال، عند إجراء طلب عرض "إعلان بيني"، تأكَّد من إيقاف أي مصدر إخراج للصوت مؤقتًا يتم إنتاجه من خلال تطبيقك.
اسمح بوقت تحميل كافٍ.
كما أنّه من المهم التأكّد من عرض "الإعلانات البينية" في وقت مناسب، من المهم أيضًا التأكّد من عدم اضطرار المستخدم إلى الانتظار حتى يتم تحميلها. يمكن أن يضمن تحميل الإعلان مسبقًا من خلال استدعاء load() قبل أن تنوي استدعاء show() أن يكون تطبيقك جاهزًا لعرض "إعلان بيني" تم تحميله بالكامل عندما يحين وقت عرضه.
عدم عرض كمّ هائل من الإعلانات للمستخدمين
زيادة معدّل تكرار "الإعلانات البينية" في تطبيقك قد تبدو ملائمة لزيادة الإيرادات، لكنّها قد تؤدي أيضًا إلى تدهور تجربة المستخدم وانخفاض نسب النقر إلى الظهور. يجب الحرص على عدم مقاطعة تجربة المستخدمين بشكل متكرر بما يحول دون استمتاعهم بتطبيقك.

رمز مصدر

أمثلة على GitHub

  • مثال على "الإعلانات البينية": جافا | Kotlin

قصص النجاح

الخطوات التالية