Com os eventos personalizados, é possível adicionar a mediação em hierarquia a uma rede de publicidade que não é compatível. Para isso, implemente um adaptador de evento personalizado para a rede de publicidade que você quer integrar.
Você pode encontrar um projeto de evento personalizado de exemplo completo no nosso repositório do GitHub.
Pré-requisitos
Antes de criar eventos personalizados, integre um dos seguintes formatos de anúncio ao seu app:
Criar um evento personalizado na interface
Primeiro, um evento personalizado precisa ser criado na IU da AdMob. Consulte as instruções em Adicionar um evento personalizado.
Você precisa fornecer o seguinte:
- Nome da classe
O nome totalmente qualificado da classe que implementa o adaptador de evento personalizado, por exemplo,
SampleCustomEvent
. Se a classe for implementada no Swift,MediationExample.SampleCustomEventSwift
.O nome do destino é obrigatório se você tiver vários destinos no projeto ou se o nome do projeto for diferente do nome do destino. Com o nome do destino, ele fica assim:
appName_targetName.className
. Além disso, substitua todos os caracteres não alfanuméricos, como traços, por sublinhados. Exemplo.- Rótulo
Um nome exclusivo que define a origem do anúncio.
- Parâmetro
Um argumento de string opcional transmitido para o adaptador de evento personalizado.
Implementar o GADMediationAdapter
A primeira etapa para criar um evento personalizado é implementar o
protocolo GADMediationAdapter
, conforme mostrado pela classe SampleCustomEvent
no nosso exemplo.
É responsabilidade dessa classe receber mensagens da AdMob e delegar a responsabilidade de criar o formato de anúncio correto.
Inicializar o adaptador
Quando o SDK dos anúncios para dispositivos móveis do Google é inicializado,
setUpWithConfiguration:completionHandler:
é invocado em todos os adaptadores de terceiros e eventos personalizados com suporte configurados
para o app na interface da AdMob. Use esse método para
realizar qualquer configuração ou inicialização necessária no SDK de terceiros
para seu evento personalizado.
Swift
import GoogleMobileAds
class SampleCustomEvent: NSObject, GADMediationAdapter {
static func setUpWith(
_ configuration: GADMediationServerConfiguration,
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);
}
Números de versão do relatório
Todos os eventos personalizados precisam informar ao SDK dos anúncios para dispositivos móveis do Google a versão do próprio adaptador de eventos personalizados e a versão do SDK de terceiros com que o evento personalizado interage. As versões são relatadas como
objetos
GADVersionNumber
:
Swift
static func adSDKVersion() -> GADVersionNumber {
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 GADVersionNumber(
majorVersion: majorVersion, minorVersion: minorVersion, patchVersion: patchVersion)
}
return GADVersionNumber()
}
static func adapterVersion() -> GADVersionNumber {
let versionComponents = String(SampleAdSDK.SampleAdSDKVersionNumber).components(
separatedBy: ".")
var version = GADVersionNumber()
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;
}
Solicitar um anúncio
Para solicitar um anúncio, consulte as instruções específicas do formato: