פורמטים מותאמים אישית של מודעות
בדומה לפורמטים המוגדרים על ידי המערכת, פורמטים מותאמים אישית של מודעות מותאמות נטענים באמצעות אובייקטים מסוג GADAdLoader
. אם תכללו את הקבוע GADAdLoaderAdTypeCustomNative
במערך adTypes
בזמן האיניציאציה של GADAdLoader
, הוא יבקש פורמטים מותאמים אישית של מודעות מותאמות בזמן הטעינה של המודעות.
GADCustomNativeAdLoaderDelegate
לפרוטוקול לטעינת פורמטים מותאמים אישית יש שתי שיטות. השדה הראשון משמש את GADAdLoader
כדי לברר אילו מזהי פורמט צריך לבקש:
Swift
public func customNativeAdFormatIDs(for adLoader: AdLoader) -> [Any]
Objective-C
- (NSArray *)customNativeAdFormatIDsForAdLoader:(AdLoader *)adLoader;
לכל פורמט של מודעה מותאמת אישית יש מזהה פורמט תואם שמזהה אותו. כשמתבצעת קריאה ל-method הזה, האפליקציה צריכה להחזיר מערך שמכיל את מזהי הפורמטים של המודעות שהיא מוכנה להציג.
ההודעה השנייה נשלחת אחרי שהמודעה המותאמת אישית נטענת, בדומה להודעות לגבי פורמטים שמוגדרים על ידי המערכת:
Swift
public func adLoader(_ adLoader: AdLoader, didReceive customNativeAd: CustomNativeAd)
Objective-C
- (void)adLoader:(AdLoader *)adLoader didReceiveCustomNativeAd:(CustomNativeAd *)customNativeAd;
מזהי פורמטים
מזהי הפורמטים שמשמשים להפניה ייחודית לפורמטים מותאמים אישית של מודעות מותאמות מופיעים בממשק המשתמש של Ad Manager בקטע Native בתפריט הנפתח Delivery:
מזהה הפורמט של כל מודעת Native מותאמת אישית מופיע לצד השם שלה. לחיצה על אחד מהשמות תוביל אתכם למסך פרטים שבו מוצג מידע על השדות של הפורמט:
מכאן אפשר להוסיף, לערוך ולהסיר שדות ספציפיים. שימו לב לשם של כל אחד מהנכסים. השם הוא המפתח שמשמש לאחזור הנתונים של כל נכס כשמציגים את פורמט המודעה המותאם אישית.
הצגת פורמטים מותאמים אישית של מודעות מותאמות
פורמטים מותאמים אישית של מודעות מותאמות שונים מפורמטים שמוגדרים על ידי המערכת, כי לבעלי התוכן הדיגיטלי יש אפשרות להגדיר רשימה משלהם של נכסים שמרכיבים מודעה. לכן, התהליך להצגת מודעות מותאמות אישית שונה במספר דרכים מהתהליך להצגת מודעות בפורמטים שמוגדרים על ידי המערכת:
- מכיוון ש-
GADCustomNativeAd
נועד לטפל בכל פורמט של מודעה מותאמת אישית שאתם יוצרים, אין לו גישות (accessors) לאתרים בשם. במקום זאת, הוא מציע שיטות כמוimageForKey:
ו-stringForKey:
שמקבלות את שם השדה כארגומנטים. - אין סיווג ייעודי של צפייה במודעה כמו
GADNativeAdView
שאפשר להשתמש בו עםGADCustomNativeAd
. אתם יכולים להשתמש בכל תצוגה שמתאימה לחוויית המשתמש שלכם. - מכיוון שאין סוג ייעודי של תצוגת מודעה, אין צורך לרשום אף אחת מהתצוגות שבהן אתם משתמשים כדי להציג את נכסי המודעה.
זו דוגמה לתצוגת מודעה שיכולה להציג מודעה מותאמת פשוטה:
MySimpleNativeAdView.h
Swift
import UIKit import GoogleMobileAds /// Custom native ad view class with format ID 10063170. class MySimpleNativeAdView: UIView { /// Weak references to this ad's asset views. @IBOutlet weak var headlineView: UILabel! @IBOutlet weak var mainImageView: UIImageView! @IBOutlet weak var captionView: UILabel! ... /// Populates the ad view with the custom native ad object. func populateWithCustomNativeAd(_ customNativeAd: CustomNativeAd) { ... } }
Objective-C
@import UIKit; @import GoogleMobileAds; /// View representing a custom native ad format with format ID 10063170. @interface MySimpleNativeAdView : UIView // Weak references to this ad's asset views. @property(weak, nonatomic) IBOutlet UILabel *headlineView; @property(weak, nonatomic) IBOutlet UIImageView *mainImageView; @property(weak, nonatomic) IBOutlet UILabel *captionView; /// Populates the ad view with the custom native ad object. - (void)populateWithCustomNativeAd:(GADCustomNativeAd *)customNativeAd; @end
MySimpleNativeAdView.m (קטע)
Swift
... func populateWithCustomNativeAd(_ customNativeAd: CustomNativeAd) { self.customNativeAd = customNativeAd // Populate the custom native ad assets. headlineView.text = self.customNativeAd.stringForKey("Headline") mainImageView.image = self.customNativeAd.imageForKey("MainImage")?.image captionView.text = self.customNativeAd.stringForKey("Caption") } ...
Objective-C
... - (void)populateWithCustomNativeAd:(GADCustomNativeAd *)customNativeAd { self.customNativeAd = customNativeAd; // Populate the custom native ad assets. self.headlineView.text = [customNativeAd stringForKey:@"Headline"]; self.mainImageView.image = [customNativeAd imageForKey:@"MainImage"].image; self.captionView.text = [customNativeAd stringForKey:@"Caption"]; } ...
עיבוד (רנדר) של סמל AdChoices
כחלק מהתמיכה ב-Digital Services Act (חוק השירותים הדיגיטליים), מודעות בהזמנה שמוצגות באזור הכלכלי האירופי (EEA) צריכות לכלול את הסמל של AdChoices וקישור לדף 'מידע על המודעה הזו' ב-Google. כשמטמיעים מודעות מותאמות בהתאמה אישית, אתם אחראים להצגת סמל AdChoices. חשוב לבצע פעולות כדי להציג ולקבוע את הקשבת הקליקים על סמל AdChoices בזמן היצירה של נכסי המודעה הראשיים.
בדוגמה הבאה מוצגת ההצגה של סמל AdChoices והגדרת התנהגות הקליקים המתאימה.
Swift
class MySimpleNativeAdView: UIView {
@IBOutlet weak var adChoicesView: UIImageView!
override func awakeFromNib() {
super.awakeFromNib()
// Enable clicks on AdChoices.
adChoicesView.addGestureRecognizer(
UITapGestureRecognizer(
target: self,
action: #selector(performClickOnAdChoices(_:))))
adChoicesView.isUserInteractionEnabled = true
}
@objc func performClickOnAdChoices(_ sender: UIImage!) {
customNativeAd.performClickOnAsset(withKey:
NativeAssetIdentifier.adChoicesViewAsset.rawValue)
}
func populate(withCustomNativeAd customNativeAd: CustomNativeAd) {
// Render the AdChoices image.
let adChoicesKey = NativeAssetIdentifier.adChoicesViewAsset.rawValue
let adChoicesImage = customNativeAd.image(forKey: adChoicesKey)?.image
adChoicesView.image = adChoicesImage
adChoicesView.isHidden = adChoicesImage == nil
...
}
}
Objective-C
@interface MySimpleNativeAdView ()
@property(nonatomic, weak) IBOutlet UIImageView *adChoicesView;
@end
@implementation MySimpleNativeAdView
- (void)awakeFromNib {
[super awakeFromNib];
// Enable clicks on AdChoices.
[self.adChoicesView addGestureRecognizer:[[UITapGestureRecognizer alloc]
initWithTarget:self
action:@selector(performClickOnAdChoices:)]];
self.adChoicesView.userInteractionEnabled = YES;
}
- (void)performClickOnAdChoices:(UITapGestureRecognizer *)sender {
[self.customNativeAd performClickOnAssetWithKey:GADNativeAdChoicesViewAsset];
}
- (void)populateWithCustomNativeAd:(GADCustomNativeAd *)customNativeAd {
// Render the AdChoices image.
GADNativeAdImage *adChoicesAsset = [customNativeAd
imageForKey:GADNativeAdChoicesViewAsset];
self.adChoicesView.image = adChoicesAsset.image;
self.adChoicesView.hidden = (adChoicesAsset == nil);
...
}
וידאו מותאם לפורמטים מותאמים אישית של מודעות
כשיוצרים פורמט בהתאמה אישית, אפשר להגדיר אותו כפורמט מתאים לווידאו.
בהטמעה של האפליקציה, אפשר להשתמש בנכס GADCustomNativeAd.mediaView
כדי לקבל את הצפייה בסרטון. לאחר מכן מוסיפים את התצוגה הזו להיררכיית התצוגות. אם המודעה לא כוללת תוכן וידאו, צריך להכין תוכניות חלופיות להצגת המודעה ללא וידאו.
בדוגמה הבאה בודקים אם המודעה מכילה תוכן וידאו, ומציגים תמונה במקומה אם הסרטון לא זמין:
Swift
... /// Populates the ad view with the custom native ad object. func populate(withCustomNativeAd customNativeAd: CustomNativeAd) { if customNativeAd.videoController.hasVideoContent(), let mediaView = customNativeAd.mediaView { updateMainView(mediaView) } else { // Assumes your native format has an image asset with the name MainImage. let image: UIImage? = customNativeAd.image(forKey: "MainImage")?.image updateMainView(UIImageView(image: image)) } } private func updateMainView(_ mainView:UIView) { // Assumes you have a placeholder view for your media content. // Remove all the placeholder's subviews. for subview: UIView in mainPlaceholder.subviews { subview.removeFromSuperview() } mainPlaceholder.addSubview(mainView) // Size the media view to fill our container size. mainView.translatesAutoresizingMaskIntoConstraints = false let viewDictionary: [AnyHashable: Any] = ["mainView":mainView] mainPlaceholder.addConstraints(NSLayoutConstraint.constraints( withVisualFormat: "H:|[mainView]|", options: [], metrics: nil, views: viewDictionary as? [String : Any] ?? [String : Any]())) mainPlaceholder.addConstraints(NSLayoutConstraint.constraints( withVisualFormat: "V:|[mainView]|", options: [], metrics: nil, views: viewDictionary as? [String : Any] ?? [String : Any]())) } ...
Objective-C
... - (void)populateWithCustomNativeAd:(GADCustomNativeAd *)ad { UIView *mainView = nil; if (ad.videoController.hasVideoContent) { mainView = ad.mediaView; } else { // Assumes your native format has an image asset with the name MainImage. UIImage *image = [ad imageForKey:@"MainImage"].image; mainView = [[UIImageView alloc] initWithImage:image]; } // Assumes you have a placeholder view for your media content. for (UIView *subview in self.mainPlaceholder.subviews) { [subview removeFromSuperview]; } [self.mainPlaceholder addSubview:mainView]; // Size the main view to fill our container size. [mainView setTranslatesAutoresizingMaskIntoConstraints:NO]; NSDictionary *viewDictionary = NSDictionaryOfVariableBindings(mainView); [self.mainPlaceholder addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|[mainView]|" options:0 metrics:nil views:viewDictionary]]; } ...
במאמר GADVideoController מוסבר איך להתאים אישית את חוויית הצפייה בסרטון של מודעה רגילה בהתאמה אישית.
הורדת הדוגמה לעיבוד מותאם אישית ב-Ad Manager כדי לראות דוגמה פעילה של וידאו מותאם.
טיפול בקליקים ובחשיפות של מודעות מותאמות אישית
בפורמטים מותאמים אישית של מודעות מותאמות, האפליקציה אחראית לתיעוד החשיפות ולדיווח על אירועי קליקים ל-SDK.
הקלטת חשיפות
כדי לתעד חשיפה של מודעה מותאמת אישית, פשוט צריך להפעיל את השיטה recordImpression
ב-GADCustomNativeAd
המתאים:
Swift
myCustomNativeAd.recordImpression()
Objective-C
[myCustomNativeAd recordImpression];
ה-SDK מונע רישום של חשיפות כפולות לבקשה אחת, במקרה שהאפליקציה קוראת בטעות לשיטה כמה פעמים עבור אותה מודעה.
דיווח על קליקים
כדי לדווח ל-SDK על לחיצה שקרוה בתצוגת נכס, צריך להפעיל את השיטה performClickOnAssetWithKey:
ב-GADCustomNativeAd
המתאים ולהעביר את שם הנכס שבו בוצעה הלחיצה.
לדוגמה, אם יש לכם נכס בפורמט המותאם אישית שנקרא 'MainImage' ואתם רוצים לדווח על קליק בתצוגה שתואמת לנכס הזה, הקוד שלכם ייראה כך:
Swift
myCustomNativeAd.performClickOnAsset(withKey: "MainImage")
Objective-C
[myCustomNativeAd performClickOnAssetWithKey:@"MainImage"];
שימו לב שאין צורך להפעיל את השיטה הזו לכל תצוגה של נכס שמשויכת למודעה. לדוגמה, אם יש לכם נכס אחר שנקרא 'כתוביות', שנועד להופיע אבל המשתמש לא לוחץ או מקייש עליו, לא תצטרכו לבצע קריאה ל-performClickOnAssetWithKey:
בתצוגה הזו.
תגובה לפעולות בהתאמה אישית של קליקים
ל-GADCustomNativeAd
יש מאפיין customClickHandler
מסוג
GADNativeAdCustomClickHandler
Swift
typealias NativeAdCustomClickHandler = (assetID: String) -> Void
Objective-C
typedef void (^GADNativeAdCustomClickHandler)(NSString *assetID);
זהו בלוק (Objective-C) או פונקציית סגירה (Swift) שמקבל פרמטר קלט מסוג assetID
, שמזהה את הנכס שבו לוחצים.
כשמתבצע קליק על מודעה מותאמת אישית מסוג מודעה רגילה, יש שלוש תגובות אפשריות מ-SDK, והן מתבצעות בסדר הזה:
- אם הגדרתם בלוק, צריך להפעיל אותו ב-Objective-C או ב-Swift.
customClickHandler
- עוברים ברצף על כתובות ה-URL של הקישור העמוק במודעה ופותחים את הכתובת הראשונה שאפשר למצוא לה אפליקציה תואמת.
- פותחים דפדפן ועוברים לכתובת היעד המסורתית של המודעה.
המאפיין customClickHandler
מקבל בלוק ב-Objective-C ו-closure ב-Swift. אם תגדירו חסימה או סגירה, ה-SDK יפעל אותם ולא יבצע פעולה נוספת. עם זאת, אם תגדירו ערך nil, ה-SDK יחזור לכתובת ה-URL של הקישור המורחב ו/או לכתובות ה-URL של היעד שרשומים במודעה.
טיפולים מותאמים אישית בקליק מאפשרים לאפליקציה להחליט בעצמה מהי הפעולה הטובה ביותר לביצוע בתגובה לקליק, בין אם מדובר בעדכון של ממשק המשתמש, בהצגת בורר תצוגה אחר או פשוט ברישום הקליק ביומן. דוגמה לקבלת התראה:
Swift
myCustomNativeAd.customClickHandler = { assetID in if assetID == "MainImage" { let alertView = UIAlertView(title: "Custom Click", message: "You just clicked on the image!", delegate: self, cancelButtonTitle: "OK") alertView.alertViewStyle = .default alertView.show() } } myCustomNativeAd.performClickOnAsset(withKey: "MainImage")
Objective-C
[self.customNativeAd setCustomClickHandler:^(NSString *assetID){ if ([assetID isEqualToString:@"MainImage"]) { [[[UIAlertView alloc] initWithTitle:@"Custom Click" message:@"You just clicked on the image!" delegate:self cancelButtonTitle:@"OK" otherButtonTitles:nil] show]; } }]; [self.customNativeAd performClickOnAssetWithKey:@"MainImage"];
בדיקת הקוד של מודעות מותאמות
מודעות במכירה ישירה
אם אתם רוצים לבדוק איך נראות מודעות מותאמות שנמכרו ישירות, תוכלו להשתמש במזהה יחידת המודעות הזה ב-Ad Manager:
/21775744923/example/native
הוא מוגדר להציג מודעות לדוגמה להתקנת אפליקציות ומודעות תוכן, וגם פורמט של מודעה מותאמת אישית עם הנכסים הבאים:
- כותרת (טקסט)
- MainImage (תמונה)
- Caption (טקסט)
מודעות מותאמות לגיבוי
כדי לבדוק את ההתנהגות של מודעות מותאמות למילוי שטחי פרסום ריקים, צריך להשתמש ביחידת המודעות הזו ב-Ad Manager:
/21775744923/example/native-backfill
המערכת תציג מודעות לדוגמה להתקנת אפליקציות ומודעות תוכן שכוללות את שכבת-העל של AdChoices.
חשוב לזכור לעדכן את הקוד כך שיתייחס למזהי הפורמט והיחידת המודעות בפועל לפני שמפעילים את המודעות.