IMA DAI SDK দিয়ে শুরু করুন

IMA SDKগুলি আপনার ওয়েবসাইট এবং অ্যাপগুলিতে মাল্টিমিডিয়া বিজ্ঞাপনগুলিকে একীভূত করা সহজ করে তোলে৷ IMA SDK যেকোন VAST-সঙ্গী বিজ্ঞাপন সার্ভার থেকে বিজ্ঞাপনের অনুরোধ করতে পারে এবং আপনার অ্যাপে বিজ্ঞাপন প্লেব্যাক পরিচালনা করতে পারে। IMA DAI SDK-এর সাথে, অ্যাপগুলি বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর জন্য একটি স্ট্রিম অনুরোধ করে—হয় VOD বা লাইভ সামগ্রী। SDK তারপরে একটি সম্মিলিত ভিডিও স্ট্রিম ফেরত দেয়, যাতে আপনাকে আপনার অ্যাপের মধ্যে বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর মধ্যে স্যুইচিং পরিচালনা করতে হবে না।

আপনি আগ্রহী DAI সমাধান নির্বাচন করুন

এই নির্দেশিকাটি দেখায় কিভাবে একটি DAI পড সার্ভিং লাইভ বা VOD স্ট্রিম খেলতে হয়, Roku এর জন্য IMA DAI SDK ব্যবহার করে।

IMA DAI পড সার্ভিং ওভারভিউ

IMA DAI ব্যবহার করে পড পরিবেশন বাস্তবায়নে দুটি প্রধান SDK উপাদান জড়িত, যা এই নির্দেশিকায় প্রদর্শিত হয়েছে:

  • StreamRequest.createPodLiveStreamRequest() / StreamRequest.createPodVodStreamRequest() : এমন একটি বস্তু তৈরি করে যা Google-এর বিজ্ঞাপন সার্ভারে একটি স্ট্রিম অনুরোধ সংজ্ঞায়িত করে। এই অনুরোধগুলি একটি নেটওয়ার্ক কোড নির্দিষ্ট করে, এবং পড লাইভ ima.StreamRequest স্ট্রিমরিকোয়েস্টের জন্য একটি কাস্টম সম্পদ কী এবং একটি ঐচ্ছিক API কী প্রয়োজন।
  • StreamManager : একটি বস্তু যা ভিডিও স্ট্রীম এবং IMA DAI SDK-এর মধ্যে যোগাযোগ পরিচালনা করে, যেমন ফায়ারিং ট্র্যাকিং পিং এবং প্রকাশকের কাছে স্ট্রিম ইভেন্ট ফরওয়ার্ড করা।

এছাড়াও, আপনার অ্যাপটি প্রদর্শনের জন্য স্ট্রিম ম্যানিফেস্ট পুনরুদ্ধার করতে আপনাকে আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে একটি অনুরোধ করতে হবে। সঠিক প্রক্রিয়া ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে VTP-তে পরিবর্তিত হতে পারে।

পূর্বশর্ত

  • আপনার উদ্দেশ্য ব্যবহার কেস সমর্থিত তা নিশ্চিত করতে আমাদের সামঞ্জস্য পৃষ্ঠাটি পড়ুন।
  • আমাদের 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 স্ট্রিম প্লেয়ার তৈরি করুন

এর পরে, একটি IMA স্ট্রিম প্লেয়ার তৈরি করতে আপনাকে আপনার বিদ্যমান roVideoScreen ব্যবহার করতে হবে।

লাইভ স্ট্রিম পড পরিবেশন

লাইভ স্ট্রীমের জন্য, এই স্ট্রিম প্লেয়ার তিনটি কলব্যাক পদ্ধতি প্রয়োগ করে: 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>

ভিওডি স্ট্রিম পড পরিবেশন

VOD স্ট্রিমগুলির জন্য, এই স্ট্রিম প্লেয়ারটি চারটি কলব্যাক পদ্ধতি প্রয়োগ করে: streamInitialized , loadUrl , adBreakStarted , এবং adBreakEndedstreamInitialized কলব্যাকে, StreamManager.loadThirdPartyStream() কল করতে ভুলবেন না। এটি করতে ব্যর্থ হলে SDK loadUrl ফাংশন ট্রিগার করবে না।

এই ধাপে, আপনি loadAdPodStream() এ প্রাপ্ত একটি স্ট্রীম আইডি সহ আপনার ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে একটি স্ট্রিম URL এর জন্য অনুরোধ করবেন৷ তারপর, বিজ্ঞাপন পড ম্যানিফেস্ট এবং আপনার VTP দ্বারা ফিরে আসা যেকোনো সাবটাইটেল সহ 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>

একটি লাইভ বা VOD পড সার্ভিং স্ট্রিম অনুরোধ তৈরি করুন এবং চালান

আপনার কাছে একটি স্ট্রিম প্লেয়ার থাকার পরে, আপনি একটি স্ট্রিম অনুরোধ তৈরি এবং কার্যকর করতে পারেন৷ এই উদাহরণে m.testPodServingStream এ সঞ্চিত একটি পড সার্ভিং স্ট্রিমের ডেটা রয়েছে।

লাইভ স্ট্রিম পড পরিবেশন

m.testPodServingStream অবজেক্টে, একটি নেটওয়ার্ক কোড এবং কাস্টম অ্যাসেট কী-এর মতো প্রশ্নে থাকা স্ট্রীম শনাক্ত করার জন্য Google Ad Manager-এর প্রয়োজনীয় প্যারামিটারগুলি সঞ্চয় করুন৷ এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভার অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন। এই ক্ষেত্রে, স্ট্রিম অনুরোধ ফেরত দেওয়ার পরে ম্যানিফেস্ট URL-এ 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 একটি স্ট্রিম আইডি প্রদান করতে পারে। এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে ব্যবহারকারী নির্দিষ্ট ম্যানিফেস্ট অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন।

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

ইভেন্ট শ্রোতা যোগ করুন এবং স্ট্রীম শুরু করুন

লাইভ স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা SDK-এ ফরোয়ার্ড করা গুরুত্বপূর্ণ। এটি করতে ব্যর্থ হলে বিজ্ঞাপনের দৃশ্যগুলিকে ভুলভাবে রিপোর্ট করা হয়।

এই ধাপে, আপনি স্ট্রিম আইডি দিয়ে [[STREAMID]] ম্যাক্রো প্রতিস্থাপন করার জন্য একটি ফাংশন যোগ করুন এবং ভিডিও প্লেয়ারে সম্পূর্ণ ম্যানিফেস্ট অনুরোধ URL পাস করুন। এই বাস্তবায়ন এই ধাপে স্ট্রিম আইডি পায়, কিন্তু আপনার 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

ভিওডি স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা 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
,

IMA SDKগুলি আপনার ওয়েবসাইট এবং অ্যাপগুলিতে মাল্টিমিডিয়া বিজ্ঞাপনগুলিকে একীভূত করা সহজ করে তোলে৷ IMA SDK যেকোন VAST-সঙ্গী বিজ্ঞাপন সার্ভার থেকে বিজ্ঞাপনের অনুরোধ করতে পারে এবং আপনার অ্যাপে বিজ্ঞাপন প্লেব্যাক পরিচালনা করতে পারে। IMA DAI SDK-এর সাথে, অ্যাপগুলি বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর জন্য একটি স্ট্রিম অনুরোধ করে—হয় VOD বা লাইভ সামগ্রী। SDK তারপরে একটি সম্মিলিত ভিডিও স্ট্রিম ফেরত দেয়, যাতে আপনাকে আপনার অ্যাপের মধ্যে বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর মধ্যে স্যুইচিং পরিচালনা করতে হবে না।

আপনি আগ্রহী DAI সমাধান নির্বাচন করুন

এই নির্দেশিকাটি দেখায় কিভাবে একটি DAI পড সার্ভিং লাইভ বা VOD স্ট্রিম খেলতে হয়, Roku এর জন্য IMA DAI SDK ব্যবহার করে।

IMA DAI পড সার্ভিং ওভারভিউ

IMA DAI ব্যবহার করে পড পরিবেশন বাস্তবায়নে দুটি প্রধান SDK উপাদান জড়িত, যা এই নির্দেশিকায় প্রদর্শিত হয়েছে:

  • StreamRequest.createPodLiveStreamRequest() / StreamRequest.createPodVodStreamRequest() : এমন একটি বস্তু তৈরি করে যা Google-এর বিজ্ঞাপন সার্ভারে একটি স্ট্রিম অনুরোধ সংজ্ঞায়িত করে। এই অনুরোধগুলি একটি নেটওয়ার্ক কোড নির্দিষ্ট করে, এবং পড লাইভ ima.StreamRequest স্ট্রিমরিকোয়েস্টের জন্য একটি কাস্টম সম্পদ কী এবং একটি ঐচ্ছিক API কী প্রয়োজন।
  • StreamManager : একটি বস্তু যা ভিডিও স্ট্রীম এবং IMA DAI SDK-এর মধ্যে যোগাযোগ পরিচালনা করে, যেমন ফায়ারিং ট্র্যাকিং পিং এবং প্রকাশকের কাছে স্ট্রিম ইভেন্ট ফরওয়ার্ড করা।

এছাড়াও, আপনার অ্যাপটি প্রদর্শনের জন্য স্ট্রিম ম্যানিফেস্ট পুনরুদ্ধার করতে আপনাকে আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে একটি অনুরোধ করতে হবে। সঠিক প্রক্রিয়া ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে VTP-তে পরিবর্তিত হতে পারে।

পূর্বশর্ত

  • আপনার উদ্দেশ্য ব্যবহার কেস সমর্থিত তা নিশ্চিত করতে আমাদের সামঞ্জস্য পৃষ্ঠাটি পড়ুন।
  • আমাদের 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 স্ট্রিম প্লেয়ার তৈরি করুন

এর পরে, একটি IMA স্ট্রিম প্লেয়ার তৈরি করতে আপনাকে আপনার বিদ্যমান roVideoScreen ব্যবহার করতে হবে।

লাইভ স্ট্রিম পড পরিবেশন

লাইভ স্ট্রীমের জন্য, এই স্ট্রিম প্লেয়ার তিনটি কলব্যাক পদ্ধতি প্রয়োগ করে: 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>

ভিওডি স্ট্রিম পড পরিবেশন

VOD স্ট্রিমগুলির জন্য, এই স্ট্রিম প্লেয়ারটি চারটি কলব্যাক পদ্ধতি প্রয়োগ করে: streamInitialized , loadUrl , adBreakStarted , এবং adBreakEndedstreamInitialized কলব্যাকে, StreamManager.loadThirdPartyStream() কল করতে ভুলবেন না। এটি করতে ব্যর্থ হলে SDK loadUrl ফাংশন ট্রিগার করবে না।

এই ধাপে, আপনি loadAdPodStream() এ প্রাপ্ত একটি স্ট্রীম আইডি সহ আপনার ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে একটি স্ট্রিম URL এর জন্য অনুরোধ করবেন৷ তারপর, বিজ্ঞাপন পড ম্যানিফেস্ট এবং আপনার VTP দ্বারা ফিরে আসা যেকোনো সাবটাইটেল সহ 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>

একটি লাইভ বা VOD পড সার্ভিং স্ট্রিম অনুরোধ তৈরি করুন এবং চালান

আপনার কাছে একটি স্ট্রিম প্লেয়ার থাকার পরে, আপনি একটি স্ট্রিম অনুরোধ তৈরি এবং কার্যকর করতে পারেন৷ এই উদাহরণে m.testPodServingStream এ সঞ্চিত একটি পড সার্ভিং স্ট্রিমের ডেটা রয়েছে।

লাইভ স্ট্রিম পড পরিবেশন

m.testPodServingStream অবজেক্টে, একটি নেটওয়ার্ক কোড এবং কাস্টম অ্যাসেট কী-এর মতো প্রশ্নে থাকা স্ট্রীম শনাক্ত করার জন্য Google Ad Manager-এর প্রয়োজনীয় প্যারামিটারগুলি সঞ্চয় করুন৷ এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভার অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন। এই ক্ষেত্রে, স্ট্রিম অনুরোধ ফেরত দেওয়ার পরে ম্যানিফেস্ট URL-এ 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 একটি স্ট্রিম আইডি প্রদান করতে পারে। এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে ব্যবহারকারী নির্দিষ্ট ম্যানিফেস্ট অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন।

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

ইভেন্ট শ্রোতা যোগ করুন এবং স্ট্রীম শুরু করুন

লাইভ স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা SDK-এ ফরোয়ার্ড করা গুরুত্বপূর্ণ। এটি করতে ব্যর্থ হলে বিজ্ঞাপনের দৃশ্যগুলিকে ভুলভাবে রিপোর্ট করা হয়।

এই ধাপে, আপনি স্ট্রিম আইডি দিয়ে [[STREAMID]] ম্যাক্রো প্রতিস্থাপন করার জন্য একটি ফাংশন যোগ করুন এবং ভিডিও প্লেয়ারে সম্পূর্ণ ম্যানিফেস্ট অনুরোধ URL পাস করুন। এই বাস্তবায়ন এই ধাপে স্ট্রিম আইডি পায়, কিন্তু আপনার 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

ভিওডি স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা 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
,

IMA SDKগুলি আপনার ওয়েবসাইট এবং অ্যাপগুলিতে মাল্টিমিডিয়া বিজ্ঞাপনগুলিকে একীভূত করা সহজ করে তোলে৷ IMA SDK যেকোন VAST-সঙ্গী বিজ্ঞাপন সার্ভার থেকে বিজ্ঞাপনের অনুরোধ করতে পারে এবং আপনার অ্যাপে বিজ্ঞাপন প্লেব্যাক পরিচালনা করতে পারে। IMA DAI SDK-এর সাথে, অ্যাপগুলি বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর জন্য একটি স্ট্রিম অনুরোধ করে—হয় VOD বা লাইভ সামগ্রী। SDK তারপরে একটি সম্মিলিত ভিডিও স্ট্রিম ফেরত দেয়, যাতে আপনাকে আপনার অ্যাপের মধ্যে বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর মধ্যে স্যুইচিং পরিচালনা করতে হবে না।

আপনি আগ্রহী DAI সমাধান নির্বাচন করুন

এই নির্দেশিকাটি দেখায় কিভাবে একটি DAI পড সার্ভিং লাইভ বা VOD স্ট্রিম খেলতে হয়, Roku এর জন্য IMA DAI SDK ব্যবহার করে।

IMA DAI পড সার্ভিং ওভারভিউ

IMA DAI ব্যবহার করে পড পরিবেশন বাস্তবায়নে দুটি প্রধান SDK উপাদান জড়িত, যা এই নির্দেশিকায় প্রদর্শিত হয়েছে:

  • StreamRequest.createPodLiveStreamRequest() / StreamRequest.createPodVodStreamRequest() : এমন একটি বস্তু তৈরি করে যা Google-এর বিজ্ঞাপন সার্ভারে একটি স্ট্রিম অনুরোধ সংজ্ঞায়িত করে। এই অনুরোধগুলি একটি নেটওয়ার্ক কোড নির্দিষ্ট করে, এবং পড লাইভ ima.StreamRequest স্ট্রিমরিকোয়েস্টের জন্য একটি কাস্টম সম্পদ কী এবং একটি ঐচ্ছিক API কী প্রয়োজন।
  • StreamManager : একটি বস্তু যা ভিডিও স্ট্রীম এবং IMA DAI SDK-এর মধ্যে যোগাযোগ পরিচালনা করে, যেমন ফায়ারিং ট্র্যাকিং পিং এবং প্রকাশকের কাছে স্ট্রিম ইভেন্ট ফরওয়ার্ড করা।

এছাড়াও, আপনার অ্যাপটি প্রদর্শনের জন্য স্ট্রিম ম্যানিফেস্ট পুনরুদ্ধার করতে আপনাকে আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে একটি অনুরোধ করতে হবে। সঠিক প্রক্রিয়া ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে VTP-তে পরিবর্তিত হতে পারে।

পূর্বশর্ত

  • আপনার উদ্দেশ্য ব্যবহার কেস সমর্থিত তা নিশ্চিত করতে আমাদের সামঞ্জস্য পৃষ্ঠাটি পড়ুন।
  • আমাদের 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 স্ট্রিম প্লেয়ার তৈরি করুন

এর পরে, একটি IMA স্ট্রিম প্লেয়ার তৈরি করতে আপনাকে আপনার বিদ্যমান roVideoScreen ব্যবহার করতে হবে।

লাইভ স্ট্রিম পড পরিবেশন

লাইভ স্ট্রীমের জন্য, এই স্ট্রিম প্লেয়ার তিনটি কলব্যাক পদ্ধতি প্রয়োগ করে: 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>

ভিওডি স্ট্রিম পড পরিবেশন

VOD স্ট্রিমগুলির জন্য, এই স্ট্রিম প্লেয়ারটি চারটি কলব্যাক পদ্ধতি প্রয়োগ করে: streamInitialized , loadUrl , adBreakStarted , এবং adBreakEndedstreamInitialized কলব্যাকে, StreamManager.loadThirdPartyStream() কল করতে ভুলবেন না। এটি করতে ব্যর্থ হলে SDK loadUrl ফাংশন ট্রিগার করবে না।

এই ধাপে, আপনি loadAdPodStream() এ প্রাপ্ত একটি স্ট্রীম আইডি সহ আপনার ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে একটি স্ট্রিম URL এর জন্য অনুরোধ করবেন৷ তারপর, বিজ্ঞাপন পড ম্যানিফেস্ট এবং আপনার VTP দ্বারা ফিরে আসা যেকোনো সাবটাইটেল সহ 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>

একটি লাইভ বা VOD পড সার্ভিং স্ট্রিম অনুরোধ তৈরি করুন এবং চালান

আপনার কাছে একটি স্ট্রিম প্লেয়ার থাকার পরে, আপনি একটি স্ট্রিম অনুরোধ তৈরি এবং কার্যকর করতে পারেন৷ এই উদাহরণে m.testPodServingStream এ সঞ্চিত একটি পড সার্ভিং স্ট্রিমের ডেটা রয়েছে।

লাইভ স্ট্রিম পড পরিবেশন

m.testPodServingStream অবজেক্টে, একটি নেটওয়ার্ক কোড এবং কাস্টম অ্যাসেট কী-এর মতো প্রশ্নে থাকা স্ট্রীম শনাক্ত করার জন্য Google Ad Manager-এর প্রয়োজনীয় প্যারামিটারগুলি সঞ্চয় করুন৷ এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভার অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন। এই ক্ষেত্রে, স্ট্রিম অনুরোধ ফেরত দেওয়ার পরে ম্যানিফেস্ট URL-এ 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 একটি স্ট্রিম আইডি প্রদান করতে পারে। এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে ব্যবহারকারী নির্দিষ্ট ম্যানিফেস্ট অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন।

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

ইভেন্ট শ্রোতা যোগ করুন এবং স্ট্রীম শুরু করুন

লাইভ স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা SDK-এ ফরোয়ার্ড করা গুরুত্বপূর্ণ। এটি করতে ব্যর্থ হলে বিজ্ঞাপনের দৃশ্যগুলিকে ভুলভাবে রিপোর্ট করা হয়।

এই ধাপে, আপনি স্ট্রিম আইডি দিয়ে [[STREAMID]] ম্যাক্রো প্রতিস্থাপন করার জন্য একটি ফাংশন যোগ করুন এবং ভিডিও প্লেয়ারে সম্পূর্ণ ম্যানিফেস্ট অনুরোধ URL পাস করুন। এই বাস্তবায়ন এই ধাপে স্ট্রিম আইডি পায়, কিন্তু আপনার 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

ভিওডি স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা 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
,

IMA SDKগুলি আপনার ওয়েবসাইট এবং অ্যাপগুলিতে মাল্টিমিডিয়া বিজ্ঞাপনগুলিকে একীভূত করা সহজ করে তোলে৷ IMA SDK যেকোন VAST-সঙ্গী বিজ্ঞাপন সার্ভার থেকে বিজ্ঞাপনের অনুরোধ করতে পারে এবং আপনার অ্যাপে বিজ্ঞাপন প্লেব্যাক পরিচালনা করতে পারে। IMA DAI SDK-এর সাথে, অ্যাপগুলি বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর জন্য একটি স্ট্রিম অনুরোধ করে—হয় VOD বা লাইভ সামগ্রী। SDK তারপরে একটি সম্মিলিত ভিডিও স্ট্রিম ফেরত দেয়, যাতে আপনাকে আপনার অ্যাপের মধ্যে বিজ্ঞাপন এবং বিষয়বস্তু ভিডিওর মধ্যে স্যুইচিং পরিচালনা করতে হবে না।

আপনি আগ্রহী DAI সমাধান নির্বাচন করুন

এই নির্দেশিকাটি দেখায় কিভাবে একটি DAI পড সার্ভিং লাইভ বা VOD স্ট্রিম খেলতে হয়, Roku এর জন্য IMA DAI SDK ব্যবহার করে।

IMA DAI পড সার্ভিং ওভারভিউ

IMA DAI ব্যবহার করে পড পরিবেশন বাস্তবায়নে দুটি প্রধান SDK উপাদান জড়িত, যা এই নির্দেশিকায় প্রদর্শিত হয়েছে:

  • StreamRequest.createPodLiveStreamRequest() / StreamRequest.createPodVodStreamRequest() : এমন একটি বস্তু তৈরি করে যা Google-এর বিজ্ঞাপন সার্ভারে একটি স্ট্রিম অনুরোধ সংজ্ঞায়িত করে। এই অনুরোধগুলি একটি নেটওয়ার্ক কোড নির্দিষ্ট করে, এবং পড লাইভ ima.StreamRequest স্ট্রিমরিকোয়েস্টের জন্য একটি কাস্টম সম্পদ কী এবং একটি ঐচ্ছিক API কী প্রয়োজন।
  • StreamManager : একটি বস্তু যা ভিডিও স্ট্রীম এবং IMA DAI SDK-এর মধ্যে যোগাযোগ পরিচালনা করে, যেমন ফায়ারিং ট্র্যাকিং পিং এবং প্রকাশকের কাছে স্ট্রিম ইভেন্ট ফরওয়ার্ড করা।

এছাড়াও, আপনার অ্যাপটি প্রদর্শনের জন্য স্ট্রিম ম্যানিফেস্ট পুনরুদ্ধার করতে আপনাকে আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে একটি অনুরোধ করতে হবে। সঠিক প্রক্রিয়া ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে VTP-তে পরিবর্তিত হতে পারে।

পূর্বশর্ত

  • আপনার উদ্দেশ্য ব্যবহার কেস সমর্থিত তা নিশ্চিত করতে আমাদের সামঞ্জস্য পৃষ্ঠাটি পড়ুন।
  • আমাদের 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 স্ট্রিম প্লেয়ার তৈরি করুন

এর পরে, একটি IMA স্ট্রিম প্লেয়ার তৈরি করতে আপনাকে আপনার বিদ্যমান roVideoScreen ব্যবহার করতে হবে।

লাইভ স্ট্রিম পড পরিবেশন

লাইভ স্ট্রীমের জন্য, এই স্ট্রিম প্লেয়ার তিনটি কলব্যাক পদ্ধতি প্রয়োগ করে: 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>

ভিওডি স্ট্রিম পড পরিবেশন

VOD স্ট্রিমগুলির জন্য, এই স্ট্রিম প্লেয়ারটি চারটি কলব্যাক পদ্ধতি প্রয়োগ করে: streamInitialized , loadUrl , adBreakStarted , এবং adBreakEndedstreamInitialized কলব্যাকে, StreamManager.loadThirdPartyStream() কল করতে ভুলবেন না। এটি করতে ব্যর্থ হলে SDK loadUrl ফাংশন ট্রিগার করবে না।

এই ধাপে, আপনি loadAdPodStream() এ প্রাপ্ত একটি স্ট্রীম আইডি সহ আপনার ভিডিও প্রযুক্তি অংশীদার (VTP) থেকে একটি স্ট্রিম URL এর জন্য অনুরোধ করবেন৷ তারপর, বিজ্ঞাপন পড ম্যানিফেস্ট এবং আপনার VTP দ্বারা ফিরে আসা যেকোনো সাবটাইটেল সহ 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>

একটি লাইভ বা VOD পড সার্ভিং স্ট্রিম অনুরোধ তৈরি করুন এবং চালান

আপনার কাছে একটি স্ট্রিম প্লেয়ার থাকার পরে, আপনি একটি স্ট্রিম অনুরোধ তৈরি এবং কার্যকর করতে পারেন৷ এই উদাহরণে m.testPodServingStream এ সঞ্চিত একটি পড সার্ভিং স্ট্রিমের ডেটা রয়েছে।

লাইভ স্ট্রিম পড পরিবেশন

m.testPodServingStream অবজেক্টে, একটি নেটওয়ার্ক কোড এবং কাস্টম অ্যাসেট কী-এর মতো প্রশ্নে থাকা স্ট্রীম শনাক্ত করার জন্য Google Ad Manager-এর প্রয়োজনীয় প্যারামিটারগুলি সঞ্চয় করুন৷ এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভার অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন। এই ক্ষেত্রে, স্ট্রিম অনুরোধ ফেরত দেওয়ার পরে ম্যানিফেস্ট URL-এ 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 একটি স্ট্রিম আইডি প্রদান করতে পারে। এছাড়াও আপনার ম্যানিফেস্ট ম্যানিপুলেশন সার্ভারে ব্যবহারকারী নির্দিষ্ট ম্যানিফেস্ট অ্যাক্সেস করতে ব্যবহৃত ম্যানিফেস্ট URL সংরক্ষণ করুন।

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

ইভেন্ট শ্রোতা যোগ করুন এবং স্ট্রীম শুরু করুন

লাইভ স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা SDK-এ ফরোয়ার্ড করা গুরুত্বপূর্ণ। এটি করতে ব্যর্থ হলে বিজ্ঞাপনের দৃশ্যগুলিকে ভুলভাবে রিপোর্ট করা হয়।

এই ধাপে, আপনি স্ট্রিম আইডি দিয়ে [[STREAMID]] ম্যাক্রো প্রতিস্থাপন করার জন্য একটি ফাংশন যোগ করুন এবং ভিডিও প্লেয়ারে সম্পূর্ণ ম্যানিফেস্ট অনুরোধ URL পাস করুন। এই বাস্তবায়ন এই ধাপে স্ট্রিম আইডি পায়, কিন্তু আপনার 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

ভিওডি স্ট্রিম পড পরিবেশন

আপনার স্ট্রীম অনুরোধ করার পরে, শুধুমাত্র কিছু কাজ বাকি আছে: বিজ্ঞাপনের অগ্রগতি ট্র্যাক করতে ইভেন্ট শ্রোতাদের যোগ করুন এবং SDK-এ Roku বার্তা ফরওয়ার্ড করুন। সঠিক বিজ্ঞাপন প্লেব্যাক নিশ্চিত করতে আপনার সমস্ত বার্তা 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