1.2.8 • Published 3 months ago

veplayer-mp-douyin v1.2.8

Weekly downloads
-
License
MIT
Repository
-
Last release
3 months ago

Veplayer小程序播放器

小程序播放器抖音原生版本

使用前提条件

小程序后台-开发-开发设置-服务器域名中添加以下域名配置

  • 日志上报域名:https://mcs.zijieapi.com

  • 播放请求域名(仅vid+playAuthToken播放时需要):https://vod.volcengineapi.com

操作截图如下所示。 npm.io

视频资源的 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功能:依赖管理中添加 npm 包。

引入组件

详情请参考抖音小程序自定义组件的使用方式

{
  "usingComponents": {
    "veplayer": "ext://veplayer-mp-douyin/veplayer"
  }
}

正确使用npm功能需要更新抖音开发者工具到4.1.0以上版本。抖音开发者工具4.1.0 之前的版本需要引用手动拷贝到 components 的包即 "/components/veplayer-mp-douyin/dist/index"

使用组件

配置播放器日志

  1. 在火山引擎视频点播控制台新建应用,获取应用的唯一AppID。

alt appid

  1. 引入日志组件,在页面加载前初始化日志数据采集 SDK 的构造器。initCollector 方法的参数中的 userId 是用来统计用户相关的播放数据。

    推荐使用应用关联的用户 ID,方便后续发生错误时进行单点排查。

import { initCollector } from 'veplayer-mp-logger'

initCollector({
  appId: 111111, // 火山引擎上业务自己的 AppID
  userId: '7231102214076007992', // 用户 ID,没有可以不传入,日志 SDK自动生成
})

如果在不使用播放器 SDK的情况下,也能够进行播放日志上报,请参考 veplayer-mp-logger。 如果在不使用播放器SDK的情况下能够进行播放日志上报,请参考veplayer-mp-logger

使用播放器组件

按照播放方式的不同,分为 url 方式播放和vid 方式播放:

1. url 方式播放

<view>
  <!-- 以下是对小程序播放器组件的引用 -->
  <veplayer
   	id="videoContainer"
    showPlayBtn
    autoplay
    src="http://xxxx.mp4"
    bindplay="onPlay"
    logInfo="{{logInfo}}"
  ></veplayer>
</view>

2. 短剧方式播放

<view>
  <!-- 以下是对小程序播放器组件的引用 -->
  <veplayer
   	id="videoContainer"
    showPlayBtn
    autoplay
    albumId="2342343543645"
    episodeId="877766252"
    bindplay="onPlay"
    logInfo="{{logInfo}}"
  ></veplayer>
</view>
  • albumId: 对应原片id
  • episodeId:对应剧集id

对应业务组件中添加日志上报需要的视频信息配置:

// 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,不在列表中的只影响原生组件:

PropertyTypeDefaultRequiredDescription
mode'portrait' | 'landscape''landscape'播放器支持竖屏(portrait)及横屏(landscape)两种播放UI模式。横屏模式偏向于普通的PC视频播放器UI,竖屏视频展示类似抖音等短视频播放模式。
srcstring
componentIdstringNOvideo组件的id,用于通过createVideoContext获取视频VideoContext,不传入则会随机生成一个id,此时视频VideoContext仅能通过组件上下文的getContext方法获取
controls'custom' | 'native'|'false'| 'focus' | 'hidden' | 'blur' | 'focus' | immerse'custom'custom: 自定义UI; native: 原生组件UI;false: 完全关闭播放UI控件(包括自定义UI及原生组件UI); focus: 高亮状态; hidden: 隐藏状态(禁交互); blur: 失去焦点状态; immerse:半沉浸状态(即半透明状态), 播放UI控件指loading状态、播控按钮、进度条、时间显示等。
showFullscreenBtnboolean当开始/继续播放时触发play事件
durationnumber根据官方文档说明,duration属性只是控制显示的时长,不会控制实际播放的时长。因此该属性不设置给原始video组件,只提供给自定义UI使用
playDomainstring调用火山引擎视频点播OpenAPI的接口地址,业务方如果做了该接口的代理,可以替换成业务方的地址
playAuthTokenstring获取视频播放信息(包括播放地址,传入此项时不需要传入src)的临时凭证,由业务方服务端通过调用火山服务端SDK本地生成,具体生成方法参考火山引擎视频点播文档
needLoadingbooleantrue是否显示loading,扩展属性,controls=custom的时候生效,v0.1.12之后的版本生效
timeUpdateIntervalnumber400进度条更新的频率, 用于减少频繁的渲染造成内存升高的问题,单位ms
autoBlurTimenumber15000自动失焦,即播放器在处于激活态用户无操作多长时间隐藏播控
interactiveConfigobject{ immersive: false, delay: 10000, focusDelay: 0 }响应式配置: immersive: 是否启用半沉浸式 delay:进入半沉浸状态/隐藏状态的延迟时间,单位ms focusDelay: 隐藏态进入focus态是否自动切换,单位ms
activeStatestringdefault当前实例是否是激活状态: active:激活状态 standby:备用状态 default:默认状态,即不区分是否激活
enableTapActivebooleantrue自定义controls时,即controls不是native时,是否启用点击触发激活(进入focus态)
albumIdstring短剧方式播放时必填原片id
episodeIdstring短剧方式播放时必填剧集id
cloudTypenumber1使用cdn类型,1: 抖音云 2: 三方云; 如果不填服务端默认不从CDN上获取链接
threePartyCloudstring三方云链接,当cloud_type为2,即三方云时必传
versionstring'1'废弃字段。为了兼容老版本,请传 1
binduseractioneventhandle用户行为触发,如用户点击暂停、滑动进度条
bindplayeventhandle当开始/继续播放时触发play事件
bindpauseeventhandle当暂停播放时触发 pause 事件
bindendedeventhandle当播放到末尾时触发 ended 事件
bindtimeupdateeventhandle播放进度变化时触发,event.detail = {currentTime, duration} 。触发频率 250ms 一次
bindfullscreenchangeeventhandle视频进入和退出全屏时触发,event.detail = {fullScreen, direction},direction 有效值为 vertical 或 horizontal
bindwaitingeventhandle视频出现缓冲时触发
binderroreventhandle视频播放出错时触发
bindprogresseventhandle加载进度变化时触发,只支持一段加载。event.detail = {buffered},百分比
bindloadedmetadataeventhandle视频元数据加载完成时触发。event.detail = {width, height, duration}
bindplaybackratechangeeventhandle视频倍速改变完成时触发。返回改变后的倍速值。event.detail={playbackRate}。
bindenterbackgroundeventhandle进入小窗播放时触发
bindclosebackgroundeventhandle关闭小窗播放时触发
bindleavebackgroundeventhandle离开小窗进入 app 事件时触发
bindseekingeventhandle组件内部代理劫持VideoContext,VideoContext.seek 调用后会立即发送该事件,该事件非video自带事件,只支持 controls="custom" 时才对外发送
bindseekcompleteeventhandleseek 完成时触发 (position iOS 单位 s, Android 单位 ms)
bindcontrolstoggleeventhandle切换 controls 显示隐藏时触发 controlstoggle 事件。event.detail = {show}

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()
// ...

组件事件

小程序播放器对外支持两种方式的事件订阅形式:

  • 组件属性 bind 方式事件监听
  • 组件对象提供事件订阅的机制进行事件监听

请选择其中一种进行订阅,尽量不要两者混用。这两种方式在组件实例中,被从页面节点树移除(lifetimes->detached)时,进行事件解绑,您无需单独关注事件泄漏的问题。

组件属性 bind 方式事件监听

请参见组件属性中 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)
  })
  // ...
});

详细的事件列表:

EventNameCustomEventDescription
play参见属性 bindplay 描述
pause参见属性 bindpause 描述
ended参见属性 bindended 描述
timeupdate参见属性 bindtimeupdate 描述
fullscreenchange参见属性 bindfullscreenchange 描述
waiting参见属性 bindwaiting 描述
error参见属性 binderror 描述
progress参见属性 bindprogress 描述
loadedmetadata参见属性 bindloadedmetadata 描述
playbackratechange参见属性 bindplaybackratechange 描述
enterbackground参见属性 bindenterbackground 描述
closebackground参见属性 bindclosebackground 描述
leavebackground参见属性 bindleavebackground 描述
seeking参见属性 bindseeking 描述
seekcomplete参见属性 bindseekcomplete 描述
controlstoggle参见属性 bindcontrolstoggle 描述
getsource获取到视频信息,仅短剧播放模式下触发
useraction用户行为触发,如用户点击暂停、滑动进度条

uni-app 项目使用

此播放器组件提供的是原生小程序版本,uni-app项目支持使用小程序自定义组件,可以按照以下步骤在uni-app项目中使用此播放器组件:

1. 在项目中安装依赖

# 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

2. 拷贝组件到项目目录

拷贝node_modules/veplayer-mp-douyin到项目小程序组件存放目录ttcomponents(0.1.14之后的版本会自动拷贝)。HBuilderX 建立的工程 ttcomponents 文件夹在 项目根目录下。vue-cli 建立的工程 ttcomponents 文件夹在 src 目录下。

3. 配置播放器日志

在页面/组件实例化之前,配置播放器日志的相关配置。

import { initCollector } from 'veplayer-mp-logger'

initCollector({
  appId: 111111, // 火山引擎上业务自己的 AppID
  userId: '7231102214076007992', // 用户 ID,没有可以不传入,日志 SDK自动生成
})

4. 配置组件引入

pages.json 对应页面的 style -> usingComponents 引入组件: 可通过uni-app提供的条件编译的方式在不同平台上编译使用不同的SDK,抖音小程序播放器SDK对应veplayer-mp-douyin

如果是在 vue 组件中使用小程序组件时,注意需要在 pages.jsonglobalStyle 中配置 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"
			}
		}
	]
}

5. 组件使用

以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 的方式进行数据和事件绑定:

短剧行业能力

播放器继承了抖音短剧行业能力,使用方法参照以下说明:

前提条件

按照官网文档配置行业 SDK 的权限配置。

使用组件

短剧行业能力依赖video-player,video-player 只在 抖音23.0以上版本支持,播放器组件会自动使用 tt.canIUse('video-player') 校验当前抖音能否使用。若监测到不支持时,组件会自动降级为video组件进行播放,此时请确保传入了正确有效的视频地址,或者引导用户升级抖音版本。

<veplayer
  id="video"
  albumId="{{aid}}" 
  episodeId="{{eid}}"
  src="{{degradeSrc}}"
  autoplay
  bindgetsource="getSource"
  ...
></veplayer>
Component({
  // ...
  data: {
    aid: 'x32432w',
    eid: 'xxsddw',
    // 抖音23.0以下版本不支持短剧行业能力时使用的兜底地址
    degradeSrc: 'https://xx.demo.com/d.mp4'
  },
  methods: {
    getSource(e){
      // do something
    },
    playVideo(){
      // do something
      this.player.play()
    }
  }
})

Taro 项目使用

Taro 项目支持使用原生小程序组件,可以按照以下步骤在Taro项目中使用此播放器组件。

1. 在项目中安装依赖

# npm
npm i veplayer-mp-douyin
npm i veplayer-mp-logger

# yarn 
yarn add veplayer-mp-douyin
yarn add veplayer-mp-logger

2. 拷贝组件到项目目录

拷贝node_modules/veplayer-mp-douyin到项目小程序组件存放目录ttcomponents(0.1.14之后的版本会自动拷贝)。

3. 配置播放器日志

在页面/组件实例化之前,配置播放器日志的相关配置。

import { initCollector } from 'veplayer-mp-logger'

initCollector({
  appId: 111111, // 火山引擎上业务自己的 AppID
  userId: '7231102214076007992', // 用户 ID,没有可以不传入,日志 SDK自动生成
})

4. 配置组件引入

在使用到播放器组件所在页面的index.config.ts配置中引入组件:

export default definePageConfig({
    navigationBarTitleText: '',
    navigationBarTextStyle: 'black',
    navigationStyle: 'custom',
    disableScroll: true,
    usingComponents: {
        veplayer: '../../ttcomponents/veplayer-mp-douyin/dist/index',
    },
});

注意保证组件路径配置正确

5. 组件使用

以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
  // ...
};
1.2.8

3 months ago

1.2.8-rc.2

3 months ago

1.2.8-rc.1

3 months ago

1.2.7

3 months ago

1.2.7-rc.0

3 months ago

1.2.8-rc.0

3 months ago

1.2.7-alpha.5

3 months ago

1.2.7-alpha.4

4 months ago

1.2.7-alpha.3

4 months ago

1.2.7-alpha.2

4 months ago

1.2.7-alpha.1

4 months ago

1.2.7-alpha.0

4 months ago

1.2.6

5 months ago

1.2.6-alpha.3

5 months ago

1.2.6-alpha.2

5 months ago

1.2.6-alpha.5

5 months ago

1.2.6-alpha.4

5 months ago

1.2.6-alpha.1

5 months ago

1.2.6-alpha.0

5 months ago

1.2.5

5 months ago

1.2.3-alpha.0

6 months ago

1.2.3-alpha.1

6 months ago

1.2.3-alpha.2

6 months ago

1.2.4

6 months ago

1.2.3

6 months ago

1.2.5-alpha.0

6 months ago

1.2.5-alpha.1

6 months ago

1.2.3-alpha.3

6 months ago

1.2.3-alpha.4

6 months ago

1.2.3-alpha.6

6 months ago

1.2.3-alpha.7

6 months ago

1.2.3-alpha.13

6 months ago

1.2.3-alpha.12

6 months ago

1.2.3-alpha.15

6 months ago

1.2.3-alpha.14

6 months ago

1.2.3-alpha.11

6 months ago

1.2.3-alpha.10

6 months ago

1.0.2

9 months ago

1.0.4-alpha.0

8 months ago

1.0.1

10 months ago

1.0.0

10 months ago

0.1.10

11 months ago

0.1.11

11 months ago

0.1.12

10 months ago

0.1.13

10 months ago

0.1.14

10 months ago

0.1.15

10 months ago

1.0.6-alpha.1

7 months ago

1.0.6-alpha.0

7 months ago

1.0.6

7 months ago

1.0.5

8 months ago

1.0.4

8 months ago

1.0.3

9 months ago

1.0.2-alpha.4

9 months ago

1.0.2-alpha.2

9 months ago

1.0.2-alpha.3

9 months ago

1.0.2-alpha.0

9 months ago

1.0.2-alpha.1

9 months ago

0.1.2

12 months ago

0.1.1

12 months ago

0.1.8

11 months ago

0.1.7

11 months ago

0.1.9

11 months ago

0.1.4

12 months ago

0.1.3

12 months ago

0.1.6

12 months ago

0.1.5

12 months ago

1.0.3-alpha.7

9 months ago

1.0.3-alpha.8

9 months ago

1.0.3-alpha.5

9 months ago

0.0.20

12 months ago

1.0.3-alpha.6

9 months ago

1.0.5-alpha.0

8 months ago

1.0.5-alpha.2

8 months ago

1.0.3-alpha.9

9 months ago

0.1.15-alpha.0

10 months ago

1.0.5-alpha.1

8 months ago

0.1.15-alpha.1

10 months ago

0.1.10-alpha.14

11 months ago

0.1.10-alpha.13

11 months ago

1.0.5-alpha.4

8 months ago

0.0.15

12 months ago

1.0.5-alpha.3

8 months ago

1.0.3-alpha.0

9 months ago

0.0.16

12 months ago

0.0.17

12 months ago

1.0.3-alpha.3

9 months ago

0.0.19

12 months ago

1.0.3-alpha.4

9 months ago

0.1.10-alpha.19

11 months ago

1.0.3-alpha.1

9 months ago

0.1.10-alpha.16

11 months ago

1.0.3-alpha.2

9 months ago

0.0.11

12 months ago

0.0.12

12 months ago

0.0.13

12 months ago

0.0.14

12 months ago

0.1.11-alpha.0

11 months ago

0.1.16

10 months ago

0.1.17

10 months ago

0.0.9-alpha.0

12 months ago

0.0.7

12 months ago

0.0.6

12 months ago

0.0.4

12 months ago

0.0.3

12 months ago

0.0.1

12 months ago