เหตุการณ์ที่กําหนดเองช่วยให้คุณเพิ่มสื่อกลาง Waterfall สําหรับเครือข่ายโฆษณาที่ไม่ใช่เครือข่ายโฆษณาที่รองรับได้ ซึ่งทำได้โดยการใช้อะแดปเตอร์เหตุการณ์ที่กำหนดเองสำหรับเครือข่ายโฆษณาที่คุณต้องการผสานรวม
คุณดูตัวอย่างโปรเจ็กต์เหตุการณ์ที่กำหนดเองแบบเต็มได้ในที่เก็บของ GitHub
ข้อกำหนดเบื้องต้น
ก่อนที่จะสร้างเหตุการณ์ที่กำหนดเอง คุณต้องผสานรวมรูปแบบโฆษณาอย่างใดอย่างหนึ่งต่อไปนี้ลงในแอปก่อน
สร้างเหตุการณ์ที่กำหนดเองใน UI
คุณต้องสร้างเหตุการณ์ที่กำหนดเองใน AdMob UI ก่อน ดูวิธีการในหัวข้อ เพิ่มเหตุการณ์ที่กําหนดเอง
คุณต้องระบุข้อมูลต่อไปนี้
- ชื่อคลาส
ชื่อที่มีคุณสมบัติครบถ้วนของคลาสที่ใช้อะแดปเตอร์เหตุการณ์ที่กําหนดเอง เช่น
SampleCustomEvent
หรือหากใช้งานชั้นเรียนของคุณใน SwiftMediationExample.SampleCustomEventSwift
ต้องระบุชื่อเป้าหมายหากมีหลายเป้าหมายในโปรเจ็กต์หรือเมื่อชื่อโปรเจ็กต์ต่างจากชื่อเป้าหมาย ชื่อเป้าหมาย จะมีลักษณะดังนี้
appName_targetName.className
นอกจากนี้ อย่าลืมแทนที่อักขระที่ไม่ใช่ตัวอักษรและตัวเลขคละกัน เช่น เครื่องหมายขีดกลางด้วยขีดล่าง ตัวอย่าง- ป้ายกำกับ
ชื่อที่ไม่ซ้ำกันเป็นตัวกำหนดแหล่งที่มาของโฆษณา
- พารามิเตอร์
อาร์กิวเมนต์สตริงที่ไม่บังคับซึ่งส่งไปยังอะแดปเตอร์เหตุการณ์ที่กําหนดเอง
ติดตั้งใช้งาน GADMediationAdapter
ขั้นตอนแรกในการสร้างเหตุการณ์ที่กําหนดเองคือการใช้โปรโตคอล GADMediationAdapter
ตามที่แสดงในคลาส SampleCustomEvent
ในตัวอย่างของเรา
ชั้นเรียนนี้มีหน้าที่รับข้อความจากAdMob และมอบอำนาจในการสร้างรูปแบบโฆษณาที่ถูกต้อง
เริ่มต้นอะแดปเตอร์
เมื่อ Google Mobile Ads SDK เริ่มต้น
setUpWithConfiguration:completionHandler:
จะมีการเรียกใช้ในอะแดปเตอร์ของบุคคลที่สามที่รองรับทั้งหมดและเหตุการณ์ที่กําหนดเองซึ่งกําหนดค่าไว้สําหรับแอปใน AdMob UI ใช้วิธีนี้เพื่อตั้งค่าหรือเริ่มต้นที่จําเป็นใน SDK ของบุคคลที่สามที่จําเป็นสําหรับเหตุการณ์ที่กําหนดเอง
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); }
รายงานหมายเลขเวอร์ชัน
เหตุการณ์ที่กำหนดเองทั้งหมดต้องรายงานไปยัง Google Mobile Ads SDK ทั้งเวอร์ชันของตัวอะแดปเตอร์เหตุการณ์ที่กำหนดเองและเวอร์ชันของ SDK บุคคลที่สามที่ใช้อินเทอร์เฟซเหตุการณ์ที่กำหนดเอง ระบบจะรายงานเวอร์ชันเป็น
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; }
ส่งคำขอโฆษณา
หากต้องการขอโฆษณา ให้ทำตามวิธีการเฉพาะสำหรับรูปแบบโฆษณานั้น: