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