Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
veplayer-mp-douyin
Advanced tools
小程序播放器抖音原生版本
在小程序后台-开发-开发设置-服务器域名中添加以下域名配置:
日志上报域名:https://mcs.zijieapi.com
播放请求域名(仅vid+playAuthToken播放时需要):https://vod.volcengineapi.com
操作截图如下所示。
视频资源的 CDN 域名不需要添加到域名配置中。 视频资源的CDN域名不需要添加到域名配置中
# npm
npm i veplayer-mp-douyin
npm i veplayer-mp-logger
# yarn
yarn add veplayer-mp-douyin
yarn add veplayer-mp-logger
请优先了解抖音开放平台官网对于 npm 功能 的介绍。
导入项目后,在开发工具编辑器左侧功能栏中,NPM功能:依赖管理中添加 npm 包。
详情请参考抖音小程序自定义组件的使用方式。
{
"usingComponents": {
"veplayer": "ext://veplayer-mp-douyin/veplayer" // 抖音开发者工具4.1.0 之前的版本需要引用手动拷贝到 components 的包即 "/components/veplayer-mp-douyin/dist/index"
}
}
正确使用npm功能需要更新抖音开发者工具到4.1.0以上版本。
setCollector
方法的第二项参数中的 userId
是用来统计用户相关的播放数据。推荐使用应用关联的用户 ID,方便后续发生错误时进行单点排查。
import { CollectorManager } from 'veplayer-mp-douyin/tool/index'
import Collector from 'veplayer-mp-logger'
CollectorManager.setCollector(Collector, {
appId: 111111, // 火山引擎上业务自己的 AppID
userId: '7231102214076007992' // 用户 ID,没有可以不传入,日志 SDK自动生成
})
如果在不使用播放器 SDK的情况下,也能够进行播放日志上报,请参考 veplayer-mp-logger。 如果在不使用播放器SDK的情况下能够进行播放日志上报,请参考veplayer-mp-logger
按照播放方式的不同,分为 url 方式播放和vid 方式播放:
<view>
<!-- 以下是对小程序播放器组件的引用 -->
<veplayer
id="videoContainer"
showPlayBtn
autoplay
src="http://xxxx.mp4"
bindplay="onPlay"
logInfo="{{logInfo}}"
></veplayer>
</view>
<view>
<!-- 以下是对一个播放器组件的引用 -->
<veplayer
id="videoContainer"
showPlayBtn
autoplay
playDomain='https://vod.volcengineapi.com'
playAuthToken='*****************'
bindplay="onPlay"
logInfo="{{logInfo}}"
></veplayer>
</view>
playDomain
是调用火山引擎视频点播OpenAPI的接口地址,业务方如果做了该接口的代理,可以替换成业务方的地址。使用正式appid调试时需要将该地址配置在小程序服务器域名配置白名单中。playAuthToken
是获取视频播放信息(包括播放地址,传入此项时不需要传入src)的临时凭证,由业务方服务端通过调用火山服务端SDK本地生成,具体生成参考火山引擎视频点播文档
对应业务组件中添加日志上报需要的视频信息配置:
// index.js
Component({
data: {
src: 'https://xxxx.mp4',
...,
logInfo: {
vtype: 'MP4', // [可选]播放类型, 默认为'MP4', 'HLS' || 'MP4'
codecType: 'h264', // [可选]视频编码类型,默认h264, 'h264' || 'h265'
sourceType: 'url', // [可选]播放资源类型,默认'vid', 'vid' || 'url'
bitrate: 1334556, // [可选]视频码率, 默认为0
vid: '1', // [可选]sourceType为vid的时候视频vid
tag: 'myTag', // [可选]播放场景
subtag: 'subtag', // [可选]二级播放场景
logger: true, // [可选] 是否开启log打印,默认false, 开发环境可设置为true
}
}
})
视频信息配置完成后,登录视频点播控制台,选择左侧导航栏质量平台 > 播放看板,进入播放看板页面,选择大盘速览页签,在查询条件中选择在小程序点播 SDK 中配置的各项指标。详细操作说明请见查看大盘速览。
小程序播放器对video原生组件进行了封装,因此支持大部分的video属性配置。以下说明列出了新增属性及差异化属性,列出的部分中以 show-
开头的开关即影响原生组件又影响自定义UI,不在列表中的只影响原生组件:
Property | Type | Default | Required | Description |
---|---|---|---|---|
mode | 'portrait' | 'landscape' | 'landscape' | No | 播放器支持竖屏(portrait)及横屏(landscape)两种播放UI模式。横屏模式偏向于普通的PC视频播放器UI,竖屏视频展示类似抖音等短视频播放模式。 |
src | string | No | ||
componentId | string | NO | video组件的id,用于通过createVideoContext 获取视频VideoContext,不传入则会随机生成一个id,此时视频VideoContext仅能通过组件上下文的getContext 方法获取 | |
controls | 'custom' | 'native'|'false' | 'custom' | No | custom: 自定义UI,native: 原生组件UI,false: 完全关闭播放UI控件(包括自定义UI及原生组件UI),播放UI控件指loading状态、播控按钮、进度条、时间显示等 |
tagType | string | 'video' | No | video组件渲染使用的标签类型,需要使用短剧行业能力时请指定为'video-player' |
albumId | string | No | 原片id,仅tagType 为video-player 且小程序启用了行业能力时生效 | |
episodeId | string | No | 剧集id,仅tagType 为video-player 且小程序启用了行业能力时生效 | |
showFullscreenBtn | boolean | No | 当开始/继续播放时触发play事件 | |
duration | number | No | 根据官方文档说明,duration属性只是控制显示的时长,不会控制实际播放的时长。因此该属性不设置给原始video组件,只提供给自定义UI使用 | |
playDomain | string | No | 调用火山引擎视频点播OpenAPI的接口地址,业务方如果做了该接口的代理,可以替换成业务方的地址 | |
playAuthToken | string | No | 获取视频播放信息(包括播放地址,传入此项时不需要传入src)的临时凭证,由业务方服务端通过调用火山服务端SDK本地生成,具体生成方法参考火山引擎视频点播文档 | |
needLoading | boolean | true | No | 是否显示loading,扩展属性,controls=custom的时候生效,v0.1.12之后的版本生效 |
bindplay | eventhandle | No | 当开始/继续播放时触发play事件 | |
bindpause | eventhandle | No | 当暂停播放时触发 pause 事件 | |
bindended | eventhandle | No | 当播放到末尾时触发 ended 事件 | |
bindtimeupdate | eventhandle | No | 播放进度变化时触发,event.detail = {currentTime, duration} 。触发频率 250ms 一次 | |
bindfullscreenchange | eventhandle | No | 视频进入和退出全屏时触发,event.detail = {fullScreen, direction},direction 有效值为 vertical 或 horizontal | |
bindwaiting | eventhandle | No | 视频出现缓冲时触发 | |
binderror | eventhandle | No | 视频播放出错时触发 | |
bindprogress | eventhandle | No | 加载进度变化时触发,只支持一段加载。event.detail = {buffered},百分比 | |
bindloadedmetadata | eventhandle | No | 视频元数据加载完成时触发。event.detail = {width, height, duration} | |
bindplaybackratechange | eventhandle | No | 视频倍速改变完成时触发。返回改变后的倍速值。event.detail={playbackRate}。 | |
bindenterbackground | eventhandle | No | 进入小窗播放时触发 | |
bindclosebackground | eventhandle | No | 关闭小窗播放时触发 | |
bindleavebackground | eventhandle | No | 离开小窗进入 app 事件时触发 | |
bindseeking | eventhandle | No | 组件内部代理劫持VideoContext,VideoContext.seek 调用后会立即发送该事件,该事件非video自带事件,只支持 controls="custom" 时才对外发送 | |
bindseekcomplete | eventhandle | No | seek 完成时触发 (position iOS 单位 s, Android 单位 ms) |
PS. 原生组件支持的属性配置请参考抖音官方文档,注意show-play-btn
这类中划线分割的属性名需要改写成驼峰式命名showPlayBtn
。
原生组件支持的属性配置请参考抖音官方文档,注意
show-play-btn
这类中划线分割的属性名需要改写成驼峰式命名showPlayBtn
。
小程序播放器对VideoContext进行了封装,提供同原生接口一致的API。原生接口更多细节可阅读官网
let player = null
// 异步获取组件内video的VideoContext
const component = this.selectComponent("#videoContainer", (component) => {
player = component.getContext()
// 原生接口
player.play()
player.pause()
player.stop()
player.seek(10)
player.requestFullScreen()
player.exitFullScreen()
player.setWaterMark({ color: "#FFFF11" })
player.setMediaVolume({ value: 1})
player.getMediaVolume(options)
player.playbackRate(1)
player.requestFullScreen({ direction: 90 })
player.exitFullScreen()
});
// 同步获取组件内video的VideoContext,需要保证是在page或者component的ready事件之后才能正常调用
// player = this.selectComponent("#videoContainer").getContext();
// player.play()
// ...
小程序播放器对外支持两种方式的事件订阅形式:
请选择其中一种进行订阅,尽量不要两者混用。这两种方式在组件实例中,被从页面节点树移除(lifetimes->detached)时,进行事件解绑,您无需单独关注事件泄漏的问题。
请参见组件属性中 bind 开头的事件属性。
小程序播放器提供了接口可以获取player context,并可以对player添加事件订阅。具体方式如下:
let player = null
const component = this.selectComponent("#videoContainer", (component) => {
player = component.getContext()
// 事件订阅
player.on('error', (e) => {
console.log('event error:', e)
})
player.on('timeupdate', (e) => {
const { currentTime, duration } = e.detail;
console.log('event error:', currentTime, duration)
})
...
});
详细的事件列表:
EventName | CustomEvent | Description |
---|---|---|
play | No | 参见属性 bindplay 描述 |
pause | No | 参见属性 bindpause 描述 |
ended | No | 参见属性 bindended 描述 |
timeupdate | No | 参见属性 bindtimeupdate 描述 |
fullscreenchange | No | 参见属性 bindfullscreenchange 描述 |
waiting | No | 参见属性 bindwaiting 描述 |
error | No | 参见属性 binderror 描述 |
progress | No | 参见属性 bindprogress 描述 |
loadedmetadata | No | 参见属性 bindloadedmetadata 描述 |
playbackratechange | No | 参见属性 bindplaybackratechange 描述 |
enterbackground | No | 参见属性 bindenterbackground 描述 |
closebackground | No | 参见属性 bindclosebackground 描述 |
leavebackground | No | 参见属性 bindleavebackground 描述 |
seeking | Yes | 参见属性 bindseeking 描述 |
seekcomplete | No | 参见属性 bindseekcomplete 描述 |
getvideoinfo | No | 获取到视频信息,仅tagType 为video-player 且小程序启用了行业能力时触发 |
此播放器组件提供的是原生小程序版本,uni-app项目支持使用小程序自定义组件,可以按照以下步骤在uni-app项目中使用此播放器组件:
# npm
npm i veplayer-mp-douyin
npm i veplayer-mp-logger
# yarn
yarn add veplayer-mp-douyin
yarn add veplayer-mp-logger
HBuilderX创建的项目默认没有
package.json
文件,需要通过初始化命令来创建。npm init -y
拷贝node_modules/veplayer-mp-douyin
到项目小程序组件存放目录ttcomponents
(0.1.14之后的版本会自动拷贝)。HBuilderX 建立的工程 ttcomponents
文件夹在 项目根目录下。vue-cli 建立的工程 ttcomponents
文件夹在 src
目录下。
在页面/组件实例化之前,配置播放器日志的相关配置。
import { CollectorManager } from '@/ttcomponents/veplayer-mp-douyin/dist/tool';
import Collector from 'veplayer-mp-logger';
CollectorManager.setCollector(Collector, {
appId: 11***1, // 视频点播控制台中获取的应用 ID
userId: '7231102***76007992' // 用户 ID,没有可以不传入,SDK 自动生成
});
在 pages.json
对应页面的 style -> usingComponents 引入组件: 可通过uni-app提供的条件编译的方式在不同平台上编译使用不同的SDK,抖音小程序播放器SDK对应veplayer-mp-douyin
如果是在 vue 组件中使用小程序组件时,注意需要在
pages.json
的globalStyle
中配置usingComponents
,而不是页面级配置。
{
"pages": [
{
"path": "pages/index/index",
"style": {
// #ifdef MP-WEIXIN
"usingComponents": {
"veplayer": "/ttcomponents/veplayer-mp-douyin/dist/index"
},
// #endif
// #ifdef MP-TOUTIAO
"usingComponents": {
"veplayer": "/ttcomponents/veplayer-mp-douyin/dist/index"
},
// #endif
"navigationBarTitleText": "uni-app"
}
}
]
}
以vue模板语法示例:
<!-- 页面模板 (index.vue) -->
<template>
<view>
<!-- 在页面中对自定义组件进行引用 -->
<veplayer
id="video"
:src="src"
controls="custom"
@play="onPlay"
@timeupdate="onTimeupdate"
/>
</view>
</template>
<script>
export default {
data() {
return {
src: 'https://xx.cdn.com/demo.mp4'
}
},
methods: {
onPlay(e) {
// TODO something
console.log('play event: ', e);
},
onTimeupdate(e) {
// TODO something
console.log('timeupdate event', e);
},
},
}
</script>
API使用,以暂停为例:
const component = this.selectComponent('#video');
const player = component.getContext();
if (player) {
player.pause();
}
订阅事件:
除了通过@事件名
方式进行监听外,还可以通过组件的videoContext
以事件订阅的方式动态监听。
const component = this.selectComponent('#video');
const player = component.getContext();
if (player) {
player.on('timeupdate', (e) => {
const { currentTime, duration } = e.detail;
console.log('event timeupdate:', currentTime, duration);
});
}
- 如果是从uni-app的video组件迁移到本组件,不作API使用的更改,则组件属性里通过
componentId
传入uni.createVideoContext
需要的组件id,API调用同uni-app组件说明。- 需要注意的是通过
createVideoContext
获取的播放器上下文无法使用事件订阅。
注意数据和事件绑定的差异,组件使用时应按照 vue 的方式进行数据和事件绑定:
详细的小程序转uni-app语法差异可参考文档https://ask.dcloud.net.cn/article/35786。
播放器继承了抖音短剧行业能力,使用方法参照以下说明:
按照官网文档配置行业 SDK 的权限配置。
短剧行业能力依赖video-player
,video-player
只在 抖音23.0以上版本支持,播放器组件会自动使用 tt.canIUse('video-player')
校验当前抖音能否使用。若监测到不支持时,组件会自动降级为video
组件进行播放,此时请确保传入了正确有效的视频地址,或者引导用户升级抖音版本。
使用时请指定tagType
为video-player
,开发者可传入 src
及 definition
,但需要有相关播放权限 ,也可选择传入 albumId
和episodeId
(分别代表原片id和剧集id),由组件通过相关 id 查询平台媒资接口,获取对应视频播放地址。
<veplayer
id="video"
tagType="video-player"
albumId="{{aid}}"
episodeId="{{eid}}"
src="{{degradeSrc}}"
autoplay
bindgetvideoinfo="getVideoInfo"
...
></veplayer>
Component({
// ...
data: {
aid: 'x32432w',
eid: 'xxsddw',
// 抖音23.0以下版本不支持短剧行业能力时使用的兜底地址
degradeSrc: 'https://xx.demo.com/d.mp4'
},
methods: {
getVideoInfo(e){
// do something
},
playVideo(){
// do something
this.player.play()
}
}
})
Taro 项目支持使用原生小程序组件,可以按照以下步骤在Taro项目中使用此播放器组件。
# npm
npm i veplayer-mp-douyin
npm i veplayer-mp-logger
# yarn
yarn add veplayer-mp-douyin
yarn add veplayer-mp-logger
拷贝node_modules/veplayer-mp-douyin
到项目小程序组件存放目录ttcomponents
(0.1.14之后的版本会自动拷贝)。
在页面/组件实例化之前,配置播放器日志的相关配置。
import { CollectorManager } from '@/ttcomponents/veplayer-mp-douyin/dist/tool';
import Collector from 'veplayer-mp-logger';
CollectorManager.setCollector(Collector, {
appId: 11***1, // 视频点播控制台中获取的应用 ID
userId: '7231102***76007992' // 用户 ID,没有可以不传入,SDK 自动生成
});
在使用到播放器组件所在页面的index.config.ts
配置中引入组件:
export default definePageConfig({
navigationBarTitleText: '',
navigationBarTextStyle: 'black',
navigationStyle: 'custom',
disableScroll: true,
usingComponents: {
veplayer: '../../ttcomponents/veplayer-mp-douyin/dist/index',
},
});
注意保证组件路径配置正确
以react语法示例在自定义组件中使用播放器组件:
const VideoPlayer = ({
videoComponentId,
className,
videoPlayUrl,
coverUrl,
controlShow,
onTimeUpdate,
onError,
}) => {
const handleTimeupdate = (e) => {
// 注意原生组件事件的event在taro项目中被劫持包装到了e.mpEvent.detail.e中
const originEvent = e.mpEvent.detail.e;
const { currentTime, duration } = originEvent.detail;
// TODO something
// ...
onTimeUpdate(currentTime);
};
const handleVideoTap = () => {
// 点击视频
};
return (
<veplayer
id={videoComponentId}
// 引用原生组件需要使用 class 传参
class={className}
src={videoPlayUrl}
showPlayBtn
showBottomProgress={false}
controls={controlShow}
// 原生组件需要使用小写 autoplay
autoplay
onPlay={onPlay}
onTimeupdate={handleTimeupdate}
poster={coverUrl}
onError={onError}
onTap={handleVideoTap}
/>
);
};
API使用,以暂停为例:
import Taro, { nextTick } from '@tarojs/taro';
const { page } = Taro.getCurrentInstance();
const videoContext = page?.selectComponent(`#${id}`)?.getContext();
videoContext.play();
订阅事件:
除了通过在jsx语法上添加on+首字母大写事件名
方式进行监听外,还可以通过组件的videoContext
以事件订阅的方式动态监听,以监听timeupdate
事件为例
import Taro from '@tarojs/taro';
const { page } = Taro.getCurrentInstance();
const videoContext = page?.selectComponent(`#${id}`)?.getContext();
if (player) {
player.on('timeupdate', (data) => {
const { currentTime, duration } = data.e.detail;
console.log('event timeupdate:', currentTime, duration)
});
}
需要注意的是通过jsx语法监听的原生事件event在taro项目中被劫持包装到了e.mpEvent.detail.e中,以监听timeupdate
事件为例,取数据时参考以下代码:
const handleTimeupdate = (e) => {
// 注意原生组件事件的event在taro项目中被劫持包装到了e.mpEvent.detail.e中
const originEvent = e.mpEvent.detail.e;
const { currentTime, duration } = originEvent.detail;
// TODO something
// ...
};
FAQs
> 小程序播放器抖音原生版本
The npm package veplayer-mp-douyin receives a total of 48 weekly downloads. As such, veplayer-mp-douyin popularity was classified as not popular.
We found that veplayer-mp-douyin demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.