微信小程序里 vidao 达成视频播放与弹幕功能的介绍

why 152 2024-08-20

这篇文章主要介绍了微信小程序 vidao实现视频播放和弹幕的功能的相关资料,这里提供实现代码及实现效果图,需要的朋友可以参考下

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

vidao

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

.wxml


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<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


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

function getRandomColor () {

 let rgb = []

 for (let i = 0 ; i < 3; ++i){

  let color = Math.floor(Math.random() * 256).toString(16)

  color = color.length == 1 ? &#39;0&#39; + color : color

  rgb.push(color)

 }

 return &#39;#&#39; + rgb.join(&#39;&#39;)

}

 

Page({

 onReady: function (res) {

  this.videoContext = wx.createVideoContext(&#39;myVideo&#39;)

 },

 inputValue: &#39;&#39;,

  data: {

    src: &#39;&#39;,

  danmuList: [

   {

    text: &#39;第 1s 出现的弹幕&#39;,

    color: &#39;#ff0000&#39;,

    time: 1

   },

   {

    text: &#39;第 3s 出现的弹幕&#39;,

    color: &#39;#ff00ff&#39;,

    time: 3

   }

  ]

  },

 bindInputBlur: function(e) {

  this.inputValue = e.detail.value

 },

  bindButtonTap: function() { //视频-

    var that = this

    wx.chooseVideo({

      sourceType: [&#39;album&#39;, &#39;camera&#39;],

      maxDuration: 60,

      camera: [&#39;front&#39;,&#39;back&#39;],

      success: function(res) {

        that.setData({

          src: res.tempFilePath

        })

      }

    })

  },

 bindSendDanmu: function () {

  this.videoContext.sendDanmu({

   text: this.inputValue,

   color: getRandomColor()

  })

 },

  videoErrorCallback: function(e) {

   console.log(&#39;视频错误信息:&#39;);

   console.log(e.detail.errMsg);

  }

})


效果

 


以上就是本文的全部内容,希望对大家的学习有所帮助。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:国产操作系统,引领技术创新的未来之路
下一篇:微信小程序中swiper-item标签数据的传入方式
相关文章

 发表评论

暂时没有评论,来抢沙发吧~