אירועים בהתאמה אישית מאפשרים להוסיף תהליך בחירת רשת (Mediation) ב-Waterfall עבור רשת מודעות שאינה רשת מודעות נתמכת. כדי לעשות זאת, מטמיעים מתאם של אירועים בהתאמה אישית לרשת המודעות שרוצים לשלב.
במאגר שלנו ב-GitHub תוכלו למצוא פרויקט לדוגמה של אירוע מותאם אישית.
דרישות מוקדמות
כדי ליצור אירועים מותאמים אישית, תחילה צריך לשלב באפליקציה אחד מהפורמטים הבאים של מודעות:
יצירת אירוע בהתאמה אישית בממשק המשתמש
קודם צריך ליצור אירוע בהתאמה אישית בממשק המשתמש של AdMob. הוראות מפורטות זמינות במאמר הוספת אירוע מותאם אישית.
צריך לספק את הפרטים הבאים:
- שם המחלקה
השם המלא של המחלקה שמטמיעה את המתאם של האירוע המותאם אישית. לדוגמה,
SampleCustomEvent
. אם המחלקה מוטמעת ב-Swift, השם הואMediationExample.SampleCustomEventSwift
.צריך לציין את שם היעד אם יש לכם כמה יעדים בפרויקט או אם שם הפרויקט שונה משם היעד. עם שם היעד, זה ייראה כך:
appName_targetName.className
. בנוסף, חשוב לזכור להחליף תווים שאינם אלפאנומריים, כמו מקפים, בקווים תחתונים. דוגמה- תווית
שם ייחודי שמגדיר את מקור המודעות.
- פרמטר
ארגומנטים של מחרוזות אופציונליים שמועברים למתאם האירועים המותאם אישית.
הטמעת GADMediationAdapter
השלב הראשון ביצירת אירוע מותאם אישית הוא הטמעת הפרוטוקול GADMediationAdapter
, כפי שמוצג בכיתה SampleCustomEvent
בדוגמה שלנו.
באחריות הכיתה הזו לקבל הודעות מ-AdMob ולהעביר את האחריות על יצירת פורמט המודעה הנכון.
איך מאתחלים את המתאם
כש-Google Mobile Ads SDK מופעל, הפונקציה setUpWithConfiguration:completionHandler:
מופעלת בכל המתאמים הנתמכים של צד שלישי ובאירועים מותאמים אישית שהוגדרו לאפליקציה בממשק המשתמש של AdMob. משתמשים בשיטה הזו כדי לבצע את ההגדרה או את ההפעלה הראשונית הנדרשות ב-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;
}
בקשה להצגת מודעה
כדי לבקש מודעה, יש לפעול לפי ההוראות הספציפיות לפורמט המודעה: