ตั้งแต่เดือนเมษายน 2017 เป็นต้นไป Chrome สำหรับ Android O รองรับโหมดภาพในภาพ
ซึ่งช่วยให้ผู้ใช้เล่นองค์ประกอบ <video>
ในหน้าต่างวางซ้อนขนาดเล็กที่ไม่ถูกบล็อกโดยหน้าต่างอื่นๆ เพื่อให้ผู้ใช้ดูวิดีโอขณะทำอย่างอื่นไปด้วยได้
วิธีการใช้งานคือเปิด Chrome แล้วไปที่เว็บไซต์ที่มีวิดีโอ แล้วเล่นวิดีโอแบบเต็มหน้าจอ จากนั้นกดปุ่มหน้าแรกเพื่อไปที่หน้าจอหลักของ Android แล้ววิดีโอที่เล่นอยู่จะเปลี่ยนเป็นโหมดภาพในภาพโดยอัตโนมัติ เท่านี้เอง เจ๋งไปเลยใช่ไหม
ใช่ แต่เดสก์ท็อปล่ะ จะเกิดอะไรขึ้นหากเว็บไซต์ต้องการควบคุมประสบการณ์นั้น
ข่าวดีคือเรากําลังร่างข้อกําหนดของ Picture-in-Picture Web API ข้อกำหนดนี้มีจุดประสงค์เพื่อให้เว็บไซต์เริ่มและควบคุมลักษณะการทำงานนี้โดยการเปิดเผยชุดพร็อพเพอร์ตี้ต่อไปนี้ต่อ API
- แจ้งเว็บไซต์เมื่อวิดีโอเข้าสู่และออกจากโหมดภาพซ้อนภาพ
- อนุญาตให้เว็บไซต์เรียกใช้ฟีเจอร์ภาพซ้อนภาพในองค์ประกอบวิดีโอผ่านการโต้ตอบของผู้ใช้
- อนุญาตให้เว็บไซต์ออกจากโหมดภาพซ้อนภาพ
- อนุญาตให้เว็บไซต์ตรวจสอบว่าสามารถเรียกใช้ฟีเจอร์ภาพซ้อนภาพได้หรือไม่
ซึ่งอาจมีลักษณะดังนี้
<video id="video" src="https://example.com/file.mp4"></video>
<button id="pipButton"></button>
<script>
// Hide button if Picture-in-Picture is not supported.
pipButton.hidden = !document.pictureInPictureEnabled;
pipButton.addEventListener('click', function() {
// If there is no element in Picture-in-Picture yet, let's request Picture
// In Picture for the video, otherwise leave it.
if (!document.pictureInPictureElement) {
video.requestPictureInPicture()
.catch(error => {
// Video failed to enter Picture-in-Picture mode.
});
} else {
document.exitPictureInPicture()
.catch(error => {
// Video failed to leave Picture-in-Picture mode.
});
}
});
</script>
ความคิดเห็น
คุณคิดเห็นอย่างไร โปรดส่งความคิดเห็นและแจ้งปัญหาในที่เก็บ WICG ของภาพในภาพ เรายินดีอย่างยิ่งที่จะรับฟังความคิดเห็นจากคุณ
การป้องกันลักษณะการทำงานเริ่มต้นของ PIP ใน Android
ปัจจุบันคุณสามารถป้องกันไม่ให้วิดีโอใช้ลักษณะการทำงาน PIP เริ่มต้นของ Android ใน Chrome ได้โดยตอบสนองต่อเหตุการณ์การปรับขนาด และตรวจหาเมื่อขนาดหน้าต่างมีการเปลี่ยนแปลงอย่างมาก (ดูโค้ดด้านล่าง) เราไม่แนะนำให้ใช้วิธีนี้เป็นการแก้ปัญหาถาวร แต่ให้ใช้เป็นตัวเลือกชั่วคราวจนกว่าจะมีการใช้ Web API
// See whether resize is small enough to be PiP. It's a hack, but it'll
// work for now.
window.addEventListener('resize', function() {
if (!document.fullscreenElement) {
return;
}
var minimumScreenSize = 0.33;
var screenArea = screen.width * screen.height;
var windowArea = window.outerHeight * window.outerWidth;
// If the size of the window relative to the screen is less than a third,
// let's assume we're in PiP and exit fullscreen to prevent Auto PiP.
if ((windowArea / screenArea) < minimumScreenSize) {
document.exitFullscreen();
}
});