מומלץ ליישם כמה שיטות מומלצות כדי לוודא שהאפליקציה פועלת באופן תקין ב-Android TV, כשאתם משתמשים ב-IMA SDK ל-Android.
כדי להתחיל, כדאי להכיר את התהליך של פיתוח אפליקציות לטלוויזיה ל-Android. צריך לוודא שהפעילות מוגדרת באופן ספציפי לטלוויזיה, כפי שמוסבר במדריך למתחילים. כדאי גם לטפל בניווט בטלוויזיה כדי לוודא שהמשתמשים יכולים לנווט באפליקציה שלכם ב-Android TV.
טיפול במודעות שניתן לדלג עליהן
ערכת ה-SDK מבצעת אופטימיזציה של פורמטים שניתנים לדילוג במכשירים דמויי טלוויזיה. למשל, על ידי הסרת האפשרות לאינטראקציה חוזרת באמצעות הלחצן למידע נוסף. כברירת מחדל, ה-SDK מגדיר את המיקוד בלחצן הדילוג כשהדילוג זמין, כדי שאפשר יהיה לדלג על המודעה ב-Android TV. לכן, אין צורך לבצע עבודה נוספת כדי לתמוך במודעות שניתן לדלג עליהן.
כדי להגדיר את זה, צריך להפעיל את הפונקציה AdsRenderingSettings.setFocusSkipButtonWhenAvailable()
.
למידע נוסף על המודעות הנתמכות, מומלץ לעיין במטריצת התאימות.
טיפול בתמונות חלופיות של סמל VAST
ה-IMA SDK מזהה את האינטראקציה של המשתמש עם התמונות החלופיות של סמלי ה-VAST, מבצע עיבוד שלהן ומטפל בהן. האפליקציה צריכה להאזין לאירועים ICON_TAPPED
ו-ICON_FALLBACK_IMAGE_CLOSED
כדי לטפל בהפעלת מודעות במודעות שמשתמשות בתכונה 'למה דווקא המודעה הזו?' (WTA).
צריך להוסיף ערך בוליאני כדי לבדוק אם מוצגת תמונה חלופית של סמל VAST. לאחר מכן, מקשיבים ל-ICON_TAPPED
ול-ICON_FALLBACK_IMAGE_CLOSED
כדי לטפל בהפעלת מודעות סביב התמונה החלופית של סמל VAST. בקטע Advanced Example תוכלו לראות דוגמה לאופן הטיפול הזה.
app/src/main/java/com/google/ads/interactivemedia/v3/samples/videoplayerapp/VideoPlayerController.java
// Copyright 2014 Google Inc. All Rights Reserved. package com.google.ads.interactivemedia.v3.samples.videoplayerapp; import android.app.UiModeManager; import android.content.Context; ... // Tracks if the SDK is playing an ad, since the SDK might not necessarily use // the video player provided to play the video ad. private boolean isAdPlaying; // Tracks whether the SDK has a VAST icon fallback image showing. private boolean isConnectedTvFallbackImageShowing = false; // View that handles taps to toggle ad pause/resume during video playback. private View playPauseToggle; // View that we can write log messages to, to display in the UI. private Logger log; ... adsManager.addAdEventListener( new AdEvent.AdEventListener() { /** Responds to AdEvents. */ @Override public void onAdEvent(AdEvent adEvent) { ... case CONTENT_RESUME_REQUESTED: // AdEventType.CONTENT_RESUME_REQUESTED is fired when the ad is // completed and you should start playing your content. resumeContent(); break; case ICON_TAPPED: // The user has tapped a VAST icon fallback image. On Android // mobile apps, the SDK will navigate to the landing page. On // Connected TV devices, the SDK will present a modal dialog // containing the VAST icon fallback image. // Check if the app is running on a TV device. UiModeManager uiModeManager = (UiModeManager) getSystemService(UI_MODE_SERVICE); if (uiModeManager.getCurrentModeType() == Configuration.UI_MODE_TYPE_TELEVISION) { isConnectedTvFallbackImageShowing = true; } // Focus the IMA WebView for easier access to ad UI elements. adsManager.focus(); break; case PAUSED: if (isConnectedTvFallbackImageShowing) { // Do not show the controls; continue to leave the controls in // the hands of the ads SDK. break; } isAdPlaying = false; videoPlayerWithAdPlayback.enableControls(); break; case ICON_FALLBACK_IMAGE_CLOSED: // The user has closed the VAST icon fallback image. This may // be a good time to resume ad playback if the user is ready to // continue playing the ad. This event only fires for Connected // TV devices. isConnectedTvFallbackImageShowing = false; adsManager.resume(); break; case RESUMED: isAdPlaying = true; videoPlayerWithAdPlayback.disableControls(); break;