Нативные объявления

Выберите платформу: Android (бета-версия) Новоизбранный Android iOS

Когда загружается нативная реклама, GMA Next-Gen SDK вызывает обработчик для соответствующего формата рекламы. Затем ваше приложение отвечает за отображение рекламы, хотя это не обязательно должно происходить немедленно. Чтобы упростить отображение системно определенных форматов рекламы, SDK предлагает несколько полезных ресурсов, описанных ниже.

Определите класс NativeAdView

Определите класс NativeAdView . Этот класс является классом ViewGroup и представляет собой контейнер верхнего уровня для класса NativeAdView . Каждое представление нативной рекламы содержит нативные рекламные ресурсы, такие как элемент представления MediaView или элемент представления Title , которые должны быть дочерними элементами объекта NativeAdView .

XML-макет

Добавьте XML- NativeAdView в свой проект:

<com.google.android.libraries.ads.mobile.sdk.nativead.NativeAdView
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">
    <LinearLayout
    android:orientation="vertical">
        <LinearLayout
        android:orientation="horizontal">
          <ImageView
          android:id="@+id/ad_app_icon" />
          <TextView
            android:id="@+id/ad_headline" />
        </LinearLayout>
        <!--Add remaining assets such as the image and media view.-->
    </LinearLayout>
</com.google.android.libraries.ads.mobile.sdk.nativead.NativeAdView>

Композитор Jetpack

Включите модуль JetpackComposeDemo/compose-util , который содержит вспомогательные функции для компоновки NativeAdView и его ресурсов.

С помощью модуля compose-util создайте NativeAdView :

  import com.google.android.gms.compose_util.NativeAdAttribution
  import com.google.android.gms.compose_util.NativeAdView

  @Composable
  /** Display a native ad with a user defined template. */
  fun DisplayNativeAdView(nativeAd: NativeAd) {
      NativeAdView {
          // Display the ad attribution.
          NativeAdAttribution(text = context.getString("Ad"))
          // Add remaining assets such as the image and media view.
        }
    }

Обработка загруженной нативной рекламы

Когда загружается нативная реклама, обработайте событие обратного вызова, создайте представление нативной рекламы и добавьте его в иерархию представлений:

Котлин

// Build an ad request with native ad options to customize the ad.
val adTypes = listOf(NativeAd.NativeAdType.NATIVE)
val adRequest = NativeAdRequest
  .Builder("/21775744923/example/native", adTypes)
  .build()

val adCallback =
  object : NativeAdLoaderCallback {
    override fun onNativeAdLoaded(nativeAd: NativeAd) {
      activity?.runOnUiThread {

        val nativeAdBinding = NativeAdBinding.inflate(layoutInflater)
        val adView = nativeAdBinding.root
        val frameLayout = myActivityLayout.nativeAdPlaceholder

        // Populate and register the native ad asset views.
        displayNativeAd(nativeAd, nativeAdBinding)

        // Remove all old ad views and add the new native ad
        // view to the view hierarchy.
        frameLayout.removeAllViews()
        frameLayout.addView(adView)
      }
    }
  }

// Load the native ad with our request and callback.
NativeAdLoader.load(adRequest, adCallback)

Java

// Build an ad request with native ad options to customize the ad.
List<NativeAd.NativeAdType> adTypes = Arrays.asList(NativeAd.NativeAdType.NATIVE);
NativeAdRequest adRequest = new NativeAdRequest
                                .Builder("/21775744923/example/native", adTypes)
                                .build();

NativeAdLoaderCallback adCallback = new NativeAdLoaderCallback() {
    @Override
    public void onNativeAdLoaded(NativeAd nativeAd) {
      if (getActivity() != null) {
        getActivity()
          .runOnUiThread(() -> {
            // Inflate the native ad view and add it to the view hierarchy.
            NativeAdBinding nativeAdBinding = NativeAdBinding.inflate(getLayoutInflater());
            NativeAdView adView = (NativeAdView) nativeAdBinding.getRoot();
            FrameLayout frameLayout = myActivityLayout.nativeAdPlaceholder;

            // Populate and register the native ad asset views.
            displayNativeAd(nativeAd, nativeAdBinding);

            // Remove all old ad views and add the new native ad
            // view to the view hierarchy.
            frameLayout.removeAllViews();
            frameLayout.addView(adView);
        });
      }
    }
};

// Load the native ad with our request and callback.
NativeAdLoader.load(adRequest, adCallback);

Обратите внимание, что все ресурсы для данной нативной рекламы должны отображаться внутри макета NativeAdView . GMA Next-Gen SDK пытается вывести предупреждение, если нативные ресурсы отображаются вне макета представления нативной рекламы.

Классы представлений рекламы также предоставляют методы для регистрации представления, используемого для каждого отдельного ресурса, и метод для регистрации самого объекта NativeAd . Такая регистрация представлений позволяет SDK автоматически обрабатывать такие задачи, как:

  • Запись щелчков
  • Запись показов при появлении первого пикселя на экране.
  • Отображение всплывающего окна AdChoices для нативных рекламных креативов, заполняющих пустые позиции — в настоящее время доступно только избранной группе издателей.

Показать нативную рекламу

Следующий пример демонстрирует, как отобразить нативную рекламу:

Котлин

private fun displayNativeAd(nativeAd: NativeAd, nativeAdBinding : NativeAdBinding) {
  // Set the native ad view elements.
  val nativeAdView = nativeAdBinding.root
  nativeAdView.advertiserView = nativeAdBinding.adAdvertiser
  nativeAdView.bodyView = nativeAdBinding.adBody
  nativeAdView.callToActionView = nativeAdBinding.adCallToAction
  nativeAdView.headlineView = nativeAdBinding.adHeadline
  nativeAdView.iconView = nativeAdBinding.adAppIcon
  nativeAdView.priceView = nativeAdBinding.adPrice
  nativeAdView.starRatingView = nativeAdBinding.adStars
  nativeAdView.storeView = nativeAdBinding.adStore

  // Set the view element with the native ad assets.
  nativeAdBinding.adAdvertiser.text = nativeAd.advertiser
  nativeAdBinding.adBody.text = nativeAd.body
  nativeAdBinding.adCallToAction.text = nativeAd.callToAction
  nativeAdBinding.adHeadline.text = nativeAd.headline
  nativeAdBinding.adAppIcon.setImageDrawable(nativeAd.icon?.drawable)
  nativeAdBinding.adPrice.text = nativeAd.price
  nativeAd.starRating?.toFloat().let { value ->
    nativeAdBinding.adStars.rating = value
  }
  nativeAdBinding.adStore.text = nativeAd.store

  // Hide views for assets that don't have data.
  nativeAdBinding.adAdvertiser.visibility = getAssetViewVisibility(nativeAd.advertiser)
  nativeAdBinding.adBody.visibility = getAssetViewVisibility(nativeAd.body)
  nativeAdBinding.adCallToAction.visibility = getAssetViewVisibility(nativeAd.callToAction)
  nativeAdBinding.adHeadline.visibility = getAssetViewVisibility(nativeAd.headline)
  nativeAdBinding.adAppIcon.visibility = getAssetViewVisibility(nativeAd.icon)
  nativeAdBinding.adPrice.visibility = getAssetViewVisibility(nativeAd.price)
  nativeAdBinding.adStars.visibility = getAssetViewVisibility(nativeAd.starRating)
  nativeAdBinding.adStore.visibility = getAssetViewVisibility(nativeAd.store)

  // Inform GMA Next-Gen SDK that you have finished populating
  // the native ad views with this native ad.
  nativeAdView.registerNativeAd(nativeAd, nativeAdBinding.adMedia)
}

/**
* Determines the visibility of an asset view based on the presence of its asset.
*
* @param asset The native ad asset to check for nullability.
* @return [View.VISIBLE] if the asset is not null, [View.INVISIBLE] otherwise.
*/
private fun getAssetViewVisibility(asset: Any?): Int {
  return if (asset == null) View.INVISIBLE else View.VISIBLE
}

Java

private void displayNativeAd(ad: NativeAd, nativeAdBinding : NativeAdBinding) {
  // Set the native ad view elements.
  NativeAdView nativeAdView = nativeAdBinding.getRoot();
  nativeAdView.setAdvertiserView(nativeAdBinding.adAdvertiser);
  nativeAdView.setBodyView(nativeAdBinding.adBody);
  nativeAdView.setCallToActionView(nativeAdBinding.adCallToAction);
  nativeAdView.setHeadlineView(nativeAdBinding.adHeadline);
  nativeAdView.setIconView(nativeAdBinding.adAppIcon);
  nativeAdView.setPriceView(nativeAdBinding.adPrice);
  nativeAdView.setStarRatingView(nativeAdBinding.adStars);
  nativeAdView.setStoreView(nativeAdBinding.adStore);

  // Set the view element with the native ad assets.
  nativeAdBinding.adAdvertiser.setText(nativeAd.getAdvertiser());
  nativeAdBinding.adBody.setText(nativeAd.getBody());
  nativeAdBinding.adCallToAction.setText(nativeAd.getCallToAction());
  nativeAdBinding.adHeadline.setText(nativeAd.getHeadline());
  if (nativeAd.getIcon() != null) {
      nativeAdBinding.adAppIcon.setImageDrawable(nativeAd.getIcon().getDrawable());
  }
  nativeAdBinding.adPrice.setText(nativeAd.getPrice());
  if (nativeAd.getStarRating() != null) {
      nativeAdBinding.adStars.setRating(nativeAd.getStarRating().floatValue());
  }
  nativeAdBinding.adStore.setText(nativeAd.getStore());

  // Hide views for assets that don't have data.
  nativeAdBinding.adAdvertiser.setVisibility(getAssetViewVisibility(nativeAd.getAdvertiser()));
  nativeAdBinding.adBody.setVisibility(getAssetViewVisibility(nativeAd.getBody()));
  nativeAdBinding.adCallToAction.setVisibility(getAssetViewVisibility(nativeAd.getCallToAction()));
  nativeAdBinding.adHeadline.setVisibility(getAssetViewVisibility(nativeAd.getHeadline()));
  nativeAdBinding.adAppIcon.setVisibility(getAssetViewVisibility(nativeAd.getIcon()));
  nativeAdBinding.adPrice.setVisibility(getAssetViewVisibility(nativeAd.getPrice()));
  nativeAdBinding.adStars.setVisibility(getAssetViewVisibility(nativeAd.getStarRating()));
  nativeAdBinding.adStore.setVisibility(getAssetViewVisibility(nativeAd.getStore()));

  // Inform GMA Next-Gen SDK that you have finished populating
  // the native ad views with this native ad.
  nativeAdView.registerNativeAd(nativeAd, nativeAdBinding.adMedia);
}

/**
* Determines the visibility of an asset view based on the presence of its asset.
*
* @param asset The native ad asset to check for nullability.
* @return {@link View#VISIBLE} if the asset is not null, {@link View#INVISIBLE} otherwise.
*/
private int getAssetViewVisibility(Object asset) {
    return (asset == null) ? View.INVISIBLE : View.VISIBLE;
}

Наложение AdChoices

При получении запроса на добавление рекламы в фоновое изображение, SDK добавляет наложение AdChoices в качестве рекламного окна. Если ваше приложение использует нативную рекламу в качестве фонового изображения, оставьте место в нужном углу для автоматически вставляемого логотипа AdChoices. Также важно, чтобы наложение AdChoices было видно, поэтому выбирайте соответствующие цвета и изображения фона. Для получения дополнительной информации о внешнем виде и функциях наложения обратитесь к рекомендациям по реализации программной нативной рекламы .

Атрибуция рекламы для программной нативной рекламы

При показе программной нативной рекламы необходимо указывать атрибуцию объявления, чтобы обозначить, что просмотр является рекламным. Подробнее см. в наших правилах .

Обработка кликов

Не следует реализовывать собственные обработчики кликов для каких-либо представлений поверх или внутри нативного рекламного представления. Клики по ресурсам рекламного представления обрабатываются SDK при условии правильного заполнения и регистрации этих ресурсов.

Для отслеживания кликов реализуйте функцию обратного вызова для обработки кликов в GMA Next-Gen SDK:

Котлин

private fun setEventCallback(nativeAd: NativeAd) {
  nativeAd.adEventCallback =
    object : NativeAdEventCallback {
      override fun onAdClicked() {
        Log.d(Constant.TAG, "Native ad recorded a click.")
      }
    }
}

Java

private void setEventCallback(NativeAd nativeAd) {
  nativeAd.setAdEventCallback(new NativeAdEventCallback() {
      @Override
      public void onAdClicked() {
        Log.d(Constant.TAG, "Native ad recorded a click.");
      }
  });
}

ImageScaleType

Класс MediaView имеет свойство ImageScaleType при отображении изображений. Если вы хотите изменить масштаб изображения в MediaView , установите соответствующий ImageView.ScaleType с помощью метода setImageScaleType() класса MediaView :

Котлин

nativeAdViewBinding.mediaView.imageScaleType = ImageView.ScaleType.CENTER_CROP

Java

nativeAdViewBinding.mediaView.setImageScaleType(ImageView.ScaleType.CENTER_CROP);

Медиаконтент

Класс MediaContent содержит данные, относящиеся к медиаконтенту нативной рекламы, которая отображается с помощью класса MediaView . Когда свойство MediaView класса mediaContent задано экземпляром MediaContent :

  • Если видеофайл доступен, он буферизуется и начинает воспроизводиться внутри MediaView . О наличии видеофайла можно судить по значению метода hasVideoContent() .

  • Если в рекламе отсутствует видеофайл, то вместо него загружается и помещается в MediaView файл mainImage .

Уничтожить рекламу

После показа нативной рекламы удалите её. В следующем примере показано удаление нативной рекламы:

Котлин

nativeAd.destroy()

Java

nativeAd.destroy();

Тестовый код нативной рекламы

Реклама, продаваемая напрямую

Если вы хотите протестировать работу нативной рекламы, продаваемой напрямую, вы можете использовать этот идентификатор рекламного блока в Ad Manager:

/21775744923/example/native

Он настроен на показ примеров рекламы установки приложений и контента, а также пользовательского формата нативной рекламы со следующими элементами:

  • Заголовок (текст)
  • MainImage (изображение)
  • Подпись (текст)

Идентификатор шаблона для пользовательского формата нативной рекламы — 10063170 .

Нативная реклама для заполнения пробелов

Функция заполнения данных в Ad Exchange доступна только для ограниченного числа издателей. Для проверки работы нативных объявлений, используемых для заполнения данных, используйте этот рекламный блок в Ad Manager:

/21775744923/example/native-backfill

Здесь отображаются примеры рекламных объявлений для установки приложений и контента, включающие всплывающее окно AdChoices.

Перед запуском не забудьте обновить код, указав в нем фактические идентификаторы вашего рекламного блока и шаблона.

Следующие шаги

Изучите следующие темы:

Пример

Загрузите и запустите пример приложения , демонстрирующий использование GMA Next-Gen SDK.