1.2.8 • Published 3 months ago

veplayer-mp-wechat v1.2.8

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

Veplayer小程序播放器

小程序播放器微信原生版本

前提条件

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

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

视频资源的 CDN 域名不需要添加到域名配置中。

安装

# npm
npm i veplayer-mp-wechat
npm i veplayer-mp-logger

# yarn 
yarn add veplayer-mp-wechat
yarn add veplayer-mp-logger

构建 npm 包

请优先了解微信小程序官网对于 npm 支持 的介绍。 您需要点击微信开发者工具中的菜单栏,工具 > 构建 npmnpm.io

引入组件

详情请参考微信官方文档小程序自定义组件的引入方式。引入微信小程序点播 SDK 的代码示例如下:

{
  "usingComponents": {
    "veplayer": "veplayer-mp-wechat"
  }
}

使用组件

配置播放器日志

  1. 您需要在火山引擎视频点播控制台新建应用,获取应用的唯一 AppID。image.png
  2. 引入日志组件,在页面加载前初始化日志数据采集 SDK 的构造器。initCollector 方法的参数中的 userId 是用来统计用户相关的播放数据。

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

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

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

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

使用播放器组件

按照播放方式的不同,分为 DirectUrl 方式播放和 Vid 方式播放。

DirectUrl 方式播放

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

Vid 方式播放

<view>
  <!-- 以下是对一个播放器组件的引用 -->
  <veplayer
    id="videoContainer"
    showPlayBtn
    autoplay
    playDomain='https://vod.volcengineapi.com'
    playAuthToken='*****************'
    logInfo="logInfo"
    bindplay="onPlay"
  />
</view>
  • playDomain 是调用火山引擎视频点播 OpenAPI 的播放域名,您如果做了该接口的代理,可以替换成您自己的播放域名。使用正式 AppID 调试时需要将该地址配置在小程序服务器域名配置白名单中。
  • playAuthToken 是获取视频播放信息的临时凭证,由业务方服务端通过调用火山服务端 SDK 基于视频 Vid 本地方法生成,具体生成参考火山引擎视频点播文档

对应业务组件中添加日志上报需要的视频信息配置,代码示例如下:

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

原生微信 video 组件的属性,如:show-play-btn 这类中划线分割的属性名,需要改写成驼峰式命名showPlayBtn。

属性类型默认值是否必选说明
mode'portrait' | 'landscape'landscapeUI 模式。支持 2 种播放 UI 模式。取值如下:landscape:(默认值)横屏。展示类似抖音等短视频播放 UI 模式。 portrait:竖屏。展示偏向于普通的 PC 视频播放器 UI 模式。
componentIdStringvideo 组件 ID。通过createVideoContext获取视频 VideoContext。如果不传,随机生成一个 ID,需要通过组件上下文的getContext()方法才能获取视频 VideoContext。
srcString播放视频的资源地址。支持网络路径、本地临时路径、云文件 ID等。
controls'custom' | 'native'|'false'| 'focus' | 'hidden' | 'blur' | 'focus' | immerse'custom'custom: 自定义UI; native: 原生组件UI;false: 完全关闭播放UI控件(包括自定义UI及原生组件UI); focus: 高亮状态; hidden: 隐藏状态(禁交互); blur: 失去焦点状态; immerse:半沉浸状态(即半透明状态), 播放UI控件指loading状态、播控按钮、进度条、时间显示等。
playAuthTokenstringvid方式播放必传获取视频播放信息的临时凭证,由业务方服务端通过调用火山服务端SDK基于视频vid本地服务生成,具体生成参考火山引擎视频点播文档
playDomainstringhttps://vod.volcengineapi.com调用火山引擎视频点播 OpenAPI 的播放域名,您如果做了该接口的代理,可以替换成您自己的播放域名。使用正式 AppID 调试时需要将该地址配置在小程序服务器域名配置白名单中|
durationnumber指定视频时长。不会控制实际播放的时长。因此该属性不设置给原始 video 组件,只提供给自定义 UI 使用。
showCenterPlayBtnbooleantrue是否显示视频正中心的播放按钮。
showBottomProgressbooleantrue是否展示底部进度条。
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态)
binduseractioneventhandle用户行为触发,如用户点击暂停、滑动进度条
bindplayeventhandle当开始/继续播放时触发 play 事件。
bindpauseeventhandle当暂停播放时触发 pause 事件。
bindendedeventhandle当播放到末尾时触发 ended 事件。
bindtimeupdateeventhandle播放进度变化时触发 timeupdate 事件。event.detail = {currentTime, duration} 触发频率 250ms 一次。
bindfullscreenchangeeventhandle视频进入和退出全屏时触发 fullscreenchange 事件。event.detail = {fullScreen, direction} direction 有效值为 verticalhorizontal
bindwaitingeventhandle视频出现缓冲时触发 waiting 事件。
binderroreventhandle视频播放出错时触发 error事件。
bindprogresseventhandle加载进度变化时触发 progress 事件,只支持一段加载。event.detail = { buffered } ,单位百分比
bindloadedmetadataeventhandle视频元数据加载完成时触发 loadedmetadata 事件。event.detail = {width, height, duration}
bindcontrolstoggleeventhandle切换 controls 显示隐藏时触发 controlstoggle 事件。event.detail = {show}
bindenterpictureinpictureeventhandle播放器进入小窗 enterpictureinpicture 事件。
bindleavepictureinpictureeventhandle播放器退出小窗 leavepictureinpicture 事件。
bindseekcompleteeventhandleseek 完成时触发 seekcomplete 事件。position 的单位在不同系统上有所区别: iOS单位为 s,Android,单位为 ms。

组件接口

小程序播放器封装了 VideoContext,提供同原生接口一致的 API。代码示例如下所示。

const component = this.selectComponent("#videoContainer");
const player = component.getContext()

// 原生接口
player.play()
player.pause()
player.stop()
player.seek(10)
player.sendDanmu(Object data)
player.playbackRate(1)
player.requestFullScreen({ direction: 90 })
player.exitFullScreen()
player.exitPictureInPicture()
player.requestBackgroundPlayback()
player.exitBackgroundPlayback()

组件事件

微信小程序播放器对外支持 2 种方式的事件监听形式:

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

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

组件属性 bind 方式事件监听

请参见组件属性中 bind 开头的事件属性。

组件对象提供事件订阅的机制进行事件监听

小程序播放器提供了接口可以获取 player context,并可以对 player 添加事件订阅,从而实现任意时刻对各种播放事件添加/移除监听的功能。代码示例如下所示。

const component = this.selectComponent("#videoContainer");
const player = component.getContext();

// 事件订阅
player.on('error', (e) => {
  console.log('event error:', e)
});
player.on('timeupdate', (e) => {
  const { currentTime, duration } = e.detail;
  console.log('event timeupdate:', currentTime, duration)
});
// ...

详细的事件列表如下所示。

事件名称是否可自定义事件说明
play当开始/继续播放时触发 play 事件。
pause当暂停播放时触发 pause 事件。
ended当播放到末尾时触发 ended 事件。
timeupdate播放进度变化时触发。
fullscreenchange视频进入和退出全屏时触发 fullscreenchange 事件。
waiting视频出现缓冲时触发 waiting 事件。
error视频播放出错时触发 error 事件。
progress加载进度变化时触发 progress 事件,只支持一段加载。
loadedmetadata视频元数据加载完成时触发 loadedmetadata 事件。
controlstoggle切换 controls 显示隐藏时触发 controlstoggle 事件。
enterpictureinpicture播放器进入小窗 enterpictureinpicture 事件。
leavepictureinpicture播放器退出小窗 leavepictureinpicture 事件。
seekcompleteseek 完成时触发 seekcomplete 事件。

uni-app 项目使用

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

1. 在项目中安装依赖

# npm
npm i veplayer-mp-wechat
npm i veplayer-mp-logger

# yarn 
yarn add veplayer-mp-wechat
yarn add veplayer-mp-logger

HBuilderX创建的项目默认没有package.json文件,需要通过初始化命令来创建。

npm init -y

2. 拷贝组件到项目目录

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

3. 配置播放器日志

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

  import { CollectorManager } from '@/wxcomponents/veplayer-mp-wechat/dist/tool';
  import Collector from 'veplayer-mp-logger';

  CollectorManager.setCollector(Collector, {
    appId: 11***1,            // 视频点播控制台中获取的应用 ID
    userId: '7231102***76007992'   // 用户 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": "/wxcomponents/veplayer-mp-wechat/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', (data) => {
      const { currentTime, duration } = data.e.detail;
      console.log('event timeupdate:', currentTime, duration)
    });
  }
  • 如果是从uni-app的video组件迁移到本组件,不作API使用的更改,则组件属性里通过componentId传入uni.createVideoContext需要的组件id,API调用同uni-app组件说明
  • 需要注意的是通过createVideoContext获取的播放器上下文无法使用事件订阅。

注意数据和事件绑定的差异,组件使用时应按照 vue 的方式进行数据和事件绑定:

Taro 项目使用

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

1. 在项目中安装依赖

# npm
npm i veplayer-mp-wechat
npm i veplayer-mp-logger

# yarn 
yarn add veplayer-mp-wechat
yarn add veplayer-mp-logger

2. 拷贝组件到项目目录

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

3. 配置播放器日志

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

  import { CollectorManager } from '@/wxcomponents/veplayer-mp-wechat/dist/tool';
  import Collector from 'veplayer-mp-logger';

  CollectorManager.setCollector(Collector, {
    appId: 11***1,            // 视频点播控制台中获取的应用 ID
    userId: '7231102***76007992'   // 用户 ID,没有可以不传入,SDK 自动生成
  });

4. 配置组件引入

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

export default definePageConfig({
    navigationBarTitleText: '',
    navigationBarTextStyle: 'black',
    navigationStyle: 'custom',
    disableScroll: true,
    usingComponents: {
        veplayer: '../../wxcomponents/veplayer-mp-wechat/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.8-rc.0

3 months ago

1.2.7-rc.0

3 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.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.0.6-alpha.0

6 months ago

1.2.4

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.7

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

11 months ago

0.1.13

10 months ago

0.1.14

10 months ago

0.1.15

10 months ago

1.0.5

7 months ago

1.0.4

8 months ago

1.2.2

9 months ago

1.2.2-alpha.17

8 months ago

1.2.2-alpha.16

8 months ago

1.2.2-alpha.15

9 months ago

1.2.2-alpha.14

9 months ago

1.0.2-alpha.4

9 months ago

1.2.2-alpha.13

9 months ago

1.0.2-alpha.5

9 months ago

1.2.2-alpha.12

9 months ago

1.0.2-alpha.2

9 months ago

1.2.2-alpha.11

9 months ago

1.0.2-alpha.3

9 months ago

1.2.2-alpha.10

9 months ago

1.0.2-alpha.0

9 months ago

1.0.2-alpha.1

9 months ago

0.0.15-alpha.1

11 months ago

0.0.15-alpha.0

11 months ago

1.2.2-alpha.1

9 months ago

1.2.2-alpha.0

9 months ago

1.2.2-alpha.3

9 months ago

1.2.2-alpha.2

9 months ago

1.0.5-alpha.0

7 months ago

0.1.15-alpha.0

10 months ago

0.1.13-alpha.0

10 months ago

0.0.15-alpha.21

11 months ago

1.2.2-alpha.9

9 months ago

0.1.17-alpha.0

10 months ago

1.0.3-alpha.0

9 months ago

1.2.2-alpha.8

9 months ago

1.2.2-alpha.5

9 months ago

1.2.2-alpha.4

9 months ago

1.2.2-alpha.7

9 months ago

1.2.2-alpha.6

9 months ago

0.0.10

12 months ago

0.0.11

12 months ago

0.0.12

12 months ago

0.0.13

12 months ago

0.0.14

11 months ago

0.1.16

10 months ago

0.0.14-alpha.0

11 months ago

0.0.9

12 months ago

0.1.17

10 months ago

0.0.14-alpha.1

11 months ago

0.0.8

12 months ago

0.0.7

12 months ago

0.0.6

12 months ago

0.0.5

12 months ago

0.0.4

12 months ago

0.0.3

12 months ago

0.0.2

12 months ago

0.0.1

12 months ago