这几天在写公司的h5视频播放页面,收获了不少东西。
首先,我需要支持flv和mp4格式的视频。本来想用开源插件flv.js把flv的转换成手机浏览器mp4格式视频,结果不幸的是,两月以前各大手机浏览器更新了内核,不支持flv.js这个插件了(除了chrome浏览器)。但PC端还是可用的。
下面说重点,怎么自定义播放条样式。
首先放出成品图:
html代码:
<video data-icon="0" src="" data-state="a" style="width:100%;height:13.1875rem;" id="videoBox" webkit-playsinline playsinline></video>//video标签 <div class="btnPlay"><img class="left" src="images/playBagin.png" alt="" data-icon="0"><p class="progressTime left">0:00</p></div>//开始按钮div <div class="progressBox" id="progressBox_special"> <div class="progressBar"></div>//蓝条进度条div <div class="imgBox"><img id="progressImg" src="images/progressPointer.png" alt=""></div></div>//进度条拖拉图片divBox <div class="biggerBtn" data-icon="0"><img class="right" src="images/allBigger.png" alt=""><p class="allTime right"></p></div></div>//全屏div
注:<video>标签之所以加上webkit-playsinline,playsinline两个属性,就是为了保证不同浏览器支持视频在h5页面中播放,不用手机浏览器自动托管视频。
css一些问题:
由于<video>标签默认层级最高,可设置播放条div的z-index在最上面。
用的还是jQuery库,下面放js代码:
<video>标签的API还是很全面的,不过需要通过dom本身调用。
视频总时间和播放的时间:
var video = document.getElementById("video"); var video2 = $("#video"); //视频总时间 video2.on(‘loadedmetadata‘, function() { var time = video.duration; $(‘.allTime‘).text(time.toFixed(2)); }); //视频进度时间 video2.on(‘timeupdate‘, function() { var time = video.currentTime,alltime = video.duration; var percentage = 100 *(time / alltime); $(‘.progressTime‘).text(time.toFixed(2)); $(‘.progressBar‘).css({‘width‘:percentage + ‘%‘}); $(‘.stateBox .progressBox .imgBox img‘).css({‘margin-left‘:percentage +‘%‘}); if(time == alltime){ $(‘.btnPlay img‘).attr(‘src‘,‘images/playBagin.png‘); //如果播放时间到总时间播放按钮图片换成停止图片 } });
点击播放按钮:
//视频开始按钮事件 $(‘.btnPlay img‘).on(‘touchend‘,function(){ if(video.paused) { video.play(); $(this).attr(‘src‘,‘images/pause_btn.png‘); }else { video.pause(); $(this).attr(‘src‘,‘images/playBagin.png‘); } return false; })
拖拉进度条:
//拖拉函数 function changeBar(item){ var progress = $(‘.progressBox‘); var maxduration = video.duration; //视频总时间 var barIcon = $(‘.nav .biggerBtn‘).attr(‘data-icon‘),position,percentage; if(barIcon == 0){ position = item - progress.offset().left; //横屏模式 }else{ position = item - progress.offset().top; //全屏竖屏模式 } percentage = 100 * (position / progress.width()); if(percentage > 100) { percentage = 100; } if(percentage < 0) { percentage = 0; } $(‘.progressBar‘).css(‘width‘, percentage+‘%‘); $(‘.stateBox .progressBox .imgBox img‘).css({‘margin-left‘:percentage +‘%‘}); video.currentTime = maxduration * (percentage / 100);//视频进度时间传给当前时间 video.play(); $(‘.btnPlay img‘).attr(‘src‘,‘images/pause_btn.png‘); } //视频拖拉按钮事件 var progressBox = document.getElementById(‘progressBox_special‘); progressBox.addEventListener(‘touchstart‘, progressBox_item, false); function progressBox_item(e){ var barIcon = $(‘.nav .biggerBtn‘).attr(‘data-icon‘); var point = fristPoint(e); if(barIcon == 0){ changeBar(point.pageX); }else{ changeBar(point.pageY); } };//拖拉按钮var statePic = document.getElementById(‘progressImg‘); statePic.addEventListener(‘touchmove‘, itemMove, false);//发现h5的touchmove行为要通过addEventListener注册 function itemMove(e){ e.stopPropagation();//阻止默认行为 var barIcon = $(‘.nav .biggerBtn‘).attr(‘data-icon‘); var point = fristPoint(e); if(barIcon == 0){ changeBar(point.pageX);//横屏 }else{ changeBar(point.pageY); //全屏竖屏 } }; //第一个手指为准 function fristPoint(e){ return e.touches ? e.touches[0] : e; }
点击全屏:
//点击全屏 var itemHeight = document.documentElement.clientHeight;//获取手机高度 var itemWidth = document.documentElement.clientWidth;//手机宽度 $(‘.biggerBtn img‘).on(‘touchend‘,function(event){ event.stopPropagation(); var dataIcon = $(this).parent().attr(‘data-icon‘); if(dataIcon == 0){ $(‘.nav‘).css({‘-webkit-transform‘:‘rotate(90deg)‘});//直接把视频旋转90°,给video高度宽度重新赋值。 $(‘.nav video‘).css({‘width‘:itemHeight,‘height‘:itemWidth}); $(‘.stateBox‘).css({‘width‘:itemHeight}); $(‘.biggerBtn‘).attr(‘data-icon‘,‘1‘); $(‘.nav video‘).attr(‘data-icon‘,‘1‘); }else{ $(‘.nav‘).css({‘-webkit-transform‘:‘rotate(0deg)‘}); $(‘.nav video‘).css({‘width‘:itemWidth,‘height‘:‘13.1875rem‘}); $(‘.stateBox‘).css({‘width‘:itemWidth}); $(‘.biggerBtn‘).attr(‘data-icon‘,‘0‘); $(‘.nav video‘).attr(‘data-icon‘,‘0‘); } });
时间: 2024-12-31 14:55:32