基于Vue.js2.6结合h5来实现视频播放画中画技术(Picture-in-Picture)

原文转载自「刘悦的技术博客」https://v3u.cn/a_id_125

在开发基于vue.js的在线视频教育平台的时候,我们会注意一个小问题,就是如果用户在观看播放视频的同时,也会往下拖动窗口浏览一些评论,这样视频就会被滚动条覆盖,导致用户无法在浏览评论的同时观看视频,同理,如果想边刷微博边追剧怎么办?想边聊微信边看球赛怎么办?

目前我们可以用h5的技术来解决这个问题,支持HTML5

先看效果:

image

可以看到,当触发了画中画特效,网站右下角就会出现一个小型的视频播放器,它能够浮动跟踪于窗口,这样就能在浏览信息的同时也可以观看视频。

画中画看上去很酷炫,实际上,实现非常简单。

// 进入画中画
video.requestPictureInPicture();
// 退出画中画
document.exitPictureInPicture();

为了方便用户进入和退出画中画模式,我们可以加一个按钮逻辑

//画中画
into:function(){

if (video !== document.pictureInPictureElement) {
// 尝试进入画中画模式
video.requestPictureInPicture();    
this.mymsg = '退出画中画';  
} else {
// 退出画中画
document.exitPictureInPicture();
this.mymsg = '进入画中画';
}

}

需要注意一点,使用画中画需要为视频空间添加一个选择器id="video",这虽然违背vue的数据双向绑定理念,但是目前控制方法只能如此


image

虽然简单,但是有效,做产品就得注意细节,就算是研发岗位也得有产品思想,否则就会被时代淘汰,最后奉上代码仓库项目地址:https://gitee.com/QiHanXiBei/myvue

原文转载自「刘悦的技术博客」 https://v3u.cn/a_id_125

你可能感兴趣的:(基于Vue.js2.6结合h5来实现视频播放画中画技术(Picture-in-Picture))