ערכות 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
: אובייקט שמבקש מודעות ומטפל באירועים מתגובות לבקשות מודעות. צריך ליצור רק מופע אחד של הכלי להעלאת מודעות, שאפשר להשתמש בו שוב לאורך חיי האפליקציה. -
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()
פונקציית הטיפול בקליקים שנקראת
במאזין לטעינת החלון.
8. הפעלת AdsManager
כדי להתחיל בהפעלת המודעה, מתחילים את AdsManager
. כדי לתמוך באופן מלא בדפדפנים לנייד, שבהם אי אפשר להפעיל מודעות באופן אוטומטי, צריך להפעיל את המודעות בעקבות אינטראקציות של המשתמש עם הדף, כמו לחיצה על לחצן ההפעלה.
9. תמיכה בשינוי הגודל של הנגן
כדי שהמודעות ישנו את הגודל שלהן באופן דינמי בהתאם לגודל של נגן הווידאו, או בהתאם לשינויים בכיוון המסך, צריך לקרוא ל-adsManager.resize()
בתגובה לאירועי שינוי הגודל של החלון.
זהו! עכשיו אתם שולחים בקשות למודעות ומציגים אותן באמצעות IMA SDK. כדי לקבל מידע על תכונות מתקדמות נוספות של SDK, אפשר לעיין במדריכים האחרים או בדוגמאות ב-GitHub.