博客
关于我
h5 video视频播放的同时加水印,图片加水印同样的原理
阅读量:203 次
发布时间:2019-02-28

本文共 747 字,大约阅读时间需要 2 分钟。

经常能看到播放视频的网站上加水印的效果,记录下成果以备后续看:

效果图如下:

在这里插入图片描述
h5页面视频播放的同时加水印,有以下3种方法可尝试:

  1. 在原视频上添加,由于每次登陆的用户不一样,需要根据用户名动态确定水印的文本值。这并不现实;
  2. 捕捉视频的每一帧,重新画在画布上,并添加水印。效果不太理想。捕捉到的帧失真严重;
  3. 和视频同一个页面,在其上边加类似蒙版,完美解决。

最终用方案3完美解决,源码如下:

风光无限好

方案2也尝试了下: 读取视频帧每一帧添加水印后,然后画在画布上;视频有失真情况,对于19201080的失真很严重,这是原始960540的视频稍有失真,效果如下:

在这里插入图片描述

  

以上的俩种对于非全屏情况下都生效,全屏情况下video级别超高,水印会消失。解决办法:重写controls完美解决

可参考:

  • https://blog.csdn.net/qq_22557797/article/details/72866358?utm_medium=distribute.pc_relevant.none-task-blog-baidujs-1
  • https://www.jianshu.com/p/f71d1284eaf8
你可能感兴趣的文章
No module named tensorboard.main在安装tensorboardX的时候遇到的问题
查看>>
No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
查看>>
No new migrations found. Your system is up-to-date.
查看>>
No qualifying bean of type XXX found for dependency XXX.
查看>>
No qualifying bean of type ‘com.netflix.discovery.AbstractDiscoveryClientOptionalArgs<?>‘ available
查看>>
No resource identifier found for attribute 'srcCompat' in package的解决办法
查看>>
no session found for current thread
查看>>
No static resource favicon.ico.
查看>>
no such file or directory AndroidManifest.xml
查看>>
No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
查看>>
NO.23 ZenTaoPHP目录结构
查看>>
no1
查看>>
NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
查看>>
NOAA(美国海洋和大气管理局)气象数据获取与POI点数据获取
查看>>
NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
查看>>
node
查看>>
node exporter完整版
查看>>
node HelloWorld入门篇
查看>>
Node JS: < 一> 初识Node JS
查看>>
Node JS: < 二> Node JS例子解析
查看>>