管理员
|
阅读:38799回复:1
vue中使用Alipayer,播放rtmp,m3u8,mp4视频, vue-alipayer-v2
楼主#
更多
发布于:2020-11-21 14:45
这是一个基于Alipayer 开发并封装于vue的播放器由于项目需要接入rtmp协议的直播流,用于实时监控,看了网上的几个开源播放器,最后选择了阿里云的开源播放器,Alipayer,但是Alipayer是cdn加载的,且没得一个正式的vue版本,最后还是选择了自己手写吧.废话不多说,直接上代码,如下:项目地址: https://github.com/langyuxiansheng/vue-aliplayer-v2本项目在线演示阿里云播放器在线演示假如此轮子对你有帮助,请顺手star一下吧.o( ̄︶ ̄)o
1.安装使用! 下载安装npm包- npm i vue-aliplayer-v2 --save
- or
- yarn add vue-aliplayer-v2
//全局注册 main.js
import VueAliplayerV2 from 'vue-aliplayer-v2';
Vue.use(VueAliplayerV2); 2.组件中使用组件模板使用,但需要注意的是,假如你的页面中有多个播放器,那么这个id需要唯一!!,ID必传,只有一个的时候,可以忽略,命名只能是有效字符开头. 下面的视频连接是无效的,需要自己去替换成有效的.
<template>
<div id="app">
<vue-aliplayer-v2
@ready="handleReady"
ref="VueAliplayerV2"
id="player-1194076936807171180"
:options="options" />
<button @click="play()">播放</button>
<button @click="pause()">暂停</button>
<button @click="replay()">重播</button>
<button @click="getCurrentTime()">播放时刻</button>
</div>
</template>
<script>
export default {
data(){
return {
options: { //配置项
source:'rtmp://182.112.15.258:1688/hls/1194076936807171180'
}
}
},
methods:{
/**
* 在这里需要注意的是 this.$refs 可能会返回是数组,或者对象,这个在用的时候需要注意一下.且因为是异步渲染dom,所以最好是在 this.$nextTick(()=>{ //todo }); 里面调用
* 事件可以参考文档 https://help.aliyun.com/document_detail/125572.html?spm=a2c4g.11186623.6.1085.36fc6fc57WKZ5P#h2-u64ADu653Eu5668u4E8Bu4EF63
*/
play(){
this.$refs.VueAliplayerV2.play()
},
pause(){
this.$refs.VueAliplayerV2.pause();
},
replay(){
this.$refs.VueAliplayerV2.replay();
},
getCurrentTime(){
this.$refs.VueAliplayerV2.getCurrentTime();
},
/**
* 播放器事件回调
*/
handleReady(e){
console.log(`ready`,e);
}
}
}
</script>
<style lang="less" scoped>
* {
margin: 0;
padding: 0;
}
.player-btns{
width: 800px;
margin: 0 auto;
display: flex;
justify-content: space-between;
span {
margin: 0 auto;
display: inline-block;
padding: 5px 10px;
width: 150px;
height: 40px;
line-height: 40px;
border: 1px solid #eee;
background: #e1e1e1;
border-radius: 10px;
text-align: center;
margin: 20px auto;
cursor: pointer;
}
}
</style> 3.功能与配置
props:{
options: { //配置项
required: false,
type: [Object],
default: () => null
},
id:{ //播放器的ID 唯一标识符 不传就是默认的 但是有多个的时候不一定是唯一的
required: false,
type: [String],
default: `player-${Date.parse(new Date())}`
}
} 3.1 配置项 options 属性可以参考 属性和接口说明 名称 | 类型 | 说明 | source | String | 视频播放地址url:单独url。默认状态,表示使用vid+playauth。source播放方式优先级最高。source支持多清晰度设置:source:’{“HD”:”address1”,”SD”:”address2”’,详情参见多清晰度播放。 | vid | String | 媒体转码服务的媒体Id。 | playauth | String | 播放权证,如何得到参见获取playauth。 | height | String | 播放器高度,可形如‘100%’或者‘100px’,chrome浏览器下flash播放器分别不能小于397x297。 | width | String | 播放器宽度,可形如‘100%’或者‘100px’,chrome浏览器下flash播放器分别不能小于397x297。 | videoWidth | String | 视频宽度,仅h5支持。详情参见旋转和镜像。 | videoHeight | String | 视频高度,仅h5支持。详情参见旋转和镜像。 | preload | Boolean | 播放器自动加载,目前仅h5可用。 | cover | String | 播放器默认封面图片,请填写正确的图片url地址。需要autoplay为’false’时,才生效。Flash播放器封面也需要开启允许跨域访问。 | isLive | Boolean | 播放内容是否为直播,直播时会禁止用户拖动进度条。 | autoplay | Boolean | 播放器是否自动播放,在移动端autoplay属性会失效。Safari11不会自动开启自动播放如何开启。 | rePlay | Boolean | 播放器自动循环播放。 | useH5Prism | Boolean | 指定使用H5播放器。 | useFlashPrism | Boolean | 指定使用Flash播放器。 | playsinline | Boolean | H5是否内置播放,有的Android浏览器不起作用。 | showBuffer | Boolean | 显示播放时缓冲图标,默认true。 | skinRes | Url | 说明:皮肤图片,不建议随意修改该字段,如要修改,请参照皮肤定制。 | skinLayout | Array Boolean | 说明:功能组件布局配置,不传该字段使用默认布局。传false隐藏所有功能组件,请参照皮肤定制。 | controlBarVisibility | String | 控制面板的实现,默认为‘hover’。可选的值为:‘click’、‘hover’、‘always’。 | showBarTime | String | 控制栏自动隐藏时间(ms)。 | extraInfo | String | 说明:JSON串用于定制性接口参数。 | > | > | 1.“fullTitle”:“测试页面”全屏时显示视频标题(仅flash支持)。 | > | > | 2. “m3u8BufferLength”:“30”播放m3u8时加载缓存ts文件长度单位(秒)(仅flash支持)。 | > | > | 3. “liveStartTime”:“2016/08/17 12:00:00”,直播开始时间,用于提示直播未开始(仅flash支持)。 | > | > | 4. “liveOverTime”:“2016/08/17 14:00:00”,直播结束时间,用于提示直播结束(仅flash支持)。 | enableSystemMenu | Boolean | 是否允许系统右键菜单显示,默认为false。 | format | String | 指定播放地址格式,只有使用vid的播放方式时支持,可选值为’mp4’、’m3u8’、’flv’、’mp3’,默认为空,仅H5支持。 | mediaType | String | 指定返回音频还是视频,只有使用vid的播放方式时支持。可选值为’video’和’audio’,默认为’video’,‘audio’主要是针对只包含音频的视频格式,比如音频的mp4,仅H5支持。 | qualitySort | String | 指定排序方式,只有使用vid + plauth播放方式时支持。‘desc’表示按倒序排序(即:从大到小排序),‘asc’表示按正序排序(即:从小到大排序),默认值:‘asc’,仅H5支持。 | definition | String | 显示视频清晰度,多个用逗号分隔,比如:’FD,LD’,此值是vid对应流清晰度的一个子集,取值范围:FD(流畅)LD(标清)SD(高清)HD(超清)OD(原画)2K(2K)4K(4K),仅H5支持。 | defaultDefinition | String | 默认视频清晰度,此值是vid对应流的一个清晰度,取值范围:FD(流畅)LD(标清)SD(高清)HD(超清)OD(原画)2K(2K)4K(4K),仅H5支持。 | x5_type | String | 声明启用同层H5播放器,启用时设置的值为‘h5’,详情参见同层播放。 | x5_fullscreen | Boolean | 声明视频播放时是否进入到TBS的全屏模式,默认为false。当需要把视频做为背景时,设置为true,详情参见同层播放。 | x5_video_position | String | 声明视频播在界面上的位置,默认为“center”。可选值为:“top”,“center”,详情参见同层播放。 | x5_orientation | String | 声明TBS播放器支持的方向,可选值:landscape:横屏,portraint:竖屏,详情参见同层播放。 | x5LandscapeAsFullScreen | String | 声明TBS全屏播放是否横屏,默认值为true。 | autoPlayDelay | Number | 延迟播放时间,单位为秒。详情参见延迟播放 | autoPlayDelayDisplayText | String | 延迟播放提示文本,详情参见延迟播放。 | language | String | 国际化,默认为‘zh-cn’。如果未设置,则采用浏览器语言。可选值为‘zh-cn’、‘en-us’或其它值。 | languageTexts | JSON | 自定义国际化文本json结构,key的值需要和language属性值对应起来。例子:{jp:{Play:”Play”}},自定义值参见Json结构。 | snapshot | Boolean | flash启用截图功能。 | snapshotWatermark | Object | H5设置截图水印。 | useHlsPluginForSafari | Boolean | Safari浏览器可以启用Hls插件播放,Safari 11除外。 | enableStashBufferForFlv | Boolean | H5播放flv时,设置是否启用播放缓存,只在直播下起作用。 | stashInitialSizeForFlv | Number | H5播放flv时,初始缓存大小,只在直播下起作用。 | loadDataTimeout | Number | 缓冲多长时间后,提示用户切换低清晰度,默认:20秒。 | waitingTimeout | Number | 最大缓冲超时时间,超过这个时间会有错误提示,默认:60秒。 | liveStartTime | String | 直播开始时间,直播时移功能使用,格式为:“2018/01/04 12:00:00”。 | liveOverTime | String | 直播结束时间,直播时移功能使用,格式为:“2018/01/04 12:00:00”。 | liveTimeShiftUrl | String | 直播可用时移查询地址,详情参见直播时移。 | liveShiftSource | String | flv直播地址播放时,hls的流地址,详情参见直播时移。 | recreatePlayer | Function | flv直播和hls时移切换是,重新创建播放器方法,详情参见直播时移。 | diagnosisButtonVisible | Boolean | 是否显示检测按钮,默认为true。 | disableSeek | Boolean | 禁用进度条的Seek,默认为false,仅Flash支持。 | encryptType | int | 加密类型,播放点播私有加密视频时,设置值为1,默认值为0。 | progressMarkers | Array | 进度条打点内容数组,详情参见进度条打点。 | vodRetry | int | 点播失败重试次数,默认3次 | liveRetry | int | 直播播放失败重试次数,默认5次 | 3.2 播放器方法 // 暂停播放 this.$refs.VueAliplayerV2.pause(); 可以参考 播放器接口方法4.播放器事件
<template>
<vue-aliplayer-v2 @ready="handleReady" />
</template>
<script>
export default {
methods:{
/**
* 播放器事件回调
*/
handleReady(e){
console.log(`ready`,e);
}
}
}
</script> 可以参考 播放器事件 5. 图片展示6.二次开发 下载项目git clone https://github.com/langyuxiansheng/vue-aliplayer-v2.gitProject setup
cd vue-aliplayer-v2
npm install Compiles and hot-reloads for developmentnpm run dev Compiles and minifies for productionnpm run build Lints and fixes filesnpm run lint 7.缺陷 & 后期计划您有功能建议,或者bug反馈请留言.
8.感谢 Customize configurationSee Configuration Reference.9.项目案例展示9.1 web PC端互联网监管,视频监控直播流9.2微信公众号 H5效果展示
|