H5的video视频播放标签。基础常用功能实现

效果如图,有几个小功能;视频自己准备本地视频就好,格式要MP4格式。

相关知识可参考:https://blog.youkuaiyun.com/cxws110/article/details/84138572?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522159126217119725247649177%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=159126217119725247649177&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~first_rank_v2~rank_v25-5-84138572.nonecase&utm_term=video%E4%BD%BF%E7%94%A8

完整demo。复制就可运行。

 

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <style>

    #durationbar{

        width: 100%;

        height: 5px;

    }

    #durationbar progress{

        width: 100%;

        height: 100%;

    }

    #positionBar{

        height:3px;

        /* background:#fff; */

    }

    .media::-webkit-media-controls {

        display:none !important;

    }

    button{

        margin-top:5px;

    }

    </style>

</head>

<body>

    <div>

        

        <button id='btn'>切换控件显示</button>

        <button id="start">开始</button>

        <button id="end">停止</button>

        <button id="pause">暂停</button>

        <button id="speed">2倍速度</button>

        <button id='jump'>跳转到1分钟</button>

        <button id='his'>获取当前观看的进度时间</button>

        

        <video id="media" class='' src="./video/111.mp4" controls   width="100%" height="200px" preload="metadata" poster="./img/1.jpg"></video>

 

        <div id="durationbar">

            <progress id="positionBar" value="0" max="100"></progress>

        </div>

        <!-- <div id='yt' style="width:100%;height:200px;background:url('./img/2.jpg');background-size: cover;">

            我是原图

        </div> -->

        <!-- <img id='yt' src="http://a2.att.hudong.com/53/51/16300000178518124461515846560_950.jpg" alt="" width='300px'> -->

        <div id='jt'>

            <p>我在这里放截图</p>

           <canvas id='can'></canvas>

        </div>

        

    </div>

    

<script type="text/javascript"> 

 

    var oVideo = document.getElementById('media');//获取media对象

 

    var jt=document.getElementById('jt')

//poster:封面图片

    var canvas=document.getElementById("can");//创建canvas对象

    var ctx=canvas.getContext('2d');  

  //监听加载

      oVideo.addEventListener('loadeddata',function(){

        canvas.width=oVideo.width*2;

        canvas.height=oVideo.height*2;

        canvas.style.width=jt.offsetWidth+"px";

        canvas.style.height=oVideo.height+"px";

        ctx.scale(2,2);

        ctx.drawImage(oVideo,0,0);

        console.log(oVideo.width,"1111",jt.offsetWidth) 

 

       console.log(oVideo.width,"1111",canvas.toDataURL("image/png")) 

      })

 

   

   

 

   


 

        

    var btn=document.getElementById('btn');

    btn.οnclick=function(){

        if(oVideo.className===''){

            oVideo.className="media"

        }else{

            oVideo.className=""

        }

    

    }

    

 

    var oStart = document.getElementById('start');//开始

    var oEnd = document.getElementById('end');//停止

    var oPause = document.getElementById('pause');//暂停

    var oSpeed = document.getElementById('speed');//加速

    

    // 开始函数

    oStart.οnclick=function(){

        oVideo.play();

        console.log("onclick"==="οnclick","o"==="o","onclick","onclick",typeof "ο","onclick"==="οnclick","onclick"==="οnclick")

    }

   

    // 停止函数

    oEnd.οnclick=function(){

        oVideo.pause();

        oVideo.currentTime=0;

    }

     // 暂停函数

    oPause.οnclick=function(){

        oVideo.pause();

    }

    // 加速函数

    oSpeed.οnclick=function(){

        oVideo.play();

        oVideo.playbackRate = 4;//注意这里速度大于4的时候,就没有声音了,声音得不到同步

    }

    //跳转到1分钟,指定时间,单位秒

    document.getElementById('jump').οnclick=function(){

        oVideo.currentTime=60;

        console.log("视频总时间",oVideo.duration)

    }

    //获取当前观看的时间

    document.getElementById('his').οnclick=function(){

        console.log(oVideo.currentTime)

    }

 

    // 这个事件是在视频播放中一直执行的事件

    oVideo.οntimeupdate=function(){

        var oPositionBar = document.getElementById('positionBar');

        oPositionBar.value= (oVideo.currentTime/oVideo.duration*100);

    }

        

</script>

</body>

</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值