Configuración

Los eventos personalizados te permiten agregar la mediación en cascada para una red de publicidad que no sea una red de publicidad admitida. Para ello, implementa un adaptador de eventos personalizado para la red de publicidad que deseas integrar.

Requisitos previos

Antes de crear eventos personalizados, primero debes integrar uno de los siguientes formatos de anuncio en tu app:

Cómo crear un evento personalizado en la IU

Primero se debe crear un evento personalizado en la IU de Ad Manager. Consulta las instrucciones en Crea y administra grupos de rendimiento.

Debes proporcionar lo siguiente:

Nombre de clase

Nombre completamente calificado de la clase que implementa el adaptador de eventos personalizado, por ejemplo, SampleCustomEvent o MediationExample.SampleCustomEventSwift si tu clase se implementa en Swift.

El nombre del destino es obligatorio si tienes varios destinos en tu proyecto o si el nombre del proyecto es diferente del nombre del destino. Con el nombre del destino, se vería de la siguiente manera: appName_targetName.className. Además, recuerda reemplazar cualquier carácter no alfanumérico, como los guiones, por guiones bajos. Ejemplo.

Etiqueta

Es un nombre único que define la fuente del anuncio.

Parámetro

Es un argumento de cadena opcional que se pasa a tu adaptador de eventos personalizados.

Implementa GADMediationAdapter

El primer paso para crear un evento personalizado es implementar el protocolo GADMediationAdapter, como se muestra en la clase SampleCustomEvent de nuestro ejemplo.

Es responsabilidad de esta clase recibir mensajes de Ad Manager y delegar la responsabilidad de crear el formato de anuncio correcto.

Inicializa el adaptador

Cuando se inicializa el SDK de anuncios de Google para dispositivos móviles, se invoca setUpWithConfiguration:completionHandler: en todos los adaptadores de terceros admitidos y los eventos personalizados configurados para la app en la IU de Ad Manager. Usa este método para realizar cualquier configuración o inicialización necesaria en el SDK de terceros requerido para tu evento personalizado.

Swift

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);
}

Números de versión del informe

Todos los eventos personalizados deben informar al SDK de anuncios de Google para dispositivos móviles tanto la versión del adaptador de eventos personalizados como la versión del SDK de terceros con el que se vincula el evento personalizado. Las versiones se informan como objetos GADVersionNumber:

Swift

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;
}

Anuncio de solicitud

Para solicitar un anuncio, consulta las instrucciones específicas del formato de anuncio: