สร้างเหตุการณ์ที่กําหนดเอง

เลือกแพลตฟอร์ม: Android ใหม่ Android iOS Unity

เหตุการณ์ที่กำหนดเองช่วยให้คุณเพิ่มการแสดงโฆษณาสื่อกลางตามลำดับขั้น (Waterfall Mediation) สำหรับเครือข่ายโฆษณาที่ไม่ใช่เครือข่ายโฆษณาที่รองรับได้ โดยทำได้ด้วยการติดตั้งใช้งานอะแดปเตอร์เหตุการณ์ที่กำหนดเองสำหรับเครือข่ายโฆษณาที่ต้องการผสานรวม

ข้อกำหนดเบื้องต้น

ก่อนที่จะสร้างเหตุการณ์ที่กำหนดเองได้ คุณต้องผสานรวมรูปแบบโฆษณารูปแบบใดรูปแบบหนึ่งต่อไปนี้เข้ากับแอปก่อน

สร้างเหตุการณ์ที่กำหนดเองใน UI

คุณต้องสร้างเหตุการณ์ที่กำหนดเองใน UI ของ Ad Manager ก่อน ดูวิธีการในหัวข้อ สร้างและจัดการกลุ่มผลตอบแทน

คุณต้องระบุข้อมูลต่อไปนี้

ชื่อชั้นเรียน

ชื่อแบบเต็มของคลาสที่ติดตั้งใช้งานอะแดปเตอร์เหตุการณ์ที่กำหนดเอง เช่น SampleCustomEvent หรือหากติดตั้งใช้งานคลาสใน Swift ก็จะเป็น MediationExample.SampleCustomEventSwift

คุณต้องระบุชื่อเป้าหมายหากมีเป้าหมายหลายรายการในโปรเจ็กต์ หรือหากชื่อโปรเจ็กต์แตกต่างจากชื่อเป้าหมาย ชื่อเป้าหมายจะมีลักษณะดังนี้ appName_targetName.className นอกจากนี้ อย่าลืมแทนที่อักขระที่ไม่ใช่ตัวอักษรผสมตัวเลข เช่น ขีดกลาง ด้วยขีดล่าง ตัวอย่าง.

ป้ายกำกับ

ชื่อที่ไม่ซ้ำกันซึ่งกำหนดแหล่งที่มาของโฆษณา

พารามิเตอร์

อาร์กิวเมนต์สตริงที่ไม่บังคับซึ่งส่งไปยังอะแดปเตอร์เหตุการณ์ที่กำหนดเอง

ติดตั้งใช้งาน GADMediationAdapter

ขั้นตอนแรกในการสร้างเหตุการณ์ที่กำหนดเองคือการติดตั้งใช้งานโปรโตคอล GADMediationAdapter ดังที่แสดงโดยคลาส SampleCustomEvent ใน ตัวอย่างของเรา

คลาสนี้มีหน้าที่รับข้อความจาก Ad Manager และมอบหมายความรับผิดชอบในการสร้างรูปแบบโฆษณาที่ถูกต้อง

เริ่มต้นอะแดปเตอร์

เมื่อ Google Mobile Ads SDK เริ่มต้นใช้งาน setUpWithConfiguration:completionHandler: จะมีการเรียกใช้ในอะแดปเตอร์ของบุคคลที่สามที่รองรับทั้งหมดและเหตุการณ์ที่กำหนดเองที่กำหนดค่าไว้ สำหรับแอปภายใน UI ของ Ad Manager ใช้วิธีนี้เพื่อทำการตั้งค่าหรือเริ่มต้นใช้งานที่จำเป็นใน SDK ของบุคคลที่สามที่จำเป็นสำหรับเหตุการณ์ที่กำหนดเอง

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

หมายเลขเวอร์ชันรายงาน

เหตุการณ์ที่กำหนดเองทั้งหมดต้องรายงานทั้งเวอร์ชันของอะแดปเตอร์เหตุการณ์ที่กำหนดเองและเวอร์ชันของ SDK ของบุคคลที่สามที่เหตุการณ์ที่กำหนดเองเชื่อมต่อด้วยไปยัง Google Mobile Ads SDK ระบบจะรายงานเวอร์ชันเป็น 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;
}

ส่งคำขอโฆษณา

หากต้องการส่งคำขอโฆษณา โปรดดูวิธีการเฉพาะสำหรับรูปแบบโฆษณาต่อไปนี้