• 技术文章 >微信小程序 >小程序开发

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

    不言不言2018-06-27 09:54:50原创2672
    这篇文章主要介绍了微信小程序 vidao实现视频播放和弹幕的功能的相关资料,这里提供实现代码及实现效果图,需要的朋友可以参考下

    微信小程序 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);
      }
    })

    效果

    以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

    相关推荐:

    微信小程序中input输入及动态设置按钮的实现

    微信小程序中小说阅读小程序的实现

    以上就是微信小程序中vidao实现视频播放和弹幕功能的介绍的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:微信小程序 <swiper-item>标签传入数据 下一篇:微信小程序开发快递查询功能的介绍
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 浅谈小程序确保每个页面都已登陆的方法• 记录一次实践,看看小程序购物车动画怎么优化• 浅析小程序中如何优雅地进行模块化处理?• 深入浅析小程序中的全局配置• 小程序中怎么对网络请求进行二次封装
    1/1

    PHP中文网