IMA SDK की मदद से, अपनी वेबसाइटों और ऐप्लिकेशन में मल्टीमीडिया विज्ञापन आसानी से इंटिग्रेट किए जा सकते हैं. IMA SDK, VAST के साथ काम करने वाले किसी भी विज्ञापन सर्वर से विज्ञापनों का अनुरोध कर सकते हैं. साथ ही, आपके ऐप्लिकेशन में विज्ञापन चलाने की सुविधा को मैनेज कर सकते हैं. IMA DAI SDK की मदद से, ऐप्लिकेशन विज्ञापन और कॉन्टेंट वीडियो के लिए स्ट्रीम का अनुरोध करते हैं. यह कॉन्टेंट, वीओडी या लाइव कॉन्टेंट में से कोई भी हो सकता है. इसके बाद, SDK टूल एक साथ वीडियो स्ट्रीम दिखाता है, ताकि आपको अपने ऐप्लिकेशन में विज्ञापन और कॉन्टेंट वीडियो के बीच स्विच करने की ज़रूरत न पड़े.
वह DAI समाधान चुनें जिसमें आपकी दिलचस्पी है
इस गाइड में, Roku के लिए IMA DAI SDK टूल का इस्तेमाल करके, DAI पॉड सर्विंग की लाइव या वीओडी स्ट्रीम चलाने का तरीका बताया गया है. पूरे किए गए सैंपल इंटिग्रेशन को देखने या उसका पालन करने के लिए, पॉड सर्व करने का उदाहरण डाउनलोड करें.
IMA DAI Pod Serving की खास जानकारी
IMA DAI का इस्तेमाल करके पॉड सर्विंग को लागू करने में, एसडीके के दो मुख्य कॉम्पोनेंट शामिल होते हैं. इनके बारे में इस गाइड में बताया गया है:
- StreamRequest.createPodLiveStreamRequest()/- StreamRequest.createPodVodStreamRequest(): यह एक ऐसा ऑब्जेक्ट बनाता है जो Google के विज्ञापन सर्वर को स्ट्रीम करने का अनुरोध तय करता है. इन अनुरोधों में नेटवर्क कोड शामिल होता है. साथ ही, Pod Live- ima.StreamRequestके लिए कस्टम ऐसेट कुंजी और एपीआई पासकोड की ज़रूरत होती है. हालांकि, एपीआई पासकोड देना ज़रूरी नहीं है.
- StreamManager: यह एक ऐसा ऑब्जेक्ट है जो वीडियो स्ट्रीम और IMA DAI SDK के बीच कम्यूनिकेशन को मैनेज करता है. जैसे, ट्रैकिंग पिंग को ट्रिगर करना और स्ट्रीम इवेंट को पब्लिशर को फ़ॉरवर्ड करना.
इसके अलावा, आपको अपने मेनिफ़ेस्ट मैनिपुलेशन सर्वर से अनुरोध करना होगा, ताकि आपका ऐप्लिकेशन स्ट्रीम मेनिफ़ेस्ट को दिखा सके. यह प्रोसेस, वीडियो टेक्नोलॉजी पार्टनर (वीटीपी) के हिसाब से अलग-अलग हो सकती है.
ज़रूरी शर्तें
- डिवाइस के साथ काम करने वाले पेज पर जाकर देखें कि आपके इस्तेमाल के लिए यह सुविधा उपलब्ध है या नहीं.
- हमारा Roku सैंपल प्लेयर कोड डाउनलोड करें.
- Roku डिवाइस पर सैंपल प्लेयर कोड डिप्लॉय करें. इससे यह पुष्टि की जा सकेगी कि आपका डेवलपमेंट सेटअप काम कर रहा है.
वीडियो चलाना
दिए गए सैंपल वीडियो प्लेयर में, कॉन्टेंट वीडियो पहले से ही मौजूद होता है. अपने Roku डिवाइस पर सैंपल प्लेयर डिप्लॉय करें, ताकि यह पक्का किया जा सके कि आपका डेवलपमेंट एनवायरमेंट सही तरीके से सेट अप किया गया है.
अपने वीडियो प्लेयर को IMA DAI स्ट्रीम प्लेयर में बदलना
स्ट्रीम प्लेयर लागू करने के लिए, यह तरीका अपनाएं.
Sdk.xml फ़ाइल बनाना
अपने प्रोजेक्ट में MainScene.xml के साथ एक नई फ़ाइल जोड़ें. इसका नाम Sdk.xml रखें. साथ ही, इसमें यह बॉयलरप्लेट जोड़ें:
Sdk.xml
<?xml version = "1.0" encoding = "utf-8" ?>
  <component name = "imasdk" extends = "Task">
  <interface>
  </interface>
  <script type = "text/brightscript">
  <![CDATA[
    ' Your code goes here.
  ]]>
  </script>
  </component>
आपको इस गाइड में, इन दोनों फ़ाइलों (MainScene.xml और Sdk.xml) में बदलाव करना होगा.
IMA DAI SDK फ़्रेमवर्क लोड करना
फ़्रेमवर्क लोड करने के लिए, manifest और Sdk.xml में यह कोड जोड़ें:
मेनिफ़ेस्ट
bs_libs_required=googleima3
Sdk.xml
<?xml version = "1.0" encoding = "utf-8" ?>
  <component name = "imasdk" extends = "Task">
  <interface>
  </interface>
  <script type = "text/brightscript">
  <![CDATA[
  Library "IMA3.brs"
  ]]>
  </script>
  </component>
IMA DAI SDK को शुरू करना
IMA की डाइनैमिक विज्ञापन इन्सर्ट करने की सुविधा वाली स्ट्रीम को लोड करने के लिए, सबसे पहले IMA DAI SDK को लोड और शुरू करें. नीचे दिए गए कोड से, IMA DAI SDK स्क्रिप्ट को शुरू किया जाता है.
Sdk.xml
<?xml version="1.0" encoding="utf-8" ?>
  <component name="IMASDKTask" extends="Task">
  <interface>
    <field id="IMASDKInitialized" type="Boolean" />
    <field id="errors" type="stringarray" />
  </interface>
  <script type = "text/brightscript">
  <![CDATA[
    Library "IMA3.brs"
    sub init()
      m.top.functionName = "runThread"
    end sub
    sub runThread()
      if not m.top.IMASDKInitialized
        initializeIMASDK()
      end if
    end sub
    sub initializeIMASDK()
        if m.sdk = invalid
          m.sdk = New_IMASDK()
        end if
        m.top.IMASDKInitialized = true
    end sub
  ]]>
  </script>
  </component>
अब इस टास्क को MainScene.xml में शुरू करें और कॉन्टेंट
स्ट्रीम को लोड करने के लिए कॉल हटाएं.
MainScene.xml
<?xml version="1.0" encoding="utf-8" ?>
<component extends="Scene" initialFocus="myVideo" name="MainScene">
  <script type="text/brightscript">
  <![CDATA[
  function init()
    m.video = m.top.findNode("myVideo")
    m.video.notificationinterval = 1
    runIMASDKTask()
  end function
  function runIMASDKTask()
    m.IMASDKTask = createObject("roSGNode", "IMASDKTask")
    m.IMASDKTask.observeField("IMASDKInitialized", "handleIMASDKInitialized")
    m.IMASDKTask.observeField("errors", "handleIMASDKErrors")
    m.IMASDKTask.control = "RUN"
  end function
  sub handleIMASDKInitialized()
    ' Follow your manifest manipulator (VTP) documentation to register a user
    ' streaming session if needed.
  end sub
  sub handleIMASDKErrors(message as object)
    print "------ IMA DAI SDK failed  ------"
    if message <> invalid and message.getData() <> invalid
      print "IMA DAI SDK Error ";message.getData()
    end if
  end sub
  ]]>
  </script>
  <children>
    <Video height="720" id="myVideo" visible="false" width="1280"/>
  </children>
</component>
IMA स्ट्रीम प्लेयर बनाना
इसके बाद, आपको अपने मौजूदा roVideoScreen का इस्तेमाल करके, IMA स्ट्रीम प्लेयर बनाना होगा.
लाइव स्ट्रीम के दौरान पॉड दिखाना
लाइव स्ट्रीम के लिए, यह स्ट्रीम प्लेयर तीन कॉलबैक तरीके लागू करता है:
streamInitialized, adBreakStarted, और adBreakEnded.
स्ट्रीम लोड होने पर, ट्रिक प्ले की सुविधा भी बंद करें. इससे उपयोगकर्ताओं को विज्ञापन ब्रेक शुरू होने से पहले, विज्ञापन ब्रेक शुरू होने का इवेंट ट्रिगर होने से ठीक पहले, प्री-रोल विज्ञापन को स्किप करने से रोका जाता है.
Sdk.xml
<?xml version="1.0" encoding="utf-8" ?>
  <component name="IMASDKTask" extends="Task">
  <interface>
    <field id="IMASDKInitialized" type="Boolean" />
    <field id="errors" type="stringarray" />
    <field id="urlData" type="assocarray" />
    <field id="adPlaying" type="Boolean" />
    <field id="videoNode" type="Node" />
  </interface>
  <script type="text/brightscript">
  ...
  sub runThread()
    if not m.top.IMASDKInitialized
      initializeIMASDK()
    end if
    setupPlayerCallbacks()
  end sub
  ...
  sub initializeIMASDK()
    if m.ima = invalid
      ima = New_IMASDK()
      ima.initSdk()
      m.ima = ima
    end if
    m.top.IMASDKInitialized = true
  end sub
  sub setupPlayerCallbacks()
    m.player = m.ima.createPlayer()
    m.player.top = m.top
    m.player.streamInitialized = function(urlData)
      m.top.videoNode.enableTrickPlay = false
      m.top.urlData = urlData
    end function
    m.player.adBreakStarted = function(adBreakInfo)
      print "------ Ad break started ------"
      m.top.adPlaying = true
      m.top.videoNode.enableTrickPlay = false
    end function
    m.player.adBreakEnded = function(adBreakInfo)
      print "------ Ad break ended ------"
      m.top.adPlaying = false
      m.top.videoNode.enableTrickPlay = true
    end function
  end sub
  </script>
...
</component>
वीओडी स्ट्रीम पॉड सर्विंग
वीओडी स्ट्रीम के लिए, यह स्ट्रीम प्लेयर चार कॉलबैक तरीके लागू करता है:
streamInitialized, loadUrl, adBreakStarted, और adBreakEnded. streamInitialized कॉलबैक में, StreamManager.loadThirdPartyStream() को कॉल करना न भूलें. ऐसा न करने पर, SDK loadUrl फ़ंक्शन को ट्रिगर नहीं करेगा.
इस चरण में, आपको अपने वीडियो टेक्नोलॉजी पार्टनर (वीटीपी) से स्ट्रीम यूआरएल का अनुरोध भी करना होगा. इसके लिए, आपको loadAdPodStream() में मिला स्ट्रीम आईडी इस्तेमाल करना होगा. इसके बाद, विज्ञापन पॉड के मेनिफ़ेस्ट और आपके वीटीपी से मिले किसी भी सबटाइटल के साथ StreamManager.loadThirdPartyStream() को कॉल करें.
स्ट्रीम लोड होने पर, ट्रिक प्ले की सुविधा भी बंद करें. इससे उपयोगकर्ताओं को विज्ञापन ब्रेक शुरू होने से पहले, विज्ञापन ब्रेक शुरू होने का इवेंट ट्रिगर होने से ठीक पहले, प्री-रोल विज्ञापन को स्किप करने से रोका जाता है.
Sdk.xml
<?xml version="1.0" encoding="utf-8" ?>
  <component name="IMASDKTask" extends="Task">
  <interface>
    <field id="IMASDKInitialized" type="Boolean" />
    <field id="errors" type="stringarray" />
    <field id="adStitchedStreamInfo" type="assocarray" />
    <field id="adPlaying" type="Boolean" />
    <field id="videoNode" type="Node" />
    <field id="streamParameters" type="assocarray" />
  </interface>
  <script type="text/brightscript">
  ...
  sub runThread()
    if not m.top.IMASDKInitialized
      initializeIMASDK()
    end if
    setupPlayerCallbacks()
  end sub
  ...
  sub initializeIMASDK()
    if m.ima = invalid
      ima = New_IMASDK()
      ima.initSdk()
      m.ima = ima
    end if
    m.top.IMASDKInitialized = true
  end sub
  sub loadThirdPartyStream(adStitchedManifest as string, subtitleConfig as dynamic)
    m.streamManager.loadThirdPartyStream(adStitchedManifest, subtitleConfig)
  end sub
  sub setupPlayerCallbacks()
    m.player = m.ima.createPlayer()
    m.player.top = m.top
    m.player.streamInitialized = function(urlData)
      adStitchedManifest = m.top.streamParameters.VTPManifest.replace("[[STREAMID]]", urlData.streamId)
      loadThirdPartyStream(adStitchedManifest, m.top.streamParameters.subtitleConfig)
    end function
    m.player.loadUrl = function(streamInfo)
      m.top.adStitchedStreamInfo = streamInfo
    end function
    m.player.adBreakStarted = function(adBreakInfo)
      print "------ Ad break started ------"
      m.top.adPlaying = true
      m.top.videoNode.enableTrickPlay = false
    end function
    m.player.adBreakEnded = function(adBreakInfo)
      print "------ Ad break ended ------"
      m.top.adPlaying = false
      m.top.videoNode.enableTrickPlay = true
    end function
  end sub
  </script>
...
</component>
लाइव या वीओडी पॉड सर्व करने के लिए स्ट्रीम का अनुरोध बनाना और उसे पूरा करना
स्ट्रीम प्लेयर मिलने के बाद, स्ट्रीम करने का अनुरोध बनाया और पूरा किया जा सकता है.
इस उदाहरण में, m.testPodServingStream में सेव की गई पॉड सर्विंग स्ट्रीम का डेटा दिखाया गया है.
लाइव स्ट्रीम के दौरान पॉड दिखाना
m.testPodServingStream ऑब्जेक्ट में, उन पैरामीटर को सेव करें जिनकी मदद से Google Ad Manager, स्ट्रीम की पहचान कर सकता है. जैसे, नेटवर्क कोड और कस्टम ऐसेट कुंजी. यह कुकी, मेनिफ़ेस्ट में बदलाव करने वाले सर्वर को ऐक्सेस करने के लिए इस्तेमाल किए गए मेनिफ़ेस्ट यूआरएल को भी सेव करती है. इस मामले में, स्ट्रीम का अनुरोध पूरा होने के बाद, मेनिफ़ेस्ट यूआरएल में Google स्ट्रीम आईडी जोड़ना होगा.
AdUI (जैसे, adChoices आइकॉन) का इस्तेमाल करने के लिए, आपको अपने अनुरोध में उस नोड का रेफ़रंस भी शामिल करना होगा जिसमें आपका कॉन्टेंट वीडियो मौजूद है.
MainScene.xml
function init()
  m.video = m.top.findNode("myVideo")
  m.video.notificationinterval = 1
  m.testPodServingStream = {
    title: "Test live stream for DAI Pod Serving",
    assetKey: "test-live-stream",
    networkCode: "your-network-code",
    manifest: "https://.../master.m3u8?stream_id=[[STREAMID]]",
    apiKey: ""
  }
  runIMASDKTask()
end function
function runIMASDKTask()
  m.IMASDKTask = createObject("roSGNode", "IMASDKTask")
  m.IMASDKTask.streamParameters = m.testPodservingStream
  m.IMASDKTask.videoNode = m.video
  m.IMASDKTask.observeField("IMASDKInitialized", "handleIMASDKInitialized")
  m.IMASDKTask.observeField("errors", "handleIMASDKErrors")
  m.IMASDKTask.control = "RUN"
end function
Sdk.xml
<interface>
  <field id="IMASDKInitialized" type="Boolean" />
  <field id="errors" type="stringarray" />
  <field id="urlData" type="assocarray" />
  <field id="adPlaying" type="Boolean" />
  <field id="videoNode" type="Node" />
  <field id="streamParameters" type="assocarray" />
</interface>
...
sub runThread()
  if not m.top.IMASDKInitialized
    initializeIMASDK()
  end if
  setupPlayerCallbacks()
  loadAdPodStream()
end sub
sub loadAdPodStream()
  request = m.ima.CreatePodLiveStreamRequest(m.top.streamParameters.assetKey, m.top.streamParameters.networkCode, m.top.streamParameters.apiKey)
  ' Set the player object so that the request can trigger the player's
  ' callbacks at stream initialization or playback events.
  request.player = m.player
  ' Set the video node for the IMA DAI SDK to create ad UI as its child nodes.
  request.adUiNode = m.top.video
  requestResult = m.ima.requestStream(request)
  if requestResult <> invalid
    print "Error requesting stream ";requestResult
    return
  end if
  m.streamManager = invalid
  while m.streamManager = invalid
    sleep(50)
    m.streamManager = m.ima.getStreamManager()
  end while
  if m.streamManager = invalid
    errors = CreateObject("roArray", 1, True)
    invalidStreamManagerError = "Invalid stream manager"
    print invalidStreamManagerError
    errors.push(invalidStreamManagerError)
    m.top.errors = errors
    return
  end if
  if m.streamManager["type"] <> invalid and m.streamManager["type"] = "error"
    errors = CreateObject("roArray", 1, True)
    print "Stream request returns an error. " ; m.streamManager["info"]
    errors.push(m.streamManager["info"])
    m.top.errors = errors
    return
  end if
  setupStreamManager()
  m.streamManager.start()
end sub
वीओडी स्ट्रीम पॉड सर्विंग
m.testPodServingStream ऑब्जेक्ट में, स्ट्रीम के अनुरोध में इस्तेमाल किया गया नेटवर्क कोड सेव किया जाएगा, ताकि Google Ad Manager स्ट्रीम आईडी दे सके. साथ ही, मेनिफ़ेस्ट में बदलाव करने वाले सर्वर पर, उस मेनिफ़ेस्ट यूआरएल को सेव करें जिसका इस्तेमाल करके, उपयोगकर्ता के हिसाब से मेनिफ़ेस्ट को ऐक्सेस किया जाता है.
AdUI, जैसे कि adChoices आइकॉन को इस्तेमाल करने के लिए, आपको अपने अनुरोध में कॉन्टेंट वीडियो वाले नोड का रेफ़रंस भी शामिल करना होगा.
MainScene.xml
sub init()
  m.video = m.top.findNode("myVideo")
  m.video.notificationinterval = 1
  m.testPodServingStream = {
    title: "Pod Serving VOD Stream",
    networkCode: "your-network-code",
    VTPManifest: "https://.../manifest.m3u8?gam-stream-id=[[STREAMID]]",
    subtitleConfig: []
  }
  runIMASDKTask()
end sub
sub runIMASDKTask()
  m.IMASDKTask = createObject("roSGNode", "IMASDKTask")
  m.IMASDKTask.streamParameters = m.testPodservingStream
  m.IMASDKTask.videoNode = m.video
  m.IMASDKTask.observeField("IMASDKInitialized", "handleIMASDKInitialized")
  m.IMASDKTask.observeField("errors", "handleIMASDKErrors")
  m.IMASDKTask.control = "RUN"
end sub
Sdk.xml
sub runThread()
  if not m.top.IMASDKInitialized
    initializeIMASDK()
  end if
  setupPlayerCallbacks()
  loadAdPodStream()
end sub
sub loadAdPodStream()
  request = m.ima.CreatePodVodStreamRequest(m.top.streamParameters.networkCode)
  ' Set the player object so that the request can trigger the player
  ' callbacks at stream initialization or playback events.
  request.player = m.player
  ' Set the video node for the IMA DAI SDK to create ad UI as its child nodes.
  request.adUiNode = m.top.video
  requestResult = m.ima.requestStream(request)
  if requestResult <> invalid
    print "Error requesting stream ";requestResult
    return
  end if
  m.streamManager = invalid
  while m.streamManager = invalid
    sleep(50)
    m.streamManager = m.ima.getStreamManager()
  end while
  if m.streamManager = invalid
    errors = CreateObject("roArray", 1, True)
    invalidStreamManagerError = "Invalid stream manager"
    print invalidStreamManagerError
    errors.push(invalidStreamManagerError)
    m.top.errors = errors
    return
  end if
  if m.streamManager["type"] <> invalid and m.streamManager["type"] = "error"
    errors = CreateObject("roArray", 1, True)
    print "Stream request returns an error. " ; m.streamManager["info"]
    errors.push(m.streamManager["info"])
    m.top.errors = errors
    return
  end if
  setupStreamManager()
  m.streamManager.start()
end sub
इवेंट लिसनर जोड़ना और स्ट्रीम शुरू करना
लाइव स्ट्रीम के दौरान पॉड दिखाना
स्ट्रीम का अनुरोध करने के बाद, आपको सिर्फ़ कुछ काम करने होते हैं: विज्ञापन की प्रोग्रेस को ट्रैक करने के लिए, इवेंट लिसनर जोड़ें और Roku मैसेज को SDK टूल पर फ़ॉरवर्ड करें. यह ज़रूरी है कि आप सभी मैसेज SDK को फ़ॉरवर्ड करें, ताकि विज्ञापन सही तरीके से चल सकें. ऐसा न करने पर, विज्ञापन के व्यू की रिपोर्टिंग सही तरीके से नहीं की जाती.
इस चरण में, [[STREAMID]] मैक्रो को स्ट्रीम आईडी से बदलने के लिए एक फ़ंक्शन भी जोड़ा जाता है. साथ ही, पूरे मेनिफ़ेस्ट अनुरोध यूआरएल को वीडियो प्लेयर को पास किया जाता है.
इस तरीके से, इस चरण में स्ट्रीम आईडी मिलता है. हालांकि, VTP इंटिग्रेशन के आधार पर, यह इस चरण से पहले भी उपलब्ध हो सकता है.
MainScene.xml
function runIMASDKTask()
  m.IMASDKTask = createObject("roSGNode", "IMASDKTask")
  m.IMASDKTask.streamParameters = m.testPodservingStream
  m.IMASDKTask.videoNode = m.video
  m.IMASDKTask.observeField("IMASDKInitialized", "handleIMASDKInitialized")
  m.IMASDKTask.observeField("errors", "handleIMASDKErrors")
  m.sdkTask.observeField("adStitchedStreamInfo", "loadAdStitchedStream")
  m.sdkTask.control = "RUN"
end function
sub loadAdStitchedStream(message as object)
  print "Ad pod stream information ";message
  adPodStreamInfo = message.getData()
  manifest = m.testPodservingStream.manifest.Replace("[[STREAMID]]", adPodStreamInfo.streamId)
  playStream(manifest, adPodStreamInfo.format)
end sub
sub playStream(url as string, format as string)
  vidContent = createObject("RoSGNode", "ContentNode")
  vidContent.url = url
  vidContent.title = m.testPodservingStream.title
  vidContent.streamformat = format
  m.video.content = vidContent
  m.video.setFocus(true)
  m.video.visible = true
  m.video.control = "play"
  m.video.EnableCookies()
end sub
Sdk.xml
sub runThread()
  if not m.top.IMASDKInitialized
    initializeIMASDK()
  end if
  setupPlayerCallbacks()
  loadAdPodStream()
  if m.streamManager <> invalid
    runLoop()
  end if
end sub
sub runLoop()
  m.top.videoNode.timedMetaDataSelectionKeys = ["*"]
  ' IMPORTANT: Failure to listen to the position and timedmetadata fields
  ' could result in ad impressions not being reported.
  m.port = CreateObject("roMessagePort")
  m.top.videoNode.observeField("position", m.port)
  m.top.videoNode.observeField("timedMetaData", m.port)
  m.top.videoNode.observeField("timedMetaData2", m.port)
  m.top.videoNode.observeField("state", m.port)
  while True
    msg = wait(1000, m.port)
    if m.top.videoNode = invalid
      print "exiting"
      exit while
    end if
    m.streamManager.onMessage(msg)
    currentTime = m.top.videoNode.position
    if currentTime > 3 And not m.top.adPlaying
      m.top.videoNode.enableTrickPlay = true
    end if
  end while
end sub
sub setupStreamManager()
  m.streamManager.addEventListener(m.sdk.AdEvent.ERROR, errorCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.START, startCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.FIRST_QUARTILE, firstQuartileCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.MIDPOINT, midpointCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.THIRD_QUARTILE, thirdQuartileCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.COMPLETE, completeCallback)
end sub
sub startCallback(ad as object)
  print "Callback from SDK -- Start called - "
end sub
sub firstQuartileCallback(ad as object)
  print "Callback from SDK -- First quartile called - "
end sub
sub midpointCallback(ad as object)
  print "Callback from SDK -- Midpoint called - "
end sub
sub thirdQuartileCallback(ad as object)
  print "Callback from SDK -- Third quartile called - "
end sub
sub completeCallback(ad as object)
  print "Callback from SDK -- Complete called - "
end sub
function errorCallback(error as object)
  print "Callback from SDK -- Error called - " ; error
  m.errorState = True
end function
वीओडी स्ट्रीम पॉड सर्विंग
स्ट्रीम का अनुरोध करने के बाद, आपको सिर्फ़ कुछ काम करने होते हैं: विज्ञापन की प्रोग्रेस को ट्रैक करने के लिए, इवेंट लिसनर जोड़ें और Roku मैसेज को SDK टूल पर फ़ॉरवर्ड करें. यह ज़रूरी है कि आप सभी मैसेज SDK को फ़ॉरवर्ड करें, ताकि विज्ञापन सही तरीके से चल सकें. ऐसा न करने पर, विज्ञापन व्यू की रिपोर्ट सही तरीके से नहीं की जाएगी.
MainScene.xml
sub runIMASDKTask()
  m.IMASDKTask = createObject("roSGNode", "IMASDKTask")
  m.IMASDKTask.streamParameters = m.testPodservingStream
  m.IMASDKTask.videoNode = m.video
  m.IMASDKTask.observeField("IMASDKInitialized", "handleIMASDKInitialized")
  m.IMASDKTask.observeField("errors", "handleIMASDKErrors")
  m.sdkTask.observeField("adStitchedStreamInfo", "loadAdStitchedStream")
  m.sdkTask.control = "RUN"
end sub
sub loadAdStitchedStream(message as object)
  print "Ad pod stream information ";message
  adPodStreamInfo = message.getData()
end sub
sub playStream(url as string, format as string, subtitleConfig as object)
  vidContent = createObject("RoSGNode", "ContentNode")
  vidContent.title = m.testPodservingStream.title
  vidContent.url = url
  vidContent.subtitleConfig = subtitleConfig
  vidContent.streamformat = format
  m.video.content = vidContent
  m.video.setFocus(true)
  m.video.visible = true
  m.video.control = "play"
  m.video.EnableCookies()
end sub
Sdk.xml
sub runThread()
  if not m.top.IMASDKInitialized
    initializeIMASDK()
  end if
  setupPlayerCallbacks()
  loadAdPodStream()
  if m.streamManager <> invalid
    runLoop()
  end if
end sub
sub runLoop()
  m.top.videoNode.timedMetaDataSelectionKeys = ["*"]
  ' IMPORTANT: Failure to listen to the position and timedmetadata fields
  ' could result in ad impressions not being reported.
  m.port = CreateObject("roMessagePort")
  m.top.videoNode.observeField("position", m.port)
  m.top.videoNode.observeField("timedMetaData", m.port)
  m.top.videoNode.observeField("timedMetaData2", m.port)
  m.top.videoNode.observeField("state", m.port)
  while True
    msg = wait(1000, m.port)
    if m.top.videoNode = invalid
      exit while
    end if
    m.streamManager.onMessage(msg)
    currentTime = m.top.videoNode.position
    if currentTime > 3 and not m.top.adPlaying
      m.top.videoNode.enableTrickPlay = true
    end if
  end while
end sub
sub setupStreamManager()
  m.streamManager.addEventListener(m.sdk.AdEvent.ERROR, errorCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.START, startCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.FIRST_QUARTILE, firstQuartileCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.MIDPOINT, midpointCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.THIRD_QUARTILE, thirdQuartileCallback)
  m.streamManager.addEventListener(m.sdk.AdEvent.COMPLETE, completeCallback)
end sub
sub startCallback(ad as object)
  print "Callback from SDK -- Start called - "
end sub
sub firstQuartileCallback(ad as object)
  print "Callback from SDK -- First quartile called - "
end sub
sub midpointCallback(ad as object)
  print "Callback from SDK -- Midpoint called - "
end sub
sub thirdQuartileCallback(ad as object)
  print "Callback from SDK -- Third quartile called - "
end sub
sub completeCallback(ad as object)
  print "Callback from SDK -- Complete called - "
end sub
sub errorCallback(error as object)
  print "Callback from SDK -- Error called - " ; error
  m.errorState = True
end sub