Zdarzenia niestandardowe umożliwiają dodanie zapośredniczenia kaskadowego w przypadku sieci reklamowej, która nie jest obsługiwana przez AdMob. Aby to zrobić, wdróż adapter zdarzenia niestandardowego w przypadku sieci reklamowej, którą chcesz zintegrować.
Pełny przykładowy projekt zdarzenia niestandardowego znajdziesz w naszym repozytorium GitHub.
Wymagania wstępne
Zanim utworzysz zdarzenia niestandardowe, musisz najpierw zintegrować z aplikacją jeden z tych formatów reklam:
Tworzenie zdarzenia niestandardowego w interfejsie
Zdarzenie niestandardowe musi najpierw zostać utworzone w interfejsie AdMob. Postępuj zgodnie z instrukcjami w artykule Dodawanie zdarzenia niestandardowego.
Musisz podać te informacje:
- Nazwa zajęć
- Pełna nazwa klasy, która implementuje adapter zdarzenia niestandardowego, np. - SampleCustomEventlub- MediationExample.SampleCustomEventSwift, jeśli klasa została zaimplementowana w kodzie Swift.- Nazwa miejsca docelowego jest wymagana, jeśli w projekcie masz wiele miejsc docelowych lub jeśli nazwa projektu różni się od nazwy miejsca docelowego. Z nazwą docelową wyglądałoby to tak: - appName_targetName.className. Pamiętaj też, aby zastąpić wszystkie znaki inne niż alfanumeryczne, np. łączniki, znakami podkreślenia. Przykład
- Etykieta
- Unikalna nazwa określająca źródło reklamy. 
- Parametr
- Opcjonalny argument w postaci ciągu znaków przekazywany do łącznika zdarzenia niestandardowego. 
Implementowanie GADMediationAdapter
Pierwszym krokiem do utworzenia zdarzenia niestandardowego jest zaimplementowanie protokołu GADMediationAdapter, jak pokazano w klasie SampleCustomEvent w naszym przykładzie.
Ta klasa jest odpowiedzialna za odbieranie wiadomości z AdMob i przekazywanie odpowiedzialności za tworzenie prawidłowego formatu reklamy.
Inicjowanie adaptera
Gdy pakiet SDK do reklam mobilnych Google zostanie zainicjowany,setUpWithConfiguration:completionHandler:
wywoływana jest funkcja setUpWithConfiguration:completionHandler:
we wszystkich obsługiwanych adapterach innych firm i zdarzeniach niestandardowych skonfigurowanych w przypadku aplikacji w interfejsie AdMob. Użyj tej metody, aby przeprowadzić niezbędną konfigurację lub inicjowanie wymaganego pakietu SDK innej firmy na potrzeby zdarzenia niestandardowego.
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);
}
Raportowanie numerów wersji
Wszystkie zdarzenia niestandardowe muszą przekazywać do pakietu SDK do reklam mobilnych Google zarówno wersję samego adaptera zdarzenia niestandardowego, jak i wersję pakietu SDK innej firmy, z którym to zdarzenie niestandardowe współpracuje. Wersje są zgłaszane jako
 GADVersionNumber
obiekty:
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;
}
Żądanie reklamy
Aby wysłać żądanie reklamy, postępuj zgodnie z instrukcjami dotyczącymi konkretnego formatu reklamy: