Пользовательские события позволяют добавить каскадную медиацию для рекламной сети, которая не является поддерживаемой . Для этого необходимо реализовать пользовательский адаптер событий для рекламной сети, которую вы хотите интегрировать.
Полный пример проекта с пользовательскими событиями можно найти в нашем репозитории на 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;
}
Запросить объявление
Чтобы запросить размещение рекламы, ознакомьтесь с инструкциями, относящимися к конкретному формату объявления: