กลับไปที่ช่วงพักโฆษณาที่ข้าม

เลือกแพลตฟอร์ม: HTML5 Android iOS tvOS Roku

ในฐานะผู้เผยแพร่วิดีโอ คุณอาจต้องการป้องกันไม่ให้ผู้ชม ข้ามโฆษณาตอนกลาง เมื่อผู้ใช้เลื่อนแถบเลื่อนเลยช่วงพักโฆษณา คุณสามารถนำผู้ใช้กลับไปยังจุดเริ่มต้นของช่วงพักโฆษณานั้น จากนั้นนำผู้ใช้กลับไปยังตำแหน่งเดิมหลังจากช่วงพักโฆษณาสิ้นสุดลง ฟีเจอร์นี้ เรียกว่า "ย้อนกลับ"

ดูตัวอย่างได้ที่แผนภาพด้านล่าง ผู้ชมกำลังดูวิดีโอ และตัดสินใจที่จะกรอจากช่วง 5 นาทีไปที่ช่วง 15 นาที อย่างไรก็ตาม มีช่วงพักโฆษณาที่เครื่องหมาย 10 นาทีที่คุณต้องการให้ผู้ชมดู ก่อนที่จะดูเนื้อหาหลังจากนั้นได้

หากต้องการแสดงช่วงพักโฆษณานี้ ให้ทำตามขั้นตอนต่อไปนี้

  1. ตรวจสอบว่าผู้ใช้เลื่อนแถบเลื่อนข้ามช่วงพักโฆษณาที่ยังไม่ได้ดูหรือไม่ หากใช่ ให้นำผู้ใช้กลับไปยังช่วงพักโฆษณานั้น
  2. หลังจากช่วงพักโฆษณาสิ้นสุดลง ให้นำผู้ใช้กลับไปยังตำแหน่งเดิมที่ผู้ใช้เลื่อนแถบเลื่อน

ในรูปแบบแผนภาพ จะมีลักษณะดังนี้

วิธีติดตั้งใช้งานเวิร์กโฟลว์นี้ใน IMA DAI SDK มีดังนี้ ซึ่งทำได้เช่นเดียวกับใน AdvancedExample

ป้องกันไม่ให้ผู้ใช้ข้ามช่วงพักโฆษณาโดยไม่ได้ดู

ตรวจสอบว่าผู้ใช้ได้กรอวิดีโอผ่านช่วงพักโฆษณาที่ยังไม่ได้ดูหรือไม่ หากใช่ ให้นำผู้ใช้กลับไปยังช่วงพักโฆษณาดังกล่าว สําหรับตัวอย่างขั้นสูงของ iOS ให้ใช้การโต้ตอบของผู้ใช้กับ UI เพื่อตรวจหาเวลาที่ผู้ใช้กรอวิดีโอ เก็บเวลาเริ่มต้นการกรอเพื่อตรวจสอบ ว่าผู้ใช้ข้ามช่วงพักโฆษณาที่ยังไม่ได้เล่นหรือไม่ เมื่อผู้ใช้ ปล่อยตัวควบคุมวิดีโอ ให้เปรียบเทียบเวลาปัจจุบันกับเวลาของ ช่วงพักโฆษณาล่าสุด หากช่วงพักโฆษณาอยู่หลังเวลาเริ่มต้นการกรอ (หมายความว่าผู้ใช้ข้ามช่วงพักโฆษณานั้นไป) และยังไม่ได้เล่น ให้กรอกลับไปยังจุดเริ่มต้นของช่วงพักโฆษณา นอกจากนี้ ให้ตั้งค่าแฟล็ก Snapback เพื่อตรวจสอบในภายหลังในตัวแฮนเดิลการหยุดโฆษณาที่เสร็จสมบูรณ์

- (IBAction)videoControlsTouchStarted:(id)sender {
  self.seekStartTime = self.contentPlayer.currentTime;
}

- (IBAction)videoControlsTouchEnded:(id)sender {
  self.seekEndTime = CMTimeMake(self.progressBar.value, 1);
  IMACuepoint *lastCuepoint =
      [self.streamManager previousCuepointForStreamTime:CMTimeGetSeconds(self.seekEndTime)];
  if (!lastCuepoint.played && (lastCuepoint.startTime > CMTimeGetSeconds(self.seekStartTime))) {
    self.snapbackMode = YES
    // Add 1 to the seek time to get the keyframe at the start of the ad to be your landing place.
    [self.contentPlayer seekToTime:CMTimeMakeWithSeconds(lastCuepoint.startTime + 1, NSEC_PER_SEC)];
  }
}

นำผู้ใช้กลับไปยังตำแหน่งเดิมที่เลื่อนหา

ในตัวแฮนเดิล ad-break-ended ให้ตรวจสอบว่ามีการเล่นเบรกก่อนหน้าเป็นผลมาจากการย้อนกลับหรือไม่ หากเป็นเช่นนั้น ให้นำผู้ใช้กลับไปยังตำแหน่งที่ผู้ใช้พยายามเลื่อนแถบเลื่อนไปในตอนแรก (ตราบใดที่ตำแหน่งนั้นไม่ใช่ช่วงพักโฆษณาที่เพิ่งเล่นจบไป)

- (void)streamManager:(IMAStreamManager *)streamManager didReceiveAdEvent:(IMAAdEvent *)event {
  switch (event.type) {
    case kIMAAdEvent_AD_BREAK_ENDED: {
      if (self.snapbackMode) {
        self.snapbackMode = NO;
        if (CMTimeCompare(self.seekEndTime, self.contentPlayer.currentTime)) {
          [self.contentPlayer seekToTime:self.seekEndTime];
        }
      }
      break;
    }
  }
}