这是腾讯视频小程序播放插件。 打广告:腾讯视

ThumbPlayer-Miniprogram 腾讯视频小程序播放器SDK

适用于手Q和微信小程序的播放器插件,开箱即用无需配置。仅支持播放腾讯视频已上架的资源

旧版本文档

1.x版本文档

Changelog 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同名事件的映射 使用

有关插件的使用请参考微信官方文档。

如果你希望在小程序中使用腾讯视频的播放器插件,请先在插件商店中找到并申请。

申请通过后,可以这样引入播放器组件和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文档

完整api和类型声明请参考typedoc

常用api

下面是一些你经常会用到的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(); player 播放

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捕获异常,播放器会自动续播当前内容。

播放器支持的video标签事件

'play', 'pause', 'ended', 'timeupdate', 'waiting', 'error', 'progress', 'loadedmetadata', 'controlstoggle', 'seekcomplete', 'fullscreenchange', 播放器支持的video标签属性

/** * 指定视频初始播放位置 */ 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

版权声明:

1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。
2、网站不提供资料下载,如需下载请到原作者页面进行下载。