ערכות IMA SDK מאפשרות לשלב בקלות מודעות מולטימדיה באתרים ובאפליקציות. IMA SDKs יכולים לשלוח בקשות למודעות מכל שרת מודעות שתואם ל-VAST ולנהל את ההפעלה של המודעות באפליקציות. עם IMA SDK בצד הלקוח, אתם שומרים על שליטה בהפעלת תוכן הווידאו, בזמן שה-SDK מטפל בהפעלת המודעות. המודעות מוצגות בנגן וידאו נפרד שממוקם מעל נגן הווידאו של התוכן באפליקציה.
במדריך הזה מוסבר איך לשלב את IMA SDK באפליקציית נגן וידאו פשוטה. אם אתם רוצים לראות או לעקוב אחרי שילוב לדוגמה, אתם יכולים להוריד את הדוגמה הפשוטה מ-GitHub. אם אתם מעוניינים בנגן HTML5 עם SDK שמשולב מראש, כדאי לעיין בפלאגין IMA SDK ל-Video.js.
סקירה כללית על IMA בצד הלקוח
הטמעה של IMA בצד הלקוח כוללת ארבעה רכיבי SDK עיקריים, שמוסברים במדריך הזה:
-
AdDisplayContainer
: אובייקט מאגר שמציין איפה IMA מעבד רכיבי ממשק משתמש של מודעות ומודד את הניראות, כולל Active View ו-Open Measurement. -
AdsLoader
: אובייקט שמבקש מודעות ומטפל באירועים מתגובות לבקשות מודעות. צריך ליצור רק מופע אחד של Ads Loader, שאפשר לעשות בו שימוש חוזר במהלך הפעילות של האפליקציה. -
AdsRequest
: אובייקט שמגדיר בקשה להצגת מודעות. בבקשות להצגת מודעות מצוינת כתובת ה-URL של תג המודעה בפורמט VAST, וגם פרמטרים נוספים כמו מידות המודעה. -
AdsManager
: אובייקט שמכיל את התגובה לבקשת המודעות, שולט בהפעלת המודעות ומאזין לאירועי מודעות שהופעלו על ידי ה-SDK.
דרישות מוקדמות
לפני שמתחילים, צריך לוודא שיש לכם:
- שלושה קבצים ריקים:
- index.html
- style.css
- ads.js
- Python מותקן במחשב, או שרת אינטרנט לשימוש בבדיקות
1. הפעלת שרת פיתוח
IMA SDK טוען תלות באמצעות אותו פרוטוקול כמו הדף שממנו הוא נטען, ולכן צריך להשתמש בשרת אינטרנט כדי לבדוק את האפליקציה. הדרך הכי פשוטה להפעיל שרת פיתוח מקומי היא להשתמש בשרת המובנה של Python.
- משתמשים בשורת פקודה, מהספרייה שמכילה את הקובץ index.html, ומריצים את הפקודה:
python -m http.server 8000
- בדפדפן אינטרנט, עוברים אל
http://localhost:8000/
אפשר גם להשתמש בכל שרת אינטרנט אחר, כמו Apache HTTP Server.
2. יצירת נגן וידאו פשוט
קודם כול, משנים את index.html כדי ליצור רכיב פשוט של סרטון HTML5, שכלול ברכיב עוטף, ולחצן להפעלת הסרטון. בדוגמה הבאה, מייבאים את IMA SDK ומגדירים את רכיב הקונטיינר AdDisplayContainer
. פרטים נוספים זמינים בשלבים
ייבוא IMA SDK
ו
יצירת מאגר המודעות
.
מוסיפים את התגים הנדרשים כדי לטעון את הקבצים style.css ו-ads.js. לאחר מכן, משנים את הקובץ styles.css כדי שהנגן יהיה רספונסיבי בניידים. לבסוף, בקובץ ads.js, מגדירים את המשתנים ומפעילים את הפעלת הסרטון כשלוחצים על לחצן ההפעלה.
שימו לב שקטע הקוד ads.js מכיל קריאה ל-setUpIMA()
, שמוגדרת בקטע
Initialize the AdsLoader and make an ads request
.
3. ייבוא של IMA SDK
לאחר מכן, מוסיפים את מסגרת IMA באמצעות תג script בקובץ index.html, לפני התג של
ads.js
.
4. יצירת קונטיינר המודעה
ברוב הדפדפנים, IMA SDK משתמש באלמנט ייעודי של מאגר מודעות כדי להציג מודעות ואלמנטים של ממשק משתמש שקשורים למודעות. גודל מאגר התגים הזה צריך להיות כזה שהוא יכסה את רכיב הסרטון מהפינה הימנית העליונה. הגובה והרוחב של המודעות שמוצבות במאגר הזה מוגדרים על ידי האובייקט adsManager
, כך שאין צורך להגדיר את הערכים האלה באופן ידני.
כדי להטמיע את רכיב מאגר המודעות הזה, קודם יוצרים רכיב div
חדש בתוך הרכיב video-container
. לאחר מכן, מעדכנים את ה-CSS כדי למקם את הרכיב בפינה הימנית העליונה של video-element
. לבסוף, מוסיפים את הפונקציה createAdDisplayContainer()
כדי ליצור את האובייקט AdDisplayContainer
באמצעות מאגר המודעות החדש div
.
5. מאתחלים את AdsLoader ושולחים בקשה להצגת מודעות
כדי לבקש מודעות, צריך ליצור מופע של AdsLoader
. הקונסטרוקטור AdsLoader
מקבל אובייקט AdDisplayContainer
כקלט, ואפשר להשתמש בו כדי לעבד אובייקטים מסוג AdsRequest
שמשויכים לכתובת URL של תג מודעה שצוינה. תג המודעה שמשמש בדוגמה הזו מכיל מודעה של 10 שניות לפני הצגת התוכן. אתם יכולים לבדוק את כתובת ה-URL הזו של תג המודעה, או כל כתובת URL אחרת של תג מודעה, באמצעות IMA Video Suite Inspector.
מומלץ להשתמש רק במופע אחד של AdsLoader
לאורך כל מחזור החיים של הדף. כדי לשלוח בקשות נוספות להצגת מודעות, יוצרים אובייקט AdsRequest
חדש, אבל משתמשים מחדש באותו AdsLoader
. מידע נוסף זמין בשאלות הנפוצות בנושא IMA SDK.
אתם יכולים להמתין לאירועים של טעינת מודעות ושגיאות ולהגיב להם באמצעות AdsLoader.addEventListener
.
האזנה לאירועים הבאים:
ADS_MANAGER_LOADED
AD_ERROR
כדי ליצור את רכיבי ה-listener onAdsManagerLoaded()
ו-onAdError()
, אפשר לעיין בדוגמה הבאה:
6. תגובה לאירועים של AdsLoader
כשהרכיב AdsLoader
טוען מודעות בהצלחה, הוא פולט אירוע ADS_MANAGER_LOADED
. מנתחים את האירוע שמועבר לקריאה החוזרת כדי לאתחל את האובייקט AdsManager
. AdsManager
טוען את המודעות הבודדות כפי שהוגדרו בתגובה לכתובת ה-URL של תג המודעה.
חשוב לטפל בכל השגיאות שמתרחשות במהלך תהליך הטעינה. אם המודעות לא נטענות, צריך לוודא שהפעלת המדיה ממשיכה ללא מודעות כדי לא להפריע לצפייה של המשתמש בתוכן.
לפרטים נוספים על הפונקציה onAdsManagerLoaded()
, אפשר לעיין בקטעי המשנה הבאים:
טיפול בשגיאות AdsManager
ה-error handler שנוצר עבור AdsLoader
יכול לשמש גם כ-error handler עבור AdsManager
. אפשר לראות את המטפל באירועים שמשתמש מחדש בפונקציה onAdError()
.
טיפול באירועי הפעלה והשהיה
כשהרכיב AdsManager
מוכן להוספת מודעה להצגה, הוא מפעיל את האירוע CONTENT_PAUSE_REQUESTED
. הטיפול באירוע הזה מתבצע על ידי הפעלת השהיה בנגן הווידאו הבסיסי. באופן דומה, כשמודעה מסתיימת, AdsManager
מפעיל את האירוע CONTENT_RESUME_REQUESTED
. מטפלים באירוע הזה על ידי הפעלה מחדש של התוכן בסרטון הבסיסי.
הגדרות של הפונקציות onContentPauseRequested()
ו-onContentResumeRequested()
מופיעות בדוגמה הבאה:
טיפול בהפעלת תוכן במהלך מודעות לא לינאריות
הלחצן AdsManager
משהה את סרטון התוכן כשהמודעה מוכנה להפעלה, אבל ההתנהגות הזו לא מתאימה למודעות לא לינאריות, שבהן התוכן ממשיך לפעול בזמן שהמודעה מוצגת.
כדי לתמוך במודעות לא לינאריות, צריך להאזין ל-AdsManager
כדי להפעיל את האירוע LOADED
. בודקים אם המודעה היא ליניארית. אם לא, מפעילים מחדש את ההפעלה ברכיב הסרטון.
ההגדרה של הפונקציה onAdLoaded()
מופיעה בדוגמה הבאה.
7. הפעלת קליק להשהיה במכשירים ניידים
מאחר שהשכבה AdContainer
מוצגת מעל רכיב הווידאו, המשתמשים לא יכולים ליצור אינטראקציה ישירה עם הנגן שמתחתיה. הדבר עלול לבלבל משתמשים במכשירים ניידים, שמצפים ללחוץ על נגן וידאו כדי להשהות את ההפעלה. כדי לפתור את הבעיה הזו, IMA SDK מעביר את כל הקליקים שלא מטופלים על ידי IMA משכבת-העל של המודעה לרכיב AdContainer
, שבו אפשר לטפל בהם. השינוי הזה לא רלוונטי למודעות ליניאריות בדפדפנים שאינם מיועדים לנייד, כי לחיצה על המודעה פותחת את הקישור להגעה לדף היעד.
כדי להטמיע קליק להשהיה, מוסיפים את הפונקציה adContainerClick()
click handler שנקראת
במאזין לטעינת החלון.
8. הפעלת AdsManager
כדי להתחיל בהפעלת המודעה, מתחילים את AdsManager
. כדי לתמוך באופן מלא בדפדפנים לנייד, שבהם אי אפשר להפעיל מודעות באופן אוטומטי, צריך להפעיל את המודעות באמצעות אינטראקציות של המשתמש עם הדף, כמו לחיצה על לחצן ההפעלה.
9. תמיכה בשינוי הגודל של הנגן
כדי שהמודעות ישנו את הגודל שלהן באופן דינמי בהתאם לגודל של נגן הווידאו, או בהתאם לשינויים בכיוון המסך, צריך להפעיל את הפונקציה adsManager.resize()
בתגובה לאירועי שינוי הגודל של החלון.
זהו! עכשיו אתם שולחים בקשות למודעות ומציגים אותן באמצעות IMA SDK. כדי לקבל מידע על תכונות מתקדמות נוספות של SDK, אפשר לעיין במדריכים האחרים או בדוגמאות ב-GitHub.