# VideoContext

VideoContext 实例,可通过 wx.createVideoContext 获取。

VideoContext 通过 id 跟一个 video 组件绑定,操作对应的 video 组件。

# 方法

# VideoContext.play()

播放视频

# VideoContext.pause()

暂停视频

# VideoContext.stop()

停止视频

# VideoContext.seek(number position)

跳转到指定位置

# VideoContext.sendDanmu(Object data)

发送弹幕

# VideoContext.playbackRate(number rate)

设置倍速播放

# VideoContext.requestFullScreen(Object object)

进入全屏。若有自定义内容需在全屏时展示,需将内容节点放置到 video 节点内。

# VideoContext.exitFullScreen()

退出全屏

# VideoContext.showStatusBar()

显示状态栏,仅在 iOS 全屏下有效

# VideoContext.hideStatusBar()

隐藏状态栏,仅在 iOS 全屏下有效

# VideoContext.exitPictureInPicture()

退出小窗,该方法可在任意页面调用

# VideoContext.requestBackgroundPlayback()

进入后台音频播放模式。

# VideoContext.exitBackgroundPlayback()

退出后台音频播放模式。

# 示例代码

在开发者工具中预览效果

<view class="section tc">
  <video id="myVideo" src="http://wxsnsdy.tc.qq.com/105/20210/snsdyvideodownload?filekey=30280201010421301f0201690402534804102ca905ce620b1241b726bc41dcff44e00204012882540400&bizid=1023&hy=SH&fileparam=302c020101042530230204136ffd93020457e3c4ff02024ef202031e8d7f02030f42400204045a320a0201000400" enable-danmu danmu-btn controls></video>
  <view class="btn-area">
    <input bindblur="bindInputBlur"/>
    <button bindtap="bindSendDanmu">发送弹幕</button>
  </view>
</view>
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 (res) {
    this.videoContext = wx.createVideoContext('myVideo')
  },
  inputValue: '',
  bindInputBlur (e) {
    this.inputValue = e.detail.value
  },
  bindSendDanmu () {
    this.videoContext.sendDanmu({
      text: this.inputValue,
      color: getRandomColor()
    })
  }
})