Nodejs中使用puppeteer控制浏览器中视频播放功能


Posted in NodeJs onAugust 26, 2019

本项目主要功能为在浏览器中自动播放视频,并且实现音量控制,快进快退,全屏控制,播放暂停控制等功能。

仓库地址:  github.com/hapiman/chr…

安装静态服务器

如果电脑上存在nodejs的环境,可以直接安装 anywhere 来访问 index.html 页面。 进入项目根目录,执行命令: anywhere ,然后浏览器会自动打开 http://localhost:8000 页面。

使用puppeteer自动化执行命令

通过在 nodejs 调用前端页面的方法,然后能够Socket实现远程控制浏览器的视频播放。

具体功能实现

var _volumeNum = 1 // 音量值
 var _speedNum = 1 // 速度值
 var videoSrc = 'demo02.mp4' // 切换资源
 window.onload = function () {
  var myVideo = document.getElementById('myVideo')
  var scSource = document.getElementById('sc')
  var myVideoBody = { pause: true }
  // 播放完成指令
  myVideo.addEventListener('ended', function () {
   scSource.src = videoSrc;
   myVideo.load()
   myVideo.play()
  })
  // 初始化
  start()
 }
 // 获取video
 function getVideo() {
  var myVideo = document.getElementById('myVideo')
  return myVideo
 }
 // 快进
 function vforward(params) {
  if (_speedNum >= 2) return
  _speedNum = accAdd(_speedNum, 0.1)
  console.log('vforward _speedNum: ', _speedNum)
  getVideo().playbackRate = _speedNum
 }
 // 快退
 function vbackward() {
  if (_speedNum <= 0.5) return
  var myVideo = getVideo()
  _speedNum = accSub(_speedNum, 0.1)
  console.log('vbackward _speedNum: ', _speedNum)
  getVideo().playbackRate = _speedNum
 }
 // 页面加载之后执行命令
 function start() {
  var myVideo = getVideo()
  myVideo.volume = 1
  myVideo.playbackRate = 1
 }
 // 设置静音
 function setMuted() {
  getVideo().muted = true
 }
 // 设置非静音
 function setNotMuted() {
  getVideo().muted = false
 }
 // 播放
 function vplay() {
  console.log('vplay =>')
  getVideo().play();
 }
 // 暂停
 function vstop() {
  getVideo().pause();
 }
 // 重播
 function vrestart() {
  getVideo().currentTime = 0
  getVideo().play()
 }
 // 取消全屏
 function cancelFull() {
  screenfull.exit()
 }
 // 打开全屏
 function openFull() {
  getVideo().webkitRequestFullscreen()
 }
 // 音量 --
 function reduceVolume() {
  console.log('reduceVolume:: current volume: ', myVideo.volume) // 当前音量
  getVideo().muted = false
  if (_volumeNum <= 0) return
  _volumeNum = accSub(_volumeNum, 0.1)
  getVideo().volume = _volumeNum
 }
 // 音量 ++
 function addVolume() {
  console.log('addVolume:: current volume: ', myVideo.volume)  // 当前音量
  getVideo().muted = false
  if (_volumeNum >= 1) return
  _volumeNum = accAdd(_volumeNum, 0.1)
  getVideo().volume = _volumeNum
 }

遇到的问题

关于人工触发

打开网页的时候,autoplay可以自动播放,但是是静音模式,从76版本开始,chrome浏览器安全机制不再允许有声自动播放视频。

同样的,处于安全考虑,浏览器也不能够在没有用户操作的情况,通过接口设置为全屏。

当前项目引入 puppeteer 目的就是为了模拟人工触发页面的情况。

总结

以上所述是小编给大家介绍的Nodejs中使用puppeteer控制浏览器中视频播放功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

NodeJs 相关文章推荐
nodejs 实现模拟form表单上传文件
Jul 14 NodeJs
nodejs npm package.json中文文档
Sep 04 NodeJs
实例分析nodejs模块xml2js解析xml过程中遇到的坑
Mar 18 NodeJs
nodeJS(express4.x)+vue(vue-cli)构建前后端分离实例(带跨域)
Jul 05 NodeJs
NodeJS收发GET和POST请求的示例代码
Aug 25 NodeJs
用nodejs实现json和jsonp服务的方法
Aug 25 NodeJs
nodejs 图解express+supervisor+ejs的用法(推荐)
Sep 08 NodeJs
nodejs之koa2请求示例(GET,POST)
Aug 07 NodeJs
nodejs微信开发之授权登录+获取用户信息
Mar 17 NodeJs
Nodejs中使用puppeteer控制浏览器中视频播放功能
Aug 26 NodeJs
图解NodeJS实现登录注册功能
Sep 16 NodeJs
浅谈使用nodejs搭建web服务器的过程
Jul 20 NodeJs
nodejs简单抓包工具使用详解
Aug 23 #NodeJs
nodejs使用node-xlsx生成excel的方法示例
Aug 22 #NodeJs
Nodejs libuv运行原理详解
Aug 21 #NodeJs
nodejs和react实现即时通讯简易聊天室功能
Aug 21 #NodeJs
Nodejs 识别图片类型的方法
Aug 15 #NodeJs
NodeJs实现简易WEB上传下载服务器
Aug 10 #NodeJs
NodeJs 实现简单WebSocket即时通讯的示例代码
Aug 05 #NodeJs
You might like
PHP 实用代码收集
2010/01/22 PHP
php多用户读写文件冲突的解决办法
2013/11/06 PHP
php提交post数组参数实例分析
2015/12/17 PHP
js资料prototype 属性
2007/03/13 Javascript
JavaScript 变量作用域分析
2011/07/04 Javascript
非常好用的JsonToString 方法 简单实例
2013/07/18 Javascript
JS教程:window.location使用方法的区别介绍
2013/10/04 Javascript
Javascript图片上传前的本地预览实例
2014/06/16 Javascript
JavaScript中匿名、命名函数的性能测试
2014/09/04 Javascript
JavaScript中的setUTCDate()方法使用详解
2015/06/11 Javascript
JavaScript实现的类字典插入或更新方法实例
2015/07/10 Javascript
学习JavaScript设计模式(链式调用)
2015/11/26 Javascript
基于d3.js实现实时刷新的折线图
2016/08/03 Javascript
BootStrap的table表头固定tbody滚动的实例代码
2016/08/24 Javascript
jquery操作checkbox火狐下第二次无法勾选的解决方法
2016/10/10 Javascript
基于JavaScript实现自定义滚动条
2017/01/25 Javascript
vue.js学习之vue-cli定制脚手架详解
2017/07/02 Javascript
动态统计当前输入内容的字节、字符数的实例详解
2017/10/27 Javascript
vue draggable resizable 实现可拖拽缩放的组件功能
2019/07/15 Javascript
闭包在python中的应用之translate和maketrans用法详解
2014/08/27 Python
Python中用max()方法求最大值的介绍
2015/05/15 Python
简单理解Python中的装饰器
2015/07/31 Python
python解决方案:WindowsError: [Error 2]
2016/08/28 Python
python 实现自动远程登陆scp文件实例代码
2017/03/13 Python
Python 窗体(tkinter)按钮 位置实例
2019/06/13 Python
简单介绍python封装的基本知识
2019/08/10 Python
基于h5py的使用及数据封装代码
2019/12/26 Python
泰国汽车、火车和轮渡票预订网站:Bus Online Ticket
2017/09/09 全球购物
日语专业毕业生自荐信
2013/11/11 职场文书
机械制造毕业生求职信
2014/03/03 职场文书
四风对照检查材料思想汇报
2014/09/20 职场文书
业务员辞职信范文
2015/03/02 职场文书
2015年检验员工作总结范文
2015/04/30 职场文书
2015年小学英语教师工作总结
2015/05/12 职场文书
有关水浒传的读书笔记
2015/06/25 职场文书
浅谈Redis的keys命令到底有多慢
2021/10/05 Redis