微信小程序 vidao实现视频播放和弹幕的功能


Posted in Javascript onNovember 02, 2016

 微信小程序 vidao视频播放及弹幕的功能的实现。

vidao

我现在看到的官方文档是不带danmu(弹幕)属性的,之前是有的,不过现在这个属性还可以生效。控制视频的状态可以根据video标签的唯一id得到一个对象实例。video组件并不具备action属性,不能通过action来控制。

.wxml

<view class="section tc">
 <video src="{{src}}"  controls ></video>
 <view class="btn-area">
  <button bindtap="bindButtonTap">获取视频</button>
 </view>
</view>

<!-- 
 danmu-list:弹幕列表
 enable-danmu:是否显示弹幕
 danmu-btn:弹幕按钮
 controls:是否显示视频控件,并没有什么用
 -->
<view class="section tc">
 <video id="myVideo" src="http://wxsnsdy.tc.qq.com/105/20210/snsdyvideodownload?filekey=30280201010421301f0201690402534804102ca905ce620b1241b726bc41dcff44e00204012882540400&bizid=1023&hy=SH&fileparam=302c020101042530230204136ffd93020457e3c4ff02024ef202031e8d7f02030f42400204045a320a0201000400" binderror="videoErrorCallback" danmu-list="{{danmuList}}" enable-danmu danmu-btn controls></video>
 <view class="btn-area">
  <button bindtap="bindButtonTap">获取视频</button>
  <input bindblur="bindInputBlur"/>
  <button bindtap="bindSendDanmu">发送弹幕</button>
 </view>
</view>

<!-- 现在的video就下面三个属性 -->
<video src="" binderror="" hidden></video>

.js

function getRandomColor () {
 let rgb = []
 for (let i = 0 ; i < 3; ++i){
  let color = Math.floor(Math.random() * 256).toString(16)
  color = color.length == 1 ? '0' + color : color
  rgb.push(color)
 }
 return '#' + rgb.join('')
}

Page({
 onReady: function (res) {
  this.videoContext = wx.createVideoContext('myVideo')
 },
 inputValue: '',
  data: {
    src: '',
  danmuList: [
   {
    text: '第 1s 出现的弹幕',
    color: '#ff0000',
    time: 1
   },
   {
    text: '第 3s 出现的弹幕',
    color: '#ff00ff',
    time: 3
   }
  ]
  },
 bindInputBlur: function(e) {
  this.inputValue = e.detail.value
 },
  bindButtonTap: function() { //视频下载
    var that = this
    wx.chooseVideo({
      sourceType: ['album', 'camera'],
      maxDuration: 60,
      camera: ['front','back'],
      success: function(res) {
        that.setData({
          src: res.tempFilePath
        })
      }
    })
  },
 bindSendDanmu: function () {
  this.videoContext.sendDanmu({
   text: this.inputValue,
   color: getRandomColor()
  })
 },
  videoErrorCallback: function(e) {
   console.log('视频错误信息:');
   console.log(e.detail.errMsg);
  }
})

效果

 微信小程序 vidao实现视频播放和弹幕的功能

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
javascript+iframe 实现无刷新载入整页的代码
Mar 17 Javascript
详解JavaScript的变量和数据类型
Nov 27 Javascript
跨域请求的完美解决方法(JSONP, CORS)
Jun 12 Javascript
基于JS快速实现导航下拉菜单动画效果附源码下载
Oct 27 Javascript
jQuery模拟淘宝购物车功能
Feb 27 Javascript
JavaScript原型继承_动力节点Java学院整理
Jun 30 Javascript
Echarts基本用法_动力节点Java学院整理
Aug 11 Javascript
基于Bootstrap框架菜鸟入门教程(推荐)
Sep 17 Javascript
webpack配置之后端渲染详解
Oct 26 Javascript
解决vue-cli脚手架打包后vendor文件过大的问题
Sep 27 Javascript
Node.js系列之连接DB的方法(3)
Aug 30 Javascript
node.js Promise对象的使用方法实例分析
Dec 26 Javascript
bootstrap基础知识学习笔记
Nov 02 #Javascript
AngularJS深入探讨scope,继承结构,事件系统和生命周期
Nov 02 #Javascript
Bootstrap table的使用方法
Nov 02 #Javascript
AngularJS指令用法详解
Nov 02 #Javascript
AngularJS表单和输入验证实例
Nov 02 #Javascript
AngularJS入门教程之数据绑定原理详解
Nov 02 #Javascript
深入理解Node.js 事件循环和回调函数
Nov 02 #Javascript
You might like
PHP以mysqli方式连接类完整代码实例
2014/07/15 PHP
js+php实现静态页面实时调用用户登陆状态的方法
2015/01/04 PHP
PHP数据库连接mysql与mysqli对比分析
2016/01/04 PHP
php获取本机真实IP地址实例代码
2016/03/31 PHP
PHP封装的多文件上传类实例与用法详解
2017/02/07 PHP
Using the TextRange Object
2006/10/14 Javascript
“不能执行已释放的Script代码”错误的原因及解决办法
2007/09/09 Javascript
BOM与DOM的区别分析
2010/10/26 Javascript
再谈JavaScript线程
2015/07/10 Javascript
js实现C#的StringBuilder效果完整实例
2015/12/22 Javascript
JS检测移动端横竖屏的代码
2016/05/30 Javascript
JS产生随机数的几个用法详解
2016/06/22 Javascript
easyui取消表单实时验证,提交时统一验证的简单实例
2016/11/07 Javascript
jQuery树插件zTree使用方法详解
2017/05/02 jQuery
详解nodejs的express如何自动生成项目框架
2017/07/12 NodeJs
nodejs实现简单的gulp打包
2017/12/21 NodeJs
基于$.ajax()方法从服务器获取json数据的几种方式总结
2018/01/31 Javascript
Vuejs开发环境搭建及热更新【推荐】
2018/09/07 Javascript
[00:57]辉夜杯战队访谈宣传片—VG
2015/12/25 DOTA
极简的Python入门指引
2015/04/01 Python
详解Python3中的Sequence type的使用
2015/08/01 Python
ZABBIX3.2使用python脚本实现监控报表的方法
2019/07/02 Python
解决django中ModelForm多表单组合的问题
2019/07/18 Python
Python中list的交、并、差集获取方法示例
2019/08/01 Python
Python配置文件处理的方法教程
2019/08/29 Python
Django中使用haystack+whoosh实现搜索功能
2019/10/08 Python
使用Python实现将多表分批次从数据库导出到Excel
2020/05/15 Python
Python __slots__的使用方法
2020/11/15 Python
简单掌握CSS3中resize属性的用法
2016/04/01 HTML / CSS
哥伦比亚最大的网上商店:Linio哥伦比亚
2016/09/25 全球购物
AVON雅芳官网:世界上最大的美容化妆品公司之一
2016/11/02 全球购物
小学语文教学经验交流材料
2014/06/02 职场文书
“四风”问题整改措施和努力方向
2014/09/20 职场文书
如何理解及使用Python闭包
2021/06/01 Python
Python jiaba库的使用详解
2021/11/23 Python
使用 Apache 反向代理的设置技巧
2022/01/18 Servers