ממשקי ה-API של תצוגת האינטרנט למודעות מאפשרים לתגים ב-WebView
לגשת לאותות מהאפליקציה, וכך לשפר את המונטיזציה של בעלי האפליקציות שסיפקו את התוכן ולהגן על המפרסמים מפני ספאם.
אותות האפליקציה האלה, כמו מזהה האפליקציה וגרסת האפליקציה, עוזרים להפעיל תרחישי שימוש של דיווח ושל טירגוט מלאי שטחי פרסום בדפדפן בתוך האפליקציה, שאחרת זמינים רק בתנועה שמגיעה מאפליקציות.
איך זה עובד
התקשורת עם Google Mobile Ads SDK מתבצעת רק בתגובה לאירועי מודעות שמופעלים על ידי אחד מהגורמים הבאים:
ה-SDK מוסיף מטפלים בהודעות ל-WebView
הרשום כדי להאזין לאירועי המודעות האלה. כדי להבין טוב יותר איך זה עובד, אפשר לעיין בקוד המקור של דף הבדיקה.
דרישות מוקדמות
- Google Mobile Ads SDK גרסה 20.6.0 ואילך.
רמת API 21 ומעלה ב-Android.
כדי לדלג על הבדיקה של
APPLICATION_ID
, מוסיפים את התג<meta-data>
הבא לקובץAndroidManifest.xml
: אם לא מבצעים את השלב הזה ולא מציינים את התג<meta-data>
, Google Mobile Ads SDK יציג את השגיאהIllegalStateException
עם הפעלת האפליקציה.<!-- Bypass APPLICATION_ID check for web view APIs for ads --> <meta-data android:name="com.google.android.gms.ads.INTEGRATION_MANAGER" android:value="webview"/>
רישום תצוגת האינטרנט
צריך להפעיל את הפונקציה
registerWebView()
ב-main thread כדי ליצור קישור ל-JavaScript handlers בקוד AdSense או ב-Google Publisher Tag בכל מופע של WebView
. מומלץ לעשות את זה מוקדם ככל האפשר, למשל בשיטה onCreate()
של MainActivity
.
Kotlin
import android.webkit.CookieManager
import android.webkit.WebView
import com.google.android.gms.ads.MobileAds
class MainActivity : AppCompatActivity() {
lateinit var webView: WebView
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
webView = findViewById(R.id.webview)
// Let the web view accept third-party cookies.
CookieManager.getInstance().setAcceptThirdPartyCookies(webView, true)
// Let the web view use JavaScript.
webView.settings.javaScriptEnabled = true
// Let the web view access local storage.
webView.settings.domStorageEnabled = true
// Let HTML videos play automatically.
webView.settings.mediaPlaybackRequiresUserGesture = false
// Register the web view.
MobileAds.registerWebView(webView)
}
}
Java
import android.webkit.CookieManager;
import android.webkit.WebView;
import com.google.android.gms.ads.MobileAds;
public class MainActivity extends AppCompatActivity {
private WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView = findViewById(R.id.webview);
// Let the web view accept third-party cookies.
CookieManager.getInstance().setAcceptThirdPartyCookies(webView, true);
// Let the web view use JavaScript.
webView.getSettings().setJavaScriptEnabled(true);
// Let the web view access local storage.
webView.getSettings().setDomStorageEnabled(true);
// Let HTML videos play automatically.
webView.getSettings().setMediaPlaybackRequiresUserGesture(false);
// Register the web view.
MobileAds.registerWebView(webView);
}
}
בדיקת השילוב
לפני שמשתמשים בכתובת URL משלכם, מומלץ לטעון את כתובת ה-URL הבאה כדי לבדוק את השילוב:
https://google.github.io/webview-ads/test/#api-for-ads-tests
אם מתקיימים התנאים הבאים, כתובת ה-URL של הבדיקה מציגה סרגלי סטטוס ירוקים שמציינים שהשילוב בוצע בהצלחה:
WebView
מחובר ל-Google Mobile Ads SDK
השלבים הבאים
- קבלת הסכמה ב-
WebView
. ממשקי ה-API של תצוגות האינטרנט לצורך הצגת מודעות לא מעבירים את ההסכמה שנאספה בהקשר של האפליקציה לנייד באמצעות IAB TCF גרסה 2.0 או IAB CCPA, אל התגים בתצוגות האינטרנט. אם אתם רוצים להטמיע תהליך הסכמה יחיד כבעלים שלWebView
ושל תוכן האינטרנט התואם שמניב הכנסות, אתם צריכים לעבוד עם הפלטפורמה לניהול הסכמה כדי לקבל הסכמה בהקשר שלWebView
.