189 8069 5689

怎么在HTML5中自定义一个视频播放器-创新互联

这期内容当中小编将会给大家带来有关怎么在HTML5中自定义一个视频播放器,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:申请域名雅安服务器托管、营销软件、网站建设、肥东网站维护、网站推广。

video对象

兼容性写法


        
        
        
        您的浏览器不支持,请升级您的浏览器
    

video 标签 width height autoplay muted

poster带有预览图(海报图片)的视频播放器

选中video标签

var VideoNode = document.getElementById('myVideo');

src控制视频的来源

VideoNode.src = 'data/demo.ogv';

手动设置控件 controls

VideoNode.controls = true;

设置视频音量

VideoNode.volume = 0.5;

currentTime当前播放时间

快进效果

gogogo.onclick = function(){
            VideoNode.currentTime = VideoNode.currentTime + 3;
        };

暂停 pause()

  stopNode.onclick = function(){
            VideoNode.pause();
        };

播放play()

 playNode.onclick = function(){
            VideoNode.play();
        };

load 刷新播放器的事件

  reloadNode.onclick = function(){
            VideoNode.src = 'data/demo.mp4';
            VideoNode.load();
        };

canplay 视频已经加载好 可以开始播放了

 VideoNode.addEventListener('canplay',function(){
            console.log('视频已经加载好 可以开始播放了');
        });

requestFullscreen 让video标签变成全屏

VideoNode.webkitRequestFullscreen();
VideoNode.mozRequestFullScreen();

        fullScreenNode.onclick = function(){
            if(VideoNode.webkitRequestFullscreen){
                VideoNode.webkitRequestFullscreen();
            }
            else if(VideoNode.mozRequestFullScreen){
                VideoNode.mozRequestFullScreen();
            }
        };

volumechange 当音量更改时

VideoNode.onvolumechange = function(){
            console.log('volumechange');
        };

声音随机更改

volumeNode.onclick = function(){
            VideoNode.volume = Math.random();
        };

seeking 当用户开始拖动进度条时 就会触发的事件

 var seekingNum = 0;
        VideoNode.onseeking = function(){
            console.log('seeking...');
            seekingNum++;
            seeking.innerHTML = seekingNum;
        };

seeked 当用户对视频的进度条并且已经完成操作时会触发的事件

   var seekedNum = 0;
        VideoNode.onseeked = function(){
            console.log('seeked...');
            seekedNum++;
            seeked.innerHTML = seekedNum;
        };

timeupdate监听视频播放的状态

   VideoNode.addEventListener('timeupdate',function(){
            // 总时长,以分钟:秒的形式显示
            let allTime = parseInt(VideoNode.duration/60)+':'+parseInt(VideoNode.duration%60);
            // 当前时间,以分钟:秒的形式显示
            let nowTime = parseInt(VideoNode.currentTime/60)+':'+parseInt(VideoNode.currentTime%60);
            timeNode.innerHTML = nowTime+'/'+allTime;
        })

readyState 视频的准备信息

  console.log(VideoNode.readyState);
        setTimeout(function(){
            console.log(VideoNode.readyState);
        },500);

playbackRate 查看或设置视频的一个播放速度

 console.log(VideoNode.playbackRate)

Rate设置倍速

//Rate设置0.5倍速
        RateNode.children[0].onclick = function(){
            VideoNode.playbackRate = 0.5;
        };
        //Rate设置1倍速
        RateNode.children[1].onclick = function(){
            VideoNode.playbackRate = 1;
        };
        //Rate设置2倍速
        RateNode.children[2].onclick = function(){
            VideoNode.playbackRate = 2;
        };

loop的设置

 loopNode.onclick = function(){
            if(VideoNode.loop == false){
                this.innerHTML = '循环';
                VideoNode.loop = true;
            }
            else{
                this.innerHTML = '不循环';
                VideoNode.loop = false;
            }
        };

src返回的数据

console.log('src='+VideoNode.src);

currentSrc返回的数据

console.log('currentSrc='+VideoNode.currentSrc);

监听ended事件

VideoNode.addEventListener('ended',function(){
            console.log('视频播放结束了');
            VideoNode.play();
        })

查看视频的网络状态

console.log(VideoNode.networkState)

手动设置控件 controls

VideoNode.controls = true;

手动设置静音 muted

VideoNode.muted = true;

自定义视频播放器

怎么在HTML5中自定义一个视频播放器

放图

 
 
 
     
     
    
*{margin: 0;padding: 0;list-style: none;} 
.outerNode{width: 540px;height: 332px;position: absolute;left: 50%;top: 50%;margin: -166px 0 0 -270px;box-shadow: 0 0 4px #5b606d;}  
.outerNode .videoNode{
    width: 540px;height: 305px;float: left;
    background: black;
}     
.outerNode .controlsNode{
    width: 540px;height: 27px;float: left;background: url(images/ctrs_bg.gif) repeat-x;
}
.outerNode .controlsNode .playNode{
    float: left;width: 15px;height: 17px;margin: 6px 0 0 14px;
    background: url(images/playNode.png) no-repeat;cursor: pointer;
}
.outerNode .controlsNode .pauseNode{
    float: left;width: 15px;height: 17px;margin: 6px 0 0 14px;
    background: url(images/pause.png) no-repeat;cursor: pointer;
}
.outerNode .controlsNode .loadNode{width: 267px;height: 10px;margin: 9px 0 0 14px;float: left;background: url(images/load_bg.png) repeat-x;position: relative;}
.outerNode .controlsNode .loadNode .lineNode{
    width: 0%;height: 7px;position: absolute;left: 0;top: 1px;
    background: url(images/line_bg.png) repeat-x;
}
.outerNode .controlsNode .loadNode .lineNode .lineRight{
    width: 2px;height: 100%;position: absolute;right: 0;top: 0;
    background: url(images/line_r_bg.png) no-repeat;
}
.outerNode .controlsNode .loadNode .loadLeft{
    height: 100%;width:3px ;position: absolute;left: 0;top: 0;
    background: url(images/left_bg.png) no-repeat;z-index: 4;
}
.outerNode .controlsNode .loadNode .loadRight{
    height: 100%;width:3px ;position: absolute;right: 0;top: 0;
    background: url(images/right_bg.png) no-repeat;
}
.outerNode .controlsNode .loadNode .crlNode{width: 17px;height: 17px;background: url(images/crl_bg.png);position: absolute;left: -8.5px;top: -3.5px;cursor: pointer;z-index: 5;}
.outerNode .controlsNode .timeNode{
    float: left;width: 75px;height: 10px;margin: 9px 0 0 9px;
}
.outerNode .controlsNode .timeNode span{font-size:10px;float: left;line-height: 10px;color: white; }
.outerNode .controlsNode .volumeNode{
    width: 17px;height: 16px;float: left;margin: 5px 0 0 6px;
    background: url(images/volume_bg.png);
}
.outerNode .controlsNode .volumeLine{
    height: 8px;width: 61px;float: left;margin: 10px 0 0 4px;
    background: url(images/volumeLine_bg.png) repeat-x;position: relative; 
}
.outerNode .controlsNode .volumeLine .v_left{
    width: 3px;height:100%;position: absolute;left: 0;top: 0;background: url(images/v_left.png) no-repeat;
}
.outerNode .controlsNode .volumeLine .v_right{
    width: 3px;height:100%;position: absolute;right: 0;top: 0;background: url(images/v_right.png) no-repeat;
}
.outerNode .controlsNode .volumeLine .v_DragNode{width: 15px;height: 13px;position: absolute;left: 58.5px;top: -3.5px;background: url(images/vo_d.png) no-repeat;cursor: pointer;}
.outerNode .controlsNode .fullNode{
    width:15px;height:17px;float: left;margin: 6px 0 0 35px;
    background: url(images/full_bg.png) no-repeat;cursor: pointer;
    transition: 0.7s;
}
.outerNode .controlsNode .fullNode:hover{
    background: url(images/full_hover_bg.png) no-repeat;
}
    


    
    
        
        
        
        
            
            
                                          
                
                                                                                                                                                                 00:00                  -                  4:30                                                                                                                                                                              //播放暂停的控制     //PlayNode 播放器按钮     //VideoNode 播放器     //PlayBln 控制暂停播放的布尔值     //FullNode 全屏按钮     //nowNode 当前时间     //allNode 视频的全部时间     //LineNode 当前的进度条     //CrlNode 进度条按钮     //LoadNode 进度条外面的元素     var PlayNode = document.getElementsByClassName('playNode')[0],         VideoNode = document.getElementsByClassName('videoNode')[0],         FullNode = document.querySelector('.fullNode'),         nowNode = document.querySelector('.now'),         allNode = document.querySelector('.all'),         LineNode = document.querySelector('.lineNode'),         CrlNode = document.querySelector('.crlNode'),         LoadNode = document.querySelector('.loadNode'),         VDragNode = document.querySelector('.v_DragNode'),         PlayBln = true;     //播放、暂停的事件     PlayNode.onclick = function(){         //传统的通过布尔值去改变classname的方法         PlayBln = !PlayBln;         if(PlayBln == false){             this.className = 'pauseNode';             VideoNode.play();         }         else{             this.className = 'playNode';             VideoNode.pause();         }     };     //全屏按钮的事件     FullNode.onclick = function(){         if(VideoNode.webkitRequestFullscreen){             VideoNode.webkitRequestFullscreen();         }         else if(VideoNode.mozRequestFullScreen){             VideoNode.mozRequestFullScreen();         }         else{             VideoNode.requestFullscreen();         }     };     //解决最开始时间的NAN的问题     VideoNode.addEventListener('canplay',function(){         var needTime = parseInt(VideoNode.duration);         var  s = needTime%60;         var  m = parseInt(needTime / 60);         var timeNum = toDou(m)+':'+toDou(s);         allNode.innerHTML = timeNum;     },false);     //解决 时间不足10 的问题     function toDou(time){         return time<10?'0'+time:time;     }     //当视频播放的时候 需要当前的时间动起来     VideoNode.addEventListener('timeupdate',function(){         //目前的 百分比进度         LineNode.style.width = VideoNode.currentTime/VideoNode.duration*100+'%';         CrlNode.style.left = LineNode.offsetWidth - 8.5 + 'px'         var needTime = parseInt(VideoNode.currentTime);         var  s = needTime%60;         var  m = parseInt(needTime / 60);         var timeNum = toDou(m)+':'+toDou(s);         nowNode.innerHTML = timeNum;     },false);     //声音的拖拽按钮     VDragNode.onmousedown = function(e){         var ev = e || event;         var l = ev.clientX - this.offsetLeft;         document.onmousemove = function(e){             var ev = e || event;             var needX = ev.clientX - l;             var maxX = VDragNode.parentNode.offsetWidth - 2.5;             needX = needX < -2.5 ? - 2.5 : needX;             needX = needX > maxX ? maxX : needX;             //计算0 - 1             var lastVolume = (VDragNode.offsetLeft + 2) / VDragNode.parentNode.offsetWidth ;             VideoNode.volume = lastVolume < 0 ? 0 : lastVolume;             VDragNode.style.left = needX + 'px';         };         document.onmouseup = function(e){             document.onmousemove = document.onmouseup = null;         }         return false;     }     //拖拽进度条按钮     CrlNode.onmousedown = function(e){         var ev = e || event;         var l = ev.clientX - this.offsetLeft;         VideoNode.pause();         document.onmousemove = function(e){             var ev = e || event;             var needX = ev.clientX - l;             var maxX = LoadNode.offsetWidth - 8.5;             needX = needX < -8.5 ? -8.5 : needX;             needX = needX > maxX ? maxX : needX;             CrlNode.style.left = needX + 'px';             LineNode.style.width = (CrlNode.offsetLeft+9)/LoadNode.offsetWidth*100 + '%';         };         document.onmouseup = function(){             document.onmousemove = document.onmouseup = null;             VideoNode.currentTime = VideoNode.duration * (CrlNode.offsetLeft+9)/LoadNode.offsetWidth;             if(PlayBln == false){                 //console.log(1);                 PlayNode.className = 'pauseNode';                 VideoNode.play();             }             else{                 //console.log(2);                 PlayNode.className = 'playNode';                 VideoNode.pause();             }         };         return false;     };

上述就是小编为大家分享的怎么在HTML5中自定义一个视频播放器了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。


网站名称:怎么在HTML5中自定义一个视频播放器-创新互联
浏览地址:http://gzruizhi.cn/article/csisjo.html

联系我们

您好HELLO!
感谢您来到宜宾网站建设公司,若您有合作意向,请您为我们留言或使用以下方式联系我们, 我们将尽快给你回复,并为您提供真诚的设计服务,谢谢。
  • 电话:028- 86922220 18980695689
  • 商务合作邮箱:631063699@qq.com
  • 合作QQ: 532337155
  • 成都网站设计地址:成都市青羊区锣锅巷31号五金站写字楼6楼

冠赛建站工作室

宜宾冠赛网站建设公司拥有多年以上互联网从业经验的团队,始终保持务实的风格,以"帮助客户成功"为已任,专注于提供对客户有价值的服务。 我们已为众企业及上市公司提供专业的网站建设服务。我们不只是一家网站建设的网络公司;我们对营销、技术、管理都有自己独特见解,冠赛建站采取“创意+综合+营销”一体化的方式为您提供更专业的服务!

冠赛观点

相对传统的宜宾网站建设公司而言,冠赛是互联网中的网站品牌策划,我们精于企业品牌与互联网相结合的整体战略服务。
我们始终认为,网站必须注入企业基因,真正使网站成为企业vi的一部分,让整个网站品牌策划体系变的深入而持久。