摘要:一个长视频可能包含多个遮罩,每个遮罩有特定的显示时间在此时间外,隐藏该遮罩。前端实现视频遮罩有基于和基于两种技术方案,本文是使用完成的。由于事件只是基于元素,所以内部每个元素一个矩形,一个圆等的事件响应要利用坐标来自己代码完成。
作者:云荒杯倾
作者博客
为一个视频添加一个覆盖物,从而挡住视频某区域,在视频的某一时间段,比如第10到第20分钟不显示划定的这块区域。应用场景包括遮挡卫视图标、遮挡视频右下角广告、充当马赛克等。
一个长视频可能包含多个遮罩,每个遮罩有特定的显示时间(在此时间外,隐藏该遮罩)。
前端实现视频遮罩有基于div和基于canvas两种技术方案,本文是使用canvas完成的。
主要原理是在HTML的video标签上贴上一个透明的canvas图层,然后响应mousedown、mousemove、mouseup事件。
由于canvas事件只是基于canvas元素,所以canvas内部每个元素(一个矩形,一个圆等)的事件响应要利用坐标来自己代码完成。
https://github.com/cunzaizhuy...
演示地址http://htmlpreview.github.io/?https://github.com/cunzaizhuyi/maskPlugin/blob/master/mask/mask.html
实现的功能点画遮罩(矩形)
设置遮罩样式(提供API)
遮罩移动
遮罩缩放
canvas上鼠标样式变换
封装的API名称 | 值类型 | 说明 |
---|---|---|
1、矩形相关设置 | ||
fillStyle | 颜色值 | 矩形填充色, 默认为"#eeeeee" |
strokeStyle | 颜色值 | 矩形边界线颜色, 默认为"#0000ff" |
inRectCursor | 字符串 | 当鼠标处于某个小矩形内部时鼠标样式,默认为"move"。可以设置为"pointer"之类的。 |
2、矩形边界上的八个小矩形 相关设置 | ||
bRectsStrokeStyle | 颜色值 | 矩形边界上的小矩形的颜色,默认为"#0000ff" |
bSideLength | number | 矩形边界上小矩形的边长值,默认为6 |
3、遮罩时间相关 | ||
masksTime | 每个遮罩的开始显示时间和结束显示时间,一个遮罩对应一个矩形 |
masksTime举例:
[{ maskId: 1, startTime: 0, endTime: 10, }, {maskId: 2, startTime: 3, endTime: 13, }]应用效果图 最后
这个基于原生canvas的700多行的小插件,对于探索canvas的世界可能仅仅是一个开始。
关于这个小插件有任何疑问,欢迎大家交流。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/90617.html
摘要:谷歌是通过来实现这个组件的,比较复杂谷歌的工具加载文件和截图文件有兴趣的同学可以看一下。高亮区域核心部分截图搞定了,接下来就是高亮区域了。 几乎所有的APP应用包括Web应用都需要一个意见反馈,这样才能了解用户对产品的意见和建议,以便于不断提升完善自己的产品。目前的反馈组件一般有两种,一种是打开一个反馈页面填写表单,另一种则是通过弹窗来完成,相比较而言第二种更加方便,而且更加容易组件化...
摘要:主要实现功能在画布上跟随鼠标的按键移动画出拖拉范围内的矩形弹出选择项,选对勾则将这部分矩形填上背景色,选叉号则取消本次拖拉的矩形。附业务目的视频遮罩是一种将视频某部分区域遮盖的效果,可用于遮盖电视台图标,广告,镜头内敏感部分等。 作者:云荒杯倾 序 本意是用这个做视频遮罩效果,但是还是从更通用的角度来解释事情本身吧。少掺杂一点业务目的。 主要实现功能 在canvas画布上跟随鼠标的按键...
摘要:转载来源包管理器管理着库,并提供读取和打包它们的工具。能构建更好应用的客户端包管理器。一个整合和的最佳思想,使开发者能快速方便地组织和编写前端代码的下一代包管理器。很棒的组件集合。隐秘地使用和用户数据。 转载来源:https://github.com/jobbole/aw... 包管理器管理着 javascript 库,并提供读取和打包它们的工具。•npm – npm 是 javasc...
阅读 1382·2021-10-14 09:43
阅读 972·2021-09-10 10:51
阅读 1423·2021-09-01 10:42
阅读 2172·2019-08-30 15:55
阅读 563·2019-08-30 15:55
阅读 2325·2019-08-30 14:21
阅读 1678·2019-08-30 13:04
阅读 3450·2019-08-29 13:09