vue專案中自定義video視訊控制條的實現程式碼
最近公司專案中,添加了視訊模組,但是產品覺得Video自帶的控制條有點LOW,於是自己設計了一個。於是開始了自定義Video控制的採坑之旅。。
首頁效果圖:
需求描述:
當滑鼠放在圖片上的時候,自動播放視訊,並顯示預覽進度條,當滑鼠移開,顯示預覽圖片,再次hover圖片,繼續上次播放
視訊詳情頁的效果圖:
需求描述:
- 能自定義的暫停和播放
- 模仿進度條可實現拖拽播放速度
- 顯示當前時間
- 能選擇倍速
- 能控制聲音
- 能全屏播放
接下來一步步的實現
首先康康首頁的,上結構程式碼:
<div class="clickL video-box" @mouseover="play(item3.images_id)" @mouseout="pause(item3.images_id)"> <img v-lazy="item3.picture" width="268" alt="vue專案中自定義video視訊控制條的實現程式碼" v-show="id != item3.images_id"> <video class="video-hover" ref="videoAll" onMouseOver="this.play()" :src="item3.short_video" @timeupdate="commonVideoUpdata(index)" width="268px" height="176px" onMouseOut="this.pause()" muted loop="loop"> </video> </div> <div class="process-slider common-progress" v-show="id == item3.images_id"> <el-slider v-model="currentTimeProgress" :show-tooltip="false" input-size="small"></el-slider> </div>
這裡思路是:
1,判斷使用者滑鼠事件,切換圖片和視訊。
2.video需要通過video來獲取他例項來進行dom操作,video的滑鼠移入和滑出分類是控制視訊的播放和停止,play和pause是video的內建方法。 更多方法見這裡哦~
3.這裡的進度條使用的是element的滑動條元件,預設max是100,顯示視訊的時候,這裡用v-show判斷顯隱。
css部分程式碼:
.video-box { position: relative; height: 176px; &>img { width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 2; } &>video { object-fit: fill; //拉伸填充盒子,保證和圖片一樣大 } }
css部分主要是要注意讓video顯示的時候和圖片的寬高一致,不然就會出現圖片大,視訊小的情況,如圖:
邏輯部分:
data() { return { id:0,//儲存當前播放的視訊id currentTimeVal:0 //進度條 } },methods:{ //開始播放 play(val) { this.id = val },// 停止播放,顯示圖片清零進度條 pause(val) { this.id = 0 this.currentTimeVal = 0 },// 公共video獲取時間 commonVideoUpdata(id) { let videoObj = this.$refs.videoAll console.log(videoObj); let currTime = videoObj[id].currentTime //當前時間 let duration = videoObj[id].duration //總時間 let pre = currTime / duration this.currentTimeProgress = pre * 100; },}
這裡使用video 的timeupdate內建方法獲取當前播放時間,並獲取當前的的dom元素,這裡的videoObj打印出來是個陣列:
我們通過當前元素在陣列中迴圈出來的索引來獲取對應視訊的時間,最後一個簡單的計算進度條的方法,(當前時間 / 總時間)* 100 = 進度條的值
注意坑點
:如果在陣列中摻雜了其他的非視訊檔案,這裡使用ref的方式,就不能根據索引來獲取,就得定義唯一的ref,嘿嘿!
到此首頁功能結束了,接著實現詳情頁的自定義控制條。
html部分:
<div class="detali_box_img video-media"> <div class="video-example"> <video :src="item.video_file" width="100%" height="100%" loop="loop" preload="auto" @timeupdate="videoTimeUpdate" @click="controlVideo" ref="videoCon"> 您的瀏覽器不支援 video 標籤。 </video> </div> //視訊中的暫停按鈕 <div class="play-btn" @click="controlVideo" :style="[opcityVal]"></div> // 控制條的播放和暫停按鈕 <div class="control-play"> <p class="control-play-btn" @click="controlVideo"> <span class="el-icon-video-play" v-show="!vcIsPlay"></span> <span class="el-icon-video-pause" v-show="vcIsPlay"></span> </p> //播放進度條 <div class="control-progress common-progress"> <div> <el-slider v-model="vcProgress" :show-tooltip="false" :max="durationProgress" input-size="small" @change="getNewTime"></el-slider> </div> <!-- <p class="control-progress-item"></p> --> </div> //當前播放時間 <div class="current-time">{{vcCurrentTime}}</div> //視訊總時長 <div class="duration">{{item.duration_time}}</div> //倍速控制 <div class="video-speed-box" @click="getPlayBackRate"> <el-dropdown placement="bottom" @command="handleCommand"> <!-- <span class="el-dropdown-link"> --> <span class="video-speed-show">{{speedTime}}</span> <!-- </span> --> <el-dropdown-menu slot="dropdown"> <el-dropdown-item command="1">0.5x</el-dropdown-item> <el-dropdown-item command="2">1x</el-dropdown-item> <el-dropdown-item command="3">1.5x</el-dropdown-item> <el-dropdown-item command="4">2x</el-dropdown-item> <el-dropdown-item command="5">3x</el-dropdown-item> </el-dropdown-menu> </el-dropdown> </div> //音量控制 <div class="control-voice common-progress"> <span class="voice-icon"></span> <div class="voice-slider"> <el-slider v-model="voiceProgress" input-size="small" @change="getNewVoice"></el-slider> </div> </div> //全屏播放 <p class="fullscreen" title="全屏" @click="getFullSceen"> <span class="el-icon-full-screen"></span> </p> </div> </div>
css部分忽略了。。。
直接看功能:首先data部分:
vcIsPlay: false,//是否播放 opcityVal: { opacity: '1' },currentTimeVal: 0,// 當前時間 vcCurrentTime: '00:00:00',//當前時間格式化 vcProgress: 0,//進度條的繫結時間 durationProgress: 0,//當前視訊的總時長 speedTime: '1x',//倍速 voiceProgress: 0 //聲音
暫停和播放:
// 播放和暫停視訊 controlVideo() { let videoObj = this.$refs.videoCon this.durationProgress = videoObj[0].duration //總時間 if (this.vcIsPlay) { videoObj[0].pause() } else { videoObj[0].play() } this.vcIsPlay = !this.vcIsPlay this.opcityVal.opacity = this.opcityVal.opacity == '1' ? '0' : '1' },
直接呼叫提供的兩個方法即可,然後使用vue的style繫結控制暫停按鈕的顯隱即可,這裡的進度條,我換了種玩法,同樣是element的滑動條元件,只不過max值我換成了總時長,單位秒,原因請耐心看下文,嘿嘿!
進度條部分:
// 獲取時間 videoTimeUpdate() { let videoObj = this.$refs.videoCon let currTime = videoObj[0].currentTime //當前時間 this.vcProgress = currTime //賦值給進度條 this.vcCurrentTime = this.getFormatVideoTime(currTime) console.log(this.vcCurrentTime) //"00:00:27" },//格式化時間 getFormatVideoTime(time) { let curtime = time let h = parseInt(curtime / 3600) let m = parseInt((curtime % 3600) / 60) let s = parseInt(curtime % 60) h = h < 10 ? '0' + h : h m = m < 10 ? '0' + m : m s = s < 10 ? '0' + s : s return h + ':' + m + ':' + s },
這裡難點是,我如何進行拖動進度條,來進行控制呢?
別慌,看 程式碼:
@change="getNewTime" //element 的滑動元件有個chang事件 getNewTime(val) { let videoObj = this.$refs.videoCon console.log(val) videoObj[0].currentTime = val },
通過change進度條,然後重新賦值給當前時間就搞定了,可以說是炒雞舒服了
倍速部分:
// 獲取當前播放的速度 handleCommand(val) { let videoObj = this.$refs.videoCon switch (val) { case '1': videoObj[0].playbackRate = 0.5 this.speedTime = '0.5x' break case '2': videoObj[0].playbackRate = 1 this.speedTime = '1x' break case '3': videoObj[0].playbackRate = 1.5 this.speedTime = '1.5x' break case '4': videoObj[0].playbackRate = 2 this.speedTime = '2x' break case '5': videoObj[0].playbackRate = 3 this.speedTime = '3x' break default: videoObj[0].playbackRate = 1 this.speedTime = '1x' break } },
看圖:
這裡使用的是element的下拉元件,同樣,Video的playbackRate可以直接賦值,控制播放速度
聲音部分:
// 設定聲音 getNewVoice(val) { let videoObj = this.$refs.videoCon let newVc = val / 100 //h5規定,volume的值必須再0-1之間,比如0.5就是50%的音量,但是進度條的值為100,因此這裡做個除法 videoObj[0].volume = newVc //賦值 },
我也是使用的滑元件,max值保持預設的100,然後滑動改變的時候,把預設值除100,比如當前滑塊的新值是50,除100後得到的就是【0-1】範圍裡的合法值,Video提供的volume值如果不在 0-1之間,就會報錯
最後是全屏部分:
// 全屏播放 getFullSceen() { let videoObj = this.$refs.videoCon videoObj[0].webkitRequestFullScreen() },
但是我看到網上還有一種方法是模擬按下f11的全部,如果有興趣也可以瞭解下!
總結
因為之前沒有很仔細的搞過video,所以對它很多的內建屬性和方法不瞭解,沒經驗就害怕,很慌很慌,這就跟談戀愛似的,哈哈哈,再組長的支援和鼓勵下,我大膽的嘗試了,成功後,這次經驗給了我很大信心,感覺以後寫其他沒做過的功能,都不會慌了,畢竟難的部分寫elementUi的大佬們都給寫好了,可以說是站在巨人的肩膀上,哈哈哈!膜拜大佬,以後還得多多努力了。
到此這篇關於vue專案中自定義video視訊控制條的實現程式碼的文章就介紹到這了,更多相關vue 自定義video視訊控制條內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!