הצגת מודעה מותאמת
כשמודעה מותאמת נטענת, Google Mobile Ads SDK מפעיל את המאזינים בפורמט המודעה התואם. לאחר מכן, האפליקציה שלכם אחראית להצגת המודעה, אבל היא לא חייבת לעשות זאת באופן מיידי. כדי שההצגה שהוגדרו על ידי המערכת בקלות רבה יותר, ה-SDK מציע כמה משאבים שימושיים, כמו שמתואר בהמשך.
כיתה אחת (NativeAdView
)
לפורמט NativeAd
יש את הכיתה המתאימה NativeAdView
. הכיתה הזו
ViewGroup
שבעלי התוכן הדיגיטלי צריכים להשתמש בו כבסיס ל-NativeAd
. ערך NativeAdView
יחיד תואם למודעה מותאמת אחת.
כל תצוגה מפורטת שמשמשת להצגת הנכסים של המודעה הזו (השדה ImageView
שבו מוצג
למשל), צריך להיות צאצא של NativeAdView
לאובייקט.
היררכיית התצוגות של מודעה מותאמת שנעשה בה שימוש
LinearLayout
להצגת הצפיות בנכס עשוי להיראות כך:
<com.google.android.gms.ads.nativead.NativeAdView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<LinearLayout
android:orientation="vertical"
... >
<LinearLayout
android:orientation="horizontal"
... >
<ImageView
android:id="@+id/ad_app_icon"
... />
<TextView
android:id="@+id/ad_headline"
... />
</LinearLayout>
// Other assets such as image or media view, call to action, etc follow.
...
</LinearLayout>
</com.google.android.gms.ads.nativead.NativeAdView>
דוגמה ליצירת NativeAdView
ויישוב שלו באמצעות NativeAd
:
Java
AdLoader.Builder builder = new AdLoader.Builder(this, "AD_UNIT_ID")
.forNativeAd(new NativeAd.OnNativeAdLoadedListener() {
@Override
public void onNativeAdLoaded(NativeAd nativeAd) {
// Assumes you have a placeholder FrameLayout in your View layout
// (with id fl_adplaceholder) where the ad is to be placed.
FrameLayout frameLayout =
findViewById(R.id.fl_adplaceholder);
// Assumes that your ad layout is in a file call native_ad_layout.xml
// in the res/layout folder
NativeAdView adView = (NativeAdView) getLayoutInflater()
.inflate(R.layout.native_ad_layout, null);
// This method sets the text, images and the native ad, etc into the ad
// view.
populateNativeAdView(nativeAd, adView);
frameLayout.removeAllViews();
frameLayout.addView(adView);
}
});
Kotlin
val builder = AdLoader.Builder(this, "AD_UNIT_ID")
.forNativeAd { nativeAd ->
// Assumes that your ad layout is in a file call native_ad_layout.xml
// in the res/layout folder
val adView = layoutInflater
.inflate(R.layout.native_ad_layout, null) as NativeAdView
// This method sets the text, images and the native ad, etc into the ad
// view.
populateNativeAdView(nativeAd, adView)
// Assumes you have a placeholder FrameLayout in your View layout
// (with id ad_frame) where the ad is to be placed.
ad_frame.removeAllViews()
ad_frame.addView(adView)
}
לתשומת ליבכם, כל הנכסים של מודעה מותאמת מסוימת צריכים להיות מוצגים בתוך
פריסה NativeAdView
. Google Mobile Ads SDK מנסה לרשום אזהרה כאשר
הנכסים המותאמים מוצגים מחוץ לפריסה של תצוגת המודעה המותאמת.
המחלקות של צפייה במודעות מספקות גם שיטות לרישום התצוגה שמשמשת
כל נכס בנפרד, ואחד כדי לרשום את האובייקט NativeAd
עצמו.
רישום התצוגות באופן הזה מאפשר ל-SDK לטפל באופן אוטומטי במשימות כמו:
- תיעוד של קליקים
- תיעוד חשיפות כשהפיקסל הראשון גלוי במסך
- הצגת שכבת-העל AdChoices
שכבת-על AdChoices
שכבת-על של AdChoices מתווספת לכל צפייה במודעה על ידי ה-SDK. השאיר מקום באחסון הפינה המועדפת של תצוגת מודעה מותאמת עבור הלוגו של AdChoices שמוצג באופן אוטומטי. בנוסף, חשוב לוודא ששכבת-העל של AdChoices תהיה בולטת לעין, לכן כדאי לבחור בצבעי רקע ותמונות כראוי. למידע נוסף על המראה של שכבת-העל מופיעה במאמר השדה 'מודעות מותאמות'. תיאורים.
ייחוס המודעה
צריך להציג ייחוס של מודעה כדי לציין שהצפייה היא פרסומת. מידע נוסף זמין בהנחיות המדיניות שלנו.
קוד לדוגמה
אלה השלבים להצגת מודעה מותאמת:
- יוצרים מופע של הכיתה
NativeAdView
. - כדי להציג כל נכס שמצורף למודעה:
- מאכלסים את תצוגת הנכס עם הנכס שבאובייקט המודעה.
- רישום תצוגת הנכס במחלקה
ViewGroup
.
- לרשום את
MediaView
אם הפריסה של המודעה המותאמת כוללת נכס מדיה גדול. - רישום אובייקט המודעה במחלקה
ViewGroup
.
זוהי פונקציה לדוגמה שמציגה NativeAd
:
Java
private void displayNativeAd(ViewGroup parent, NativeAd ad) {
// Inflate a layout and add it to the parent ViewGroup.
LayoutInflater inflater = (LayoutInflater) parent.getContext()
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
NativeAdView adView = (NativeAdView) inflater
.inflate(R.layout.ad_layout_file, parent);
// Locate the view that will hold the headline, set its text, and call the
// NativeAdView's setHeadlineView method to register it.
TextView headlineView = adView.findViewById<TextView>(R.id.ad_headline);
headlineView.setText(ad.getHeadline());
adView.setHeadlineView(headlineView);
...
// Repeat the above process for the other assets in the NativeAd
// using additional view objects (Buttons, ImageViews, etc).
...
// If the app is using a MediaView, it should be
// instantiated and passed to setMediaView. This view is a little different
// in that the asset is populated automatically, so there's one less step.
MediaView mediaView = (MediaView) adView.findViewById(R.id.ad_media);
adView.setMediaView(mediaView);
// Call the NativeAdView's setNativeAd method to register the
// NativeAdObject.
adView.setNativeAd(ad);
// Ensure that the parent view doesn't already contain an ad view.
parent.removeAllViews();
// Place the AdView into the parent.
parent.addView(adView);
}
Kotlin
fun displayNativeAd(parent: ViewGroup, ad: NativeAd) {
// Inflate a layout and add it to the parent ViewGroup.
val inflater = parent.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE)
as LayoutInflater
val adView = inflater.inflate(R.layout.ad_layout_file, parent) as NativeAdView
// Locate the view that will hold the headline, set its text, and use the
// NativeAdView's headlineView property to register it.
val headlineView = adView.findViewById<TextView>(R.id.ad_headline)
headlineView.text = ad.headline
adView.headlineView = headlineView
...
// Repeat the above process for the other assets in the NativeAd using
// additional view objects (Buttons, ImageViews, etc).
...
val mediaView = adView.findViewById<MediaView>(R.id.ad_media)
adView.mediaView = mediaView
// Call the NativeAdView's setNativeAd method to register the
// NativeAdObject.
adView.setNativeAd(ad)
// Ensure that the parent view doesn't already contain an ad view.
parent.removeAllViews()
// Place the AdView into the parent.
parent.addView(adView)
}
אלו המשימות השונות:
הגדלת הפריסה
Java
LayoutInflater inflater = (LayoutInflater) parent.getContext() .getSystemService(Context.LAYOUT_INFLATER_SERVICE); NativeAdView adView = (NativeAdView) inflater .inflate(R.layout.ad_layout_file, parent);
Kotlin
val inflater = parent.getContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater val adView = inflater.inflate(R.layout.ad_layout_file, parent) as NativeAdView
הקוד הזה מנופח מפריסת XML שכוללת תצוגות להצגת ואז מצאנו הפניה אל
NativeAdView
. לתשומת ליבכם: אפשר גם שימוש חוזר ב-NativeAdView
קיים, אם יש כזה במקטע או בפעילות שלך, או אפילו ליצור מכונה באופן דינמי בלי להשתמש בקובץ פריסה.אכלוס ורישום של תצוגות הנכסים
קוד לדוגמה שמאתר את התצוגה שמשמשת להצגת הכותרת, מגדיר את הטקסט שלה באמצעות נכס המחרוזת שסופק על ידי אובייקט המודעה ומרשם אותו באובייקט
NativeAdView
:Java
TextView headlineView = adView.findViewById<TextView>(R.id.ad_headline); headlineView.setText(ad.getHeadline()); adView.setHeadlineView(headlineView);
Kotlin
val headlineView = adView.findViewById<TextView>(R.id.ad_headline) headlineView.text = ad.headline adView.headlineView = headlineView
התהליך הזה של איתור התצוגה, הגדרת הערך שלה ורישום שלה סיווג הצפייה במודעה צריך לחזור על עצמו עבור כל אחד מהנכסים שסופקו על ידי את האובייקט של המודעה המותאמת שהאפליקציה תציג.
טיפול בקליקים
אסור להטמיע handlers מותאמים אישית של קליקים בתצוגות מפורטות מעל או בתוך בתצוגה של המודעה המותאמת. כדי לצפות באירועי קליקים בעצמכם, אפשר להשתמש במודעה Listener
ה-SDK מטפל בקליקים על נכסים של צפיות במודעה, כל עוד לאכלס ולרשום את התצוגות המפורטות של הנכסים, כפי שמתואר בקטע הקודם.
דוגמה שבה נעשה שימוש במקשיב למודעות כדי לעקוב אחרי אירועי קליקים:
Java
AdLoader adLoader = new AdLoader.Builder(context, "ca-app-pub-3940256099942544/2247696110") ... .withAdListener(new AdListener() { @Override public void onAdFailedToLoad(LoadAdError adError) { // Handle the failure by logging, altering the UI, and so on. } @Override public void onAdClicked() { // Log the click event or other custom behavior. } }) .build();
Kotlin
val adLoader = AdLoader.Builder(this, "ca-app-pub-3940256099942544/2247696110") ... .withAdListener(object : AdListener() { override fun onAdFailedToLoad(adError: LoadAdError) { // Handle the failure by logging, altering the UI, and so on. } }) .build()
רישום ה-MediaView
צריך להשתמש
MediaView
במקוםImageView
כדאי לכלול בנכס תמונה ראשית בפריסה של המודעה המותאמת המודעה.MediaView
הואView
מיוחד שנועד להציג את נכס המדיה הראשי, סרטון או תמונה.אפשר להגדיר את
MediaView
בפריסת XML או להרכיב באופן דינמי. הוא צריך להיות ממוקם בתוך היררכיית התצוגות שלNativeAdView
, בדיוק כמו תצוגת נכס אחרת. אפליקציות שמשתמשות ב-MediaView
חייבות לרשום אותו ב-NativeAdView
:Java
MediaView mediaView = adView.findViewById(R.id.ad_media); adView.setMediaView(mediaView);
Kotlin
adView.mediaView = adView.findViewById<MediaView>(R.id.ad_media)
בדומה לכל תצוגות נכסים, צריך לאכלס את התוכן בתצוגת המדיה. לשם כך, משתמשים ב-method
getMediaContent()
כדי לאחזר תוכן מדיה שאפשר להעביר ל-MediaView
. הנה קטע קוד להגדרת תוכן המדיה עבור המדיה תצוגה:Java
mediaView.setMediaContent(nativeAd.getMediaContent());
Kotlin
mediaView.mediaContent = nativeAd.mediaContent
ImageScaleType
למחלקה
MediaView
יש מאפייןImageScaleType
בזמן ההצגה תמונות. כדי לשנות את אופן שינוי התמונה ב-MediaView
, מגדירים אתImageView.ScaleType
המתאים באמצעות השיטהsetImageScaleType()
שלMediaView
:Java
mediaView.setImageScaleType(ImageView.ScaleType.CENTER_CROP);
Kotlin
mediaView.imageScaleType = ImageView.ScaleType.CENTER_CROP
MediaContent
הכיתה
MediaContent
מכילה את הנתונים שקשורים לתוכן המדיה של מודעה מותאמת, שמוצגת באמצעות המחלקהMediaView
. כאשר המאפייןMediaView
mediaContent
מוגדר עם מופעMediaContent
:אם נכס וידאו זמין, הוא נשמר במאגר נתונים זמני ומתחיל לפעול
MediaView
כדי לדעת אם נכס הווידאו זמין, אפשר לבדוקhasVideoContent()
אם המודעה לא מכילה נכס וידאו, המערכת מורידת את נכס ה-
mainImage
ומציבה אותו בתוך ה-MediaView
במקום זאת.
כברירת מחדל,
mainImage
הוא נכס התמונה הראשון שהורדתם. אם המיקוםsetReturnUrlsForImageAssets(true)
בשימוש,mainImage
היאnull
ועליך מגדירים את המאפייןmainImage
לתמונה שהורדתם באופן ידני. חשוב לזכור שהמערכת תשתמש בתמונה הזו רק אם אין נכס וידאו זמין.רישום אובייקט המודעה המותאמת
בשלב האחרון הזה, אובייקט המודעה המובנית נרשם בתצוגה שאחראית להצגת המודעה:
Java
adView.setNativeAd(ad);
Kotlin
adView.setNativeAd(ad)
השמדת מודעה
לאחר סיום הצגת המודעה המותאמת, יש להשמיד אותה כדי שהמודעה מתבצע איסוף אשפה בצורה תקינה.
Java
nativeAd.destroy();
Kotlin
nativeAd.destroy()
דוגמאות ב-GitHub
דוגמה להטמעה מלאה של מודעות מותאמות:
השלבים הבאים
לעיין בנושאים הבאים: