// 使用插件前,使用者要在 app.json 中声明需要使用的插件
"plugins": {
"polyv-live-player": {
"version": "0.11.0",
"provider": "wxfb2e591959a8bacf"
}
}
// 使用插件提供的自定义组件。在 json 文件定义需要引入的自定义组件时,使用 plugin:// 协议指明插件的引用名和自定义组件名
"usingComponents": {
"polyv-live-player": "plugin://polyv-live-player/live-player"
}
<!--
videoOption 为视频配置
controls 为控制栏配置
appSettings 为鉴权配置
配置字段见 API 说明
-->
<polyv-live-player
id="polyvPlayer"
videoOption="{{videoOption}}"
controls="{{controls}}"
appSetting="{{appSetting}}"
>
</polyv-live-player>
videoOption: {
uid: '',
cid: '',
// 自动切换直播/暂存
isAutoChange: true,
// 画中画,同微信小程序video的 picture-in-picture-mode
pipMode: [],
// statistics 设置自定义统计参数
statistics: {
param1: 'param1',
param2: 'param2',
param4: 'param4',
param5: 'param5'
},
// 自动播放,默认true
autoplay: true,
// 回放视频循环播放,默认false
vodLoop: true,
// 回放指定视频初始播放位置, 单位秒
vodInitialTime: 20
},
// app参数设置
appSetting: {
// polyv后台appId
apiId: appId,
// 加密sign, 需要channelId, appId, timestamp 3个参数按照加密规则生成参数
sign,
// 时间戳
timestamp,
},
/**
* controls: Array | null | string
* 方式1: Array: ["play", "progress", "fullscreen", "refresh", "setting"]
* play:播放/暂停按钮
* progress:进度条
* fullscreen:全屏按钮
* refresh:刷新按钮(仅直播支持
* setting: 设置按钮 (回放 + 直播)
*
* 方式2: controls: null 不显示控制栏
*
* 方式3:controls: 'default' 显示默认的控制栏
**/
controls: ["play", "progress", "fullscreen", "refresh", "setting"]
// 假设插件的组件id为polyvPlayer
const polyvVideoContext = this.selectComponent('#polyvPlayer');
<polyv-live-player
id="polyvPlayer"
videoOption="{{videoOption}}"
appSetting="{{appSetting}}"
bind:onChannelDetailReq="onChannelDetailReq"
bind:onLiveStatusChange="onLiveStatusChange"
bind:onLiveTypeChange="onLiveTypeChange"
>
</polyv-live-player>
onLiveTypeChange(e) {
// e.detail 即为状态的字符串表示(见 getLiveType 的返回值说明)
console.log('liveType:', e.detail);
}
onLiveStorageProgress(e) {
// e.detail.currentTime 为当前视频的播放进度
console.log('onLiveStorageProgress', e.detail.currentTime);
}
onLiveVodWaiting() {
console.log('onLiveVodWaiting');
},
onLiveVodEnd() {
console.log('onLiveVodEnd');
},
onChannelDetailReq(e) {
// e.detail 为频道详情数据
console.log('onChannelDetailReq', e.detail);
},
onLiveStatusChange(e) {
// status 为当前直播状态的字符串表示,有 'live' 和 'end' 两个取值
// sessionId 为直播场次
console.log('onLiveStatusChange', e.detail.status, e.detail.sessionId)
}