微信小程序API 視頻·VideoContext

2022-05-11 16:23 更新

VideoContext

VideoContext 實(shí)例,可通過(guò) wx.createVideoContext 獲取。

VideoContext 通過(guò) id 跟一個(gè) video 組件綁定,操作對(duì)應(yīng)的 video 組件。

方法:

VideoContext.exitFullScreen()

基礎(chǔ)庫(kù) 1.4.0 開(kāi)始支持,低版本需做兼容處理。

退出全屏

VideoContext.exitPictureInPicture(Object object)

退出小窗,該方法可在任意頁(yè)面調(diào)用

參數(shù)

Object object

屬性 類(lèi)型 默認(rèn)值 必填 說(shuō)明
success function 接口調(diào)用成功的回調(diào)函數(shù)
fail function 接口調(diào)用失敗的回調(diào)函數(shù)
complete function 接口調(diào)用結(jié)束的回調(diào)函數(shù)(調(diào)用成功、失敗都會(huì)執(zhí)行)

VideoContext.hideStatusBar()

基礎(chǔ)庫(kù) 2.1.0 開(kāi)始支持,低版本需做兼容處理。

隱藏狀態(tài)欄,僅在iOS全屏下有效

VideoContext.pause()

暫停視頻

VideoContext.play()

播放視頻

VideoContext.playbackRate(number rate)

基礎(chǔ)庫(kù) 1.4.0 開(kāi)始支持,低版本需做兼容處理。

設(shè)置倍速播放

參數(shù)

number rate

倍率,支持 0.5/0.8/1.0/1.25/1.5,2.6.3 起支持 2.0 倍速

VideoContext.requestFullScreen(Object object)

基礎(chǔ)庫(kù) 1.4.0 開(kāi)始支持,低版本需做兼容處理。

進(jìn)入全屏。若有自定義內(nèi)容需在全屏?xí)r展示,需將內(nèi)容節(jié)點(diǎn)放置到 video 節(jié)點(diǎn)內(nèi)。

參數(shù)

Object object

屬性 類(lèi)型 默認(rèn)值 必填 說(shuō)明 最低版本
direction number 設(shè)置全屏?xí)r視頻的方向,不指定則根據(jù)寬高比自動(dòng)判斷。 1.7.0

object.direction 的合法值

說(shuō)明 最低版本
0 正常豎向
90 屏幕逆時(shí)針90度
-90 屏幕順時(shí)針90度

VideoContext.seek(number position)

跳轉(zhuǎn)到指定位置

參數(shù)

number position

跳轉(zhuǎn)到的位置,單位 s

VideoContext.sendDanmu(Object data)

發(fā)送彈幕

參數(shù)

Object data

彈幕內(nèi)容

屬性 類(lèi)型 默認(rèn)值 必填 說(shuō)明
text string 彈幕文字
color string 彈幕顏色

VideoContext.showStatusBar()

基礎(chǔ)庫(kù) 2.1.0 開(kāi)始支持,低版本需做兼容處理。

顯示狀態(tài)欄,僅在iOS全屏下有效

VideoContext.stop()

基礎(chǔ)庫(kù) 1.7.0 開(kāi)始支持,低版本需做兼容處理。

停止視頻

示例代碼

在開(kāi)發(fā)者工具中預(yù)覽效果

<view class="section tc">
  <video id="myVideo" src="http://wxsnsdy.tc.qq.com/105/20210/snsdyvideodownload?filekey=30280201010421301f0201690402534804102ca905ce620b1241b726bc41dcff44e00204012882540400&bizid=1023&hy=SH&fileparam=302c020101042530230204136ffd93020457e3c4ff02024ef202031e8d7f02030f42400204045a320a0201000400" rel="external nofollow"  enable-danmu danmu-btn controls></video>
  <view class="btn-area">
    <input bindblur="bindInputBlur"/>
    <button bindtap="bindSendDanmu">發(fā)送彈幕</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()
    })
  }
})


以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)