使用CSS混合模式轻松实现Mp4视频透明背景

我们知道如果想在一张背景图上加特效,就需要设计师在做视频的同时将背景图导入进去, 这无非是增加了工作量和维护成本,如果我们可以自己实现融合的效果就省了很多事。而mix-blend-mode属性恰好可以做到这点。

最终效果

定义

mix-blend-mode:该属性描述了元素的内容应该与元素的直系父元素的内容和元素的背景如何混合。
screen:最终的颜色是反转颜色(顶层颜色和底层颜色),相乘它们并反转该值的结果。黑色层不会造成变化,白色层导致白色最终层。其效果类似于投射到投影屏幕上的两个图像。

太抽象了,我们只需要理解当背景是黑色的时候,他就会变成透明,我们就是利用他的这个特性来实现透明背景。

代码示例

css 复制代码
<div class="container">
  <video class="video" src="../public/video6.mp4" autoplay muted loop />
</div>
.container {
  width: 400px;
  height: 400px;
  margin: 200px auto;
  background: url("../public/img1.jpeg") no-repeat;
  background-size: 100% 100%;
}
.video {
  width: 100%;
  height: 100%;
  mix-blend-mode: screen;
}

我们需要给video元素mured静音属性autoplay才会生效,然后我们让他循环播放,在video元素上加上mix-blend-mode: screen; 就这么简单,透明效果就做出来了。

相关推荐
Rrvive16 分钟前
localhost 和 127.0.0.1 的核心区别
前端
蓝倾16 分钟前
如何使用Python通过API接口批量抓取小红书笔记评论?
前端·后端·api
極光未晚18 分钟前
JavaScript BOM 对象:浏览器的隐形控制塔
前端·javascript·源码
天涯学馆20 分钟前
网站秒变 App!手把手教你搞定 PWA
前端·javascript·面试
uu_code00723 分钟前
Android接入Pixelfree美颜SDK技术指南
前端
小鱼小鱼干24 分钟前
使用 ESLint 实现 Git Commit 前的语法检查
前端
码哥DFS40 分钟前
Flex布局原理
前端·css·css3
小样还想跑1 小时前
axios无感刷新token
前端·javascript·vue.js
Java水解1 小时前
一文了解Blob文件格式,前端必备技能之一
前端
用户3802258598241 小时前
vue3源码解析:响应式机制
前端·vue.js