当前位置:Gxlcms > html代码 > HTML5CSS3模仿优酷视频截图功能示例

HTML5CSS3模仿优酷视频截图功能示例

时间:2021-07-01 10:21:17 帮助过:20人阅读

一般的视频网站对于用户上传的视频,在用户上传完成后,可以对播放的视频进行截图,然后作为视频的展示图。项目中也可以引入这样的功能给用户一种不错的体验,而不是让用户额外上传一张展示图。

效果图:



看起来还是很不错,下面我给大家分析下,极其核心代码很简单:



核心代码就这几行,利用了ctx.drawImage时,第一个参数可以为video对象,然后就是通过canvas拿到DataUrl,赋值给Img标签了。关键点就这些。

下面来看整个例子:

HTML:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title></title>
  5. <meta charset="utf-8">
  6. <style type="text/css">
  7. html
  8. {
  9. overflow: hidden;
  10. }
  11. body
  12. {
  13. background-color: #999;
  14. }
  15. video
  16. {
  17. display: block;
  18. margin: 60px auto 0;
  19. }
  20. #shotBar
  21. {
  22. position: absolute;
  23. bottom: 5px;
  24. height: 120px;
  25. width: 98%;
  26. background-color: #000;
  27. box-shadow: -5px -5px 10px #fff;
  28. border-radius: 5px;
  29. padding: 2px;
  30. overflow: auto;
  31. }
  32. #shotBar img
  33. {
  34. border: 3px solid #fff;
  35. border-radius: 5px;
  36. height: 110px;
  37. width: 210px;
  38. margin-left: 4px;
  39. }
  40. </style>
  41. <script type="text/javascript" src="../../../jquery-1.8.3.js"></script>
  42. <script type="text/javascript" src="videoshot.js"></script>
  43. <script type="text/javascript">
  44. $(function ()
  45. {
  46. ZhangHongyang.click2shot.init();
  47. });
  48. </script>
  49. </head>
  50. <body>
  51. <video src="media/style.mp4" controls id="video">
  52. </video>
  53. <p id="shotBar">
  54. </p>
  55. </body>
  56. </html>



html和css都是相当简单的。

主要看Js的代码:



需要注意的是,video.canplay事件中获取完属性和一些操作后,一定要removeEventLinstener,否则暂停播放会一直调用此方法。点击事件时,会暂停video,然后在video的位置生成一张图片,使用jquery动画移动到缩略图的位置,然后移除文档,缩略图显示,造成的动画效果。

得到图片之后的上传之类的操作,大家可以自己添加。还有很重要的一点:canvas.toDataURL("image/png");可能需要在服务器中访问才能正常使用,我把写好的页面拖到了tomcat中,大家可以随便启动个什么服务器,不然会报安全问题。

以上就是HTML5 CSS3模仿优酷视频截图功能示例 的内容,更多相关内容请关注PHP中文网(www.gxlcms.com)!

人气教程排行