Настройка

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

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

Полный пример проекта с пользовательскими событиями можно найти в нашем репозитории на GitHub .

Предварительные требования

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

Создайте пользовательское событие в пользовательском интерфейсе.

Сначала необходимо создать пользовательское событие в пользовательском интерфейсе AdMob. См. инструкции в разделе «Добавление пользовательского события» .

Вам необходимо предоставить следующую информацию:

Название класса

Полное имя класса, реализующего пользовательский адаптер событий, например, SampleCustomEvent ; или, если ваш класс реализован на Swift, MediationExample.SampleCustomEventSwift .

Имя целевого объекта необходимо указать, если в вашем проекте несколько целевых объектов или если имя проекта отличается от имени целевого объекта. Имя целевого объекта будет выглядеть так: appName_targetName.className . Кроме того, не забудьте заменить все небуквенно-цифровые символы, такие как дефисы, на подчеркивания. Пример : .

Этикетка

Уникальное название, определяющее источник рекламы.

Параметр

Необязательный строковый аргумент, передаваемый вашему пользовательскому адаптеру событий.

Реализуйте GADMediationAdapter

Первым шагом к созданию пользовательского события является реализация протокола GADMediationAdapter , как показано в примере с классом SampleCustomEvent .

В обязанности этого класса входит получение сообщений от AdMob и делегирование ответственности за создание правильного формата объявления.

Инициализируйте адаптер.

При инициализации Google Mobile Ads SDK вызывается setUpWithConfiguration:completionHandler: для всех поддерживаемых сторонних адаптеров и пользовательских событий, настроенных для приложения в пользовательском интерфейсе AdMob. Используйте этот метод для выполнения необходимой настройки или инициализации требуемого стороннего SDK для вашего пользовательского события.

Быстрый

import GoogleMobileAds

class SampleCustomEvent: NSObject, MediationAdapter {

  static func setUpWith(
    _ configuration: MediationServerConfiguration,
    completionHandler: @escaping GADMediationAdapterSetUpCompletionBlock
  ) {
    // 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.
    completionHandler(nil)
  }
}

Objective-C

#import "SampleCustomEvent.h"

@implementation SampleCustomEvent

+ (void)setUpWithConfiguration:(nonnull GADMediationServerConfiguration *)configuration
             completionHandler:(nonnull GADMediationAdapterSetUpCompletionBlock)completionHandler {
  // This is where you initialize the SDK that this custom event is built
  // for. Upon finishing the SDK initialization, call the completion handler
  // with success.
  completionHandler(nil);
}

Номера версий отчета

Все пользовательские события должны сообщать в Google Mobile Ads SDK как версию самого адаптера пользовательского события, так и версию стороннего SDK, с которым взаимодействует пользовательское событие. Версии передаются в виде объектов GADVersionNumber :

Быстрый

static func adSDKVersion() -> VersionNumber {
  let versionComponents = String(SampleSDKVersion).components(
    separatedBy: ".")

  if versionComponents.count >= 3 {
    let majorVersion = Int(versionComponents[0]) ?? 0
    let minorVersion = Int(versionComponents[1]) ?? 0
    let patchVersion = Int(versionComponents[2]) ?? 0

    return VersionNumber(
      majorVersion: majorVersion, minorVersion: minorVersion, patchVersion: patchVersion)
  }

  return VersionNumber()
}

static func adapterVersion() -> VersionNumber {
  let versionComponents = String(SampleAdSDK.SampleAdSDKVersionNumber).components(
    separatedBy: ".")
  var version = VersionNumber()
  if versionComponents.count == 4 {
    version.majorVersion = Int(versionComponents[0]) ?? 0
    version.minorVersion = Int(versionComponents[1]) ?? 0
    version.patchVersion = Int(versionComponents[2]) * 100 + Int(versionComponents[3])
  }
  return version
}

Objective-C

+ (GADVersionNumber)adSDKVersion {
  NSArray *versionComponents =
      [SampleSDKVersion componentsSeparatedByString:@"."];
  GADVersionNumber version = {0};
  if (versionComponents.count >= 3) {
    version.majorVersion = [versionComponents[0] integerValue];
    version.minorVersion = [versionComponents[1] integerValue];
    version.patchVersion = [versionComponents[2] integerValue];
  }
  return version;
}

+ (GADVersionNumber)adapterVersion {
  NSArray *versionComponents =
      [SampleCustomEventAdapterVersion componentsSeparatedByString:@"."];
  GADVersionNumber version = {0};
  if (versionComponents.count == 4) {
    version.majorVersion = [versionComponents[0] integerValue];
    version.minorVersion = [versionComponents[1] integerValue];
    version.patchVersion = [versionComponents[2] integerValue] * 100 +
                           [versionComponents[3] integerValue];
  }
  return version;
}

Запросить объявление

Чтобы запросить размещение рекламы, ознакомьтесь с инструкциями, относящимися к конкретному формату объявления: