ממשקי ה-API של תצוגת האינטרנט למודעות מאפשרים לסימנים מהאפליקציה להיות זמינים לתגים ב-WebView
, וכך עוזרים לשפר את המונטיזציה של בעלי האפליקציות שסיפקו את התוכן, ומגינים על המפרסמים מפני ספאם.
אותות האפליקציה האלה, כמו מזהה האפליקציה וגרסה שלה, עוזרים להפעיל תרחישים לדוגמה של דיווח ושל טירגוט מלאי שטחי פרסום בדפדפן בתוך האפליקציה, שבדרך כלל זמינים רק בתנועה באפליקציה.
איך זה עובד
התקשורת עם Google Mobile Ads SDK מתרחשת רק בתגובה לאירועי מודעות שמופעל על ידי אחד מהגורמים הבאים:
ה-SDK מוסיף מנהלי הודעות ל-WebView
הרשום כדי להאזין לאירועי המודעות האלה. כדי להבין טוב יותר איך זה עובד, אפשר לעיין בקוד המקור של דף הבדיקה.
דרישות מוקדמות
- Google Mobile Ads SDK בגרסה 20.6.0 ואילך.
Android API ברמה 21 ואילך.
כדי לעקוף את הבדיקה של
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()
בשרשור הראשי כדי ליצור חיבור למטפלי JavaScript בקוד AdSense או ב-Google Publisher Tag בכל WebView
מכונה. כדאי לעשות זאת מוקדם ככל האפשר, למשל בשיטהmethod 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://webview-api-for-ads-test.glitch.me#api-for-ads-tests
אם מתקיימים התנאים הבאים, בכתובת ה-URL לבדיקה יוצגו פסי סטטוס ירוקים שמציינים שילוב מוצלח:
WebView
מחוברת ל-Google Mobile Ads SDK
השלבים הבאים
- מקבלים הסכמה ב-
WebView
. ממשקי ה-API של תצוגת האינטרנט ב-Ads לא מעבירים לתגים בתצוגות האינטרנט את ההסכמה שנאספה בהקשר של האפליקציה לנייד באמצעות מסגרות התאימות של IAB TCF v2.0 או IAB CCPA. אם אתם רוצים להטמיע תהליך הסכמה יחיד כי אתם הבעלים שלWebView
ושל תוכן האינטרנט התואם שממנו אתם מוציאים הכנסות, עליכם לעבוד עם הפלטפורמה לניהול הסכמה כדי לאסוף הסכמה בהקשר שלWebView
.