我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Html5中video获取第一帧怎么作为封面

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Html5中video获取第一帧怎么作为封面

这篇文章主要介绍Html5中video获取第一帧怎么作为封面,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

1.引入库

代码如下(示例):

<script class="lazy" data-src="https://cdn.bootcdn.net/ajax/libs/jquery/1.10.0/jquery.min.js"></script>

2.HTML部分

<p class="upload-title mg-b10 title-all">上传视频(必填)</p>  <p class="file-input-trigger" onclick="document.getElementById('uploadBtn').click()">     <p class="upload-icon">+</p>     <p class="upload-text">上传文件</p>   </p>   <input type="file" class="upload-video" id="uploadBtn"> </p>

展示效果如下图,样式的话,自己写哈,我比较懒,哈哈哈哈

Html5中video获取第一帧怎么作为封面

<video class="lazy" data-src="" onloadeddata='vSetImg(this)' autoplay></video><img class="lazy" data-src="" class="video-img" alt="">

上面这部分代码是展示图片,效果如下,图片显示正常

Html5中video获取第一帧怎么作为封面

3.JS部分

let result$('#uploadBtn').on('change', function (e) {    const file = e.target.files    // console.log(file)    let fr = new FileReader()    fr.readAsDataURL(file[0]) //将文件读取为tata Url    fr.onload = function (e) {        result = e.target.result        // 视屏上传        if (/video/g.test(file[0].type)) {            $('.upload-img').show()            $('.upload-img video').attr('class="lazy" data-src', result)            $('.upload-file').hide()         }     }})function vSetImg(obj) {     $(obj).removeAttr("poster");     var vimg = $("<img/>")[0];     captureImage(obj, vimg);     $(obj).attr("poster", $(vimg).attr("class="lazy" data-src"));     //展示获取的第一帧图片     $(".upload-img img").attr("class="lazy" data-src", $(vimg).attr("class="lazy" data-src"));     $('.upload-img video').hide()     $('.upload-img img').show()}function captureImage(video, output) {     const scale = 0.8     try {         var videocanvas = $("<canvas/>")[0];         videocanvas.width = video.videoWidth * scale;         videocanvas.height = video.videoHeight * scale;         videocanvas.getContext('2d').drawImage(video, 0, 0, videocanvas.width, videocanvas.height);         output.class="lazy" data-src = videocanvas.toDataURL("image/png");         delete videocanvas;     } catch (e) {         output.class="lazy" data-src = "加载动画.gif";     }}

其中video标签上的属性autoplay是必要的,不然可能会图片显示不出来,这是我实验几次发现的。我是使用了jquery,为了操作元素方便,当然用原生的也可以。

以上是“Html5中video获取第一帧怎么作为封面”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Html5中video获取第一帧怎么作为封面

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Html5中video获取第一帧怎么作为封面

这篇文章主要介绍Html5中video获取第一帧怎么作为封面,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.引入库代码如下(示例):