适用于手Q和微信小程序的播放器插件,开箱即用无需配置。仅支持播放腾讯视频已上架的资源。
v2.1.0
- multi-slot支持:现在播放器内分为
ui-bottom-left-ctrl-btn
,ui-bottom-right-ctrl-btn
,ui-top-right-ctrl-btn
,default
四个slot,其中default
与原默认slot位置相同。另外三个对应左下角播控按键的右侧,右下清晰度等选项左侧,以及右上角三处。展示时机同控制栏,左下右下仅全屏时显示。 - 移除微信默认UI支持
- 播放结束的情况下,再次点击播放按钮现在会自动重播
- 增加微信原生video同名事件的映射
- multi-slot支持:现在播放器内分为
有关插件的使用请参考微信官方文档。
如果你希望在小程序中使用腾讯视频的播放器插件,请先在插件商店中找到并申请。
申请通过后,可以这样引入播放器组件和js接口。
// app.json
{
"plugins": {
"player": {
"version": "2.0.0",
"provider": "wxa75efa648b60994b"
}
},
}
// page index.json
{
//...你的其他页面配置
"usingComponents": {
"player-component": "plugin://player/video",
}
}
<!-- index.wxml -->
<view>
<player-component vid="{{你想要播放的vid}}">
<view slot="bottom-left-ctrl-btn" bind:tap="callback">左下角的自定义按钮</view>
<view slot="top-right-ctrl-btn" bind:tap="callback">右上角的自定义按钮</view>
<view slot="bottom-right-ctrl-btn" bind:tap="callback">右下角的自定义按钮</view>
<view slot="default" bind:tap="callback">默认slot</view>
</player-component>
</view>
// index.js
const store = requirePlugin('player')
完整api和类型声明请参考typedoc
下面是一些你经常会用到的api。
const store = requirePlugin('player')
// index.wxml 中 <player-component id="tvp-id" playerid="tvp">
const player = store.get('tvp');
// 或
const player = this.selectComponent('#tvp-id');
这两个方法获取到的实例是相同的
store.openLog();
store.closeLog();
const player = store.get('player')
player.play() // 调用小程序videoContext.play()
player.play('想播放的vid') // 播放指定vid
player.play('想播放的vid', { startTime: 5 }) // 指定起播的时间
const player = store.get('player')
player.pause(); // 暂停,同videoContext.pause()
player.stop(); // 停止,同videoContext.stop()
player.seek(5); // 跳转,同videoContext.seek()
stop()
方法会事实上停止播放流程并清空播放列表,调用后无法使用play()
接口重新开播。如果希望重新播放请调用replay()
接口
const player = store.get('player')
player.replay();
const player = store.get('player')
player.setLevel('fhd')
player.setLevel('fhd').catch(error => {
// error处理
})
如果切换失败的话可以通过catch捕获异常,播放器会自动续播当前内容。
'play',
'pause',
'ended',
'timeupdate',
'waiting',
'error',
'progress',
'loadedmetadata',
'controlstoggle',
'seekcomplete',
'fullscreenchange',
/**
* 指定视频初始播放位置
*/
initialTime: {
type: NumberConstructor,
value: number, // 0
}
/**
* 是否使用ui,这里是设置总体UI开关。
*/
controls: {
type: BooleanConstructor,
value: boolean, // true
},
/**
* 是否静音播放
*/
muted: {
type: BooleanConstructor,
value: boolean, // false
},
/**
* 设置全屏时视频的方向,不指定则根据宽高比自动判断
*/
direction: {
type: NumberConstructor,
value: number, // -1
},
/**
* 屏幕锁
*/
showScreenLockButton: {
type: BooleanConstructor,
value: boolean, // false
}
/**
* 当视频大小与 video 容器大小不一致时,视频的表现形式
*/
objectFit: {
type: StringConstructor,
value: string, // 'contain'
},
/**
* 是否开启播放手势,即双击切换播放/暂停
*/
enablePlayGesture: {
type: BooleanConstructor,
value: boolean, // false
},
/**
* 当跳转到本小程序的其他页面时,是否自动暂停本页面的视频播放
*/
autoPauseIfNavigate: {
type: BooleanConstructor,
value: boolean, // true
},
/**
* 当跳转到其它微信原生页面时,是否自动暂停本页面的视频
*/
autoPauseIfOpenNative: {
type: BooleanConstructor,
value: boolean, // true
},
/**
* 是否开启手机横屏时自动全屏,当系统设置开启自动旋转时生效
*/
enableAutoRotation: {
type: BooleanConstructor,
value: boolean, // false
},
/**
* 是否开启投屏
*/
showCastingButton: {
type: BooleanConstructor,
value: boolean, // false
},
/**
* 非全屏模式下音量/亮度手势
*/
vslideGesture: {
type: BooleanConstructor,
value: boolean, // false
},
/** 全屏下模式下音量/亮度手势 */
vslideGestureInFullscreen: {
type: BooleanConstructor,
value: boolean, // true
},
/**
* 是否使用进度条手势
*/
enableProgressGesture: {
type: BooleanConstructor,
value: boolean, // true
},
/**
* 是否自动播放
*/
autoplay: {
type: BooleanConstructor,
value: boolean, // true
},
/** 是否显示进度条 */
showProgress: {
type: BooleanConstructor,
value: boolean, // true
},
- 组件层级(z-index)
- 正在播放的video标签
z-index: 1
- 用于预加载的后台video标签
z-index: 0
- 唤起控制栏/手势操作的捕获层
z-index: 3
- 错误页
z-index: 10
- 左上角返回按钮
z-index: 2
- 上方toast区域
z-index: 1
- 正在播放的video标签