1.安裝插件
1 npm install vue-video-player -S
2.配置插件
在main.js里添加
1 import VideoPlayer from 'vue-video-player' 2 import 'video.js/dist/video-js.css'
3 import 'videojs-flash'
4 Vue.use(VideoPlayer)
3.使用插件
在vue的組件頁面里
<video-player class="video-player vjs-custom-skin"
ref="videoPlayer"
:playsinline="true"
:options="playerOptions"
></video-player>
</template>
<script>
export default {
name: 'BusImg',
data () {
return {
// 視頻播放
playerOptions : {
playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
autoplay: false, //如果true,瀏覽器准備好時開始回放。
muted: false, // 默認情況下將會消除任何音頻。
loop: false, // 導致視頻一結束就重新開始。
preload: 'auto', // 建議瀏覽器在<video>加載元素后是否應該開始下載視頻數據。auto瀏覽器選擇最佳行為,立即開始加載視頻(如果瀏覽器支持)
language: 'zh-CN',
aspectRatio: '16:9', // 將播放器置於流暢模式,並在計算播放器的動態大小時使用該值。值應該代表一個比例 - 用冒號分隔的兩個數字(例如"16:9"或"4:3")
techOrder: ['flash', 'html5'], // 兼容順序
flash: {
hls: { withCredentials: false },
swf: 'static/video-js.swf' // 引入靜態文件swf
},
html5: { hls: { withCredentials: false } },
sources: [{ // 流配置,數組形式,會根據兼容順序自動切換
type: 'rtmp/hls',
src: 'rtmp://192.168.245.37:1935/mylive/test2'
}],
poster: "", //你的封面地址
// width: document.documentElement.clientWidth,
notSupportedMessage: '此視頻暫無法播放,請稍后再試', // 允許覆蓋Video.js無法播放媒體源時顯示的默認信息。
controlBar: {
timeDivider: true,
durationDisplay: true,
remainingTimeDisplay: false,
fullscreenToggle: true //全屏按鈕
}
}
</script>
踩坑:
- 如果需要播放 HLS 流,需要安裝 videojs-contrib-hls 插件
- 如果需要播放 RTMP 流,需要安裝 videojs-flash 插件
- 如果兩個流都需要播放,flash 插件需要安裝到 hls 插件之前
- 安裝vue-video-player插件一定要用npm安裝,不可使用cnpm安裝,否則會報“The "flash" tech is undefined. Skipped browser support check for that tech”
-
在chome上播放時,視頻窗口小於400*300 不會自動播放 在options里加上 flash: {swf: 'static/video-js.swf' // 引入靜態文件swf}, 下載video-js.swf