vue播放video插件vue-video-player实现hls, rtmp播放全过程

1.安装插件

1 npm install vue-video-player -S

2.配置插件 
在main.js里添加

1 import VideoPlayer from ‘vue-video-player‘
2 require(‘video.js/dist/video-js.css‘)
3 require(‘vue-video-player/src/custom-theme.css‘)
4 Vue.use(VideoPlayer)

3.使用插件 
在vue的组件页面里

 1 <template>
 2         <video-player  class="video-player vjs-custom-skin"
 3             ref="videoPlayer"
 4             :playsinline="true"
 5             :options="playerOptions"
 6         ></video-player>
 7 </template>
 8 <script>
 9 export default {
10   name: ‘BusImg‘,
11   data () {
12     return {
13       // 视频播放
14       playerOptions : {
15         playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
16         autoplay: false, //如果true,浏览器准备好时开始回放。
17         muted: false, // 默认情况下将会消除任何音频。
18         loop: false, // 导致视频一结束就重新开始。
19         preload: ‘auto‘, // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
20         language: ‘zh-CN‘,
21         aspectRatio: ‘16:9‘, // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")
22         fluid: true, // 当true时,Video.js player将拥有流体大小。换句话说,它将按比例缩放以适应其容器。
23 flash: {
24           hls: { withCredentials: false },
25           swf: ‘./static/media/video-js.swf‘         // 引入静态文件swf
26         },
27         html5: { hls: { withCredentials: false } },
28         sources: [{ // 流配置,数组形式,会根据兼容顺序自动切换
29           type: ‘rtmp/hls‘,
30           src: ‘rtmp://192.168.1.199:10935/hls/stream_1‘
31         }, {
32           withCredentials: false,
33           type: ‘application/x-mpegURL‘,
34           src: ‘http://playertest.longtailvideo.com/adaptive/bipbop/gear4/prog_index.m3u8‘
35         }],
36         poster: "", //你的封面地址
37         // width: document.documentElement.clientWidth,
38         notSupportedMessage: ‘此视频暂无法播放,请稍后再试‘, //允许覆盖Video.js无法播放媒体源时显示的默认信息。
39         controlBar: {
40           timeDivider: true,
41           durationDisplay: true,
42           remainingTimeDisplay: false,
43           fullscreenToggle: true  //全屏按钮
44         }
45     }
46 </script>

注意点

下面说说用这个插件来直播的一些坑和注意点吧:

首先,常用的 demo 在 vue-video-player 中官方已经给出了,按要求来就可以,其中

  1. 如果需要播放 HLS 流,需要安装 videojs-contrib-hls 插件,非原生支持的浏览器,直播服务端需要开启 CORS
  2. 如果需要播放 RTMP 流,需要安装 videojs-flash 插件
  3. 如果两个流都需要播放,flash 插件需要安装到 hls 插件之前
  4. 安装vue-video-player插件一定要用npm安装,不可使用cnpm安装,否则会报“The "flash" tech is undefined. Skipped browser support check for that tech”

原文地址:https://www.cnblogs.com/wr1991/p/9957147.html

时间: 2024-07-30 22:23:44

vue播放video插件vue-video-player实现hls, rtmp播放全过程的相关文章

Cisdem Video Player for mac(高清视频播放器)

Mac视频播放器哪款好用?当然首推Cisdem Video Player for Mac!功能强大,操作简单并且不需要缓冲就可以提供更好的高清视频播放体验,是一款不能错过的视频和音频的播放软件.macdown.com为您提供Cisdem Video Player的极致下载体验,有需要的朋友欢迎前来下载体验! https://www.macdown.com mac版cisdem video player功能介绍 1.播放超过50种格式的视频/音频文件,无需编解码器包我们设计了一种技术,让您可以直接

关于Unity视频播放器插件 AVPro Video(三)360度全景视频播放

1.官网下载该插件或者我分享的链接: 链接:https://pan.baidu.com/s/1boGeJ8r 密码:mvbf 2.拖入官方做好的预制体"360SphereVideo"或者"360CubeVideo"(两种不同的360度全景)到场景中,并将场景中的摄像机拖动到"Sphere"下方并Resert 3.设置"AVPro Video Media Player"上的Media Player 控制组件即可(具体操作参考&q

在sublime 编辑器中,安装插件 Vue Syntax Hightlight,高亮识别Vue.js 的单文件组件(*.vue)

转自:http://www.cnblogs.com/cosnyang/p/6290950.html 默认情况下,Vue.js 的单文件组件(*.vue)在 sublime 编辑器中是不被识别的.若要想高亮显示,需要安装插件 Vue Syntax Hightlight.安装步骤如下: 第一,在 sublime 中打开 PackageControl 如下图,快捷键 Ctrl+Shift+P. 第二,打开 Install Package 窗口.下图中第一个,回车. 打开过程中,右下角出现状态栏.如下图

chrome浏览器的VUE调试插件Vue.js devtools

chrome浏览器的VUE调试插件Vue.js devtools 应用商店直接安装 安装成功后在VUE文件打开可以直接调试: 提示效果如下: F12进入调试状态即可: 安装中出现的问题: 插件安装后无法使用,出现vue.js not detected提示的解决办法 找到插件的安装目录: (可以通过id搜索ID:nhdogjmejiglipccpnnnanhbledajbpd) C:\Users\liangsuya\AppData\Local\Google\Chrome\User Data\Def

H5 video安卓默认点击不能全屏播放解决办法

调用方法: autoFullScrenn(obj) 还有一篇: 使用MediaElement.js构建个性的HTML5音频和视频播放器 var fullscreen = function(elem) { var prefix = 'webkit'; if ( elem[prefix + 'EnterFullScreen'] ) { return prefix + 'EnterFullScreen'; } else if( elem[prefix + 'RequestFullScreen'] )

js文本复制插件&amp;vue

/* HTML: * <a href="javascript:;" class="copy" data-clipboard-text="copy"></a> */ $('.bdsharebuttonbox .copy').on('click', function (){ $(this).attr('data-clipboard-text',window.location.href); var clipboard = new

Vue 开发自定义插件学习记录 -- 入门

首先,你需要了解插件实现的基本原理 插件基本原理: 我们都知道用Vue.use注册插件,那你知道Vue.use(plugin) 干了什么? 以下是我对Vue官网的一些摘录和个人的理解 Vue.use( plugin ) 参数: {Object | Function} plugin 用法: 安装 Vue.js 插件.如果插件是一个对象,必须提供 install 方法.如果插件是一个函数,它会被作为 install 方法. install 方法调用时,会将 Vue 作为参数传入. 该方法需要在调用

Vue 去脚手架插件,自动加载vue文件,style怎么办

书接上上会,因为当时也没想好怎么办,所以装聋作哑的忽略了Vue文件中的Style,Vue的做法我看着晕乎乎的,细想的话,无非就是自动填写到dom中,所担心的无非是命名冲突. 在一个项目中(像我这种自娱自乐的项目中)加载的自定义组件是不会重名的(应该不会吧,反正就是让他不会的意思),那就每个Vue中加组件名做前缀,然后duang,写入dom. 规规矩矩的放在head里,齐活了 更新一下我那个牛逼的文件 // vue插件引入 Vue.use({ // 插件初始化函数 install: functio

vue 封装一个插件

1.创建一个vue组件button/button.vue <template> <div class="btn" :style="{'background':color,'color':fontColor}"> {{text}} </div> </template> <script> export default { name:"button", //配置项 props:{ text:{