相信最近有很多B站的用户都注意到了不挡脸的弹幕,打开一则视频右下角的“智能防挡弹幕”功能后,弹幕就不会再覆盖人像,而是呈现从人体身后穿过的效果。

简述实现方式

前端实现方法就正如PS中的“蒙版”一样,实心区域允许,空白区域拒绝。而技术的核心就在蒙版的生成上,所以将这个功能称之为“蒙版弹幕”,而蒙版图片估计是由AI识别出来然后生成,一张图片也就一两K,一次加载很多张也不会造成很大的负担,最后结合svg图+ css的mask-image属性,通过在视频不同时的帧引入不同遮罩图,来实现弹幕遮挡的效果 。

mask-image 属性的用法

CSS中的mask-image属性用于设置图像或文本的遮罩。它用于为CSS中的特定元素形成遮罩层。语法如下:

/* <mask-source> value */
mask-image: url(masks.svg#mask1);/* <image> values */
mask-image: linear-gradient(rgba(0, 0, 0, 1.0), transparent);
mask-image: image(url(mask.png), skyblue);/* Multiple values */
mask-image: image(url(mask.png), skyblue), linear-gradient(rgba(0, 0, 0, 1.0), transparent);

mask-image指遮罩使用的图片资源,默认值是none,也就是无遮罩图片。因此,和border属性中的border-style属性类似,是一个想要有效果就必须设定的属性值。

mask-image遮罩所支持的图片类型非常的广泛,可以是url()静态图片资源,格式包括JPG,PNG以及SVG等都是支持的;也可以是动态生成的图片,例如使用各种CSS3渐变绘制的图片。语法上支持CSS3各类渐变,以及url()功能符,image()功能符,甚至element()功能符。

同时还支持多背景,因此理论上,使用mask-image我们可以遮罩出任意我们想要的图形,非常强大。

代码实现

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title><style>.video {width: 668px;height: 376px;position: relative;background-color: black;-webkit-mask-image: url("./svg.svg");-webkit-mask-size: 668px 376px;}.bullet {position: absolute;font-size: 20px;color: white;animation: ani 5s linear infinite;}.showBullet {position: absolute;font-size: 20px;color: red;animation: show 5s linear infinite;}@keyframes ani {0% {transform: translateX(668px);}100% {transform: translateX(-668px);}}@keyframes show {0% {opacity: 0;}10% {opacity: 1;}100% {opacity: 1;}}</style>
</head>
<body>
<div class="video"><div class="bullet" style="left: 100px; top: 120px;">元芳,你怎么看</div><div class="bullet" style="left: 200px; top: 60px;">你难道就是传说中的手工耿</div><div class="bullet" style="left: 500px; top: 60px;">纯手工js弹幕</div><div class="bullet" style="left: 300px; top: 140px;">失踪人口回归</div><div class="bullet" style="left: 400px; top: 100px;">下次一定,梗哥</div><div class="showBullet" style="left: 320px; top: 20px;">完结撒花</div><div class="showBullet" style="left: 340px; top: 50px;">泪目</div>
</div>
</body>
</html>

最终实现的效果:

B站不挡脸弹幕前端是如何实现的?相关推荐

  1. B站不挡脸弹幕 这到底是什么黑科技?

    B站不挡脸弹幕 这到底是什么黑科技? 2018.06.23 18:13:19来源: 游迅网作者:游迅网 B站不挡脸弹幕 这到底是什么黑科技? 近日,B站针对弹幕功能进行了升级,正式推出了"不 ...

  2. 不挡脸,放肆看!揭秘B站黑科技蒙版弹幕

    来源:AI前线 本文约2019字,建议阅读5分钟. 本文为你揭秘B 站推出的一种"不挡脸"的黑科技弹幕以及背后的故事. [ 导读 ]不久前,B 站发布一条官方消息,为了更好的提升用 ...

  3. 前端ui框架_跨屏建站发布同名响应式前端ui框架

    跨屏建站发布同名响应式前端ui框架,它是跨屏建站关于前端页面构建上的积累的结晶,现已开源,我们将持续的用开源的方式做好ui框架产品,用心做好建站产品. 关于 跨屏UI框架是基于Bootstrap的扩展 ...

  4. python获取b站视频封面及弹幕

    python网络爬虫 利用python获取b站视频封面及弹幕 获取弹幕 获取封面 完整代码 利用python获取b站视频封面及弹幕 获取弹幕 从https://api.bilibili.com/x/v ...

  5. 爬取钉钉在B站卑微道歉视频弹幕,做成词云

    爬取钉钉在B站卑微道歉视频弹幕,做成词云|钉~ 听这美妙的声音 先看用户老爷们给出得评价 B弹幕爬取的方法 打开钉钉下跪视频 B站链接 然后进入控制台如图查看,打开控制台刷新下页面. 你就会在控制台看 ...

  6. i国网app苹果版_挡脸相机苹果版苹果版下载-挡脸相机苹果版APP

    挡脸相机苹果版是一款非常好玩的相机应用,挡脸相机苹果版为大家提供提供各种贴纸素材,大小位置随意调整,能够帮助用户轻松将脸挡住,让你的照片不露脸也不尴尬,而且还很酷! 软件介绍 挡脸相机,让你从此告别& ...

  7. B站后端java_GitHub - javalovelinux/bilibili-vue: 前端vue+后端koa,全栈式开发bilibili首页...

    技术栈 前端:vue2 + vuex + webpack + ES6/7 + stylus + nginx 后端:koa2 项目运行 如何运行 运行前请先安装nodejs clone项目到本地 git ...

  8. 抗击肺炎,我们能做到的,就是别让爱隔离——python分析B站三个视频弹幕内容,云图数据。

    武汉是个美丽的城市,但这个城市现在生病了. "人之初,性本善" 美丽的武汉生病了,一场大病,有钱的人能捐钱,而我,一直陪着你们吧,武汉加油 ! 有人说"武汉人咋啥也吃&q ...

  9. 我分析了b站10万条弹幕,发现了歪嘴战神的终极奥义!(文末重磅福利)

    大家好,我是小z~ 天气太热,今天文末一次性送出5本很nice商业智能可视化书籍,给大家解解暑. 最近,歪嘴战神血洗b站,靠着"耐克式微笑"成功出圈,迷倒众生. 这次,小z爬取了1 ...

最新文章

  1. 程序员创业前要做哪些准备?
  2. python数据结构与算法分析_数据结构与算法(Python版)
  3. 算一算你的语言价值几何
  4. #翻译NO.3# --- Spring Integration Framework
  5. 动态参数与global和nonlocal
  6. spring AOP源码分析(一)
  7. 比Redis快5倍的中间件,究竟为什么这么快?
  8. 充分释放数据价值:安全、可信6到飞起
  9. ASP.NET是如何在IIS下工作的
  10. python3.6中内置函数变化
  11. 用maya怎么做ak47_串串香应该怎么用配料才能做得好吃
  12. 阶段3 1.Mybatis_05.使用Mybatis完成CRUD_7 Mybatis中参数的深入-使用实体类的包装对象作为查询条件...
  13. LaTeX中插入文本框并且设置文本框底色(填充色)的方法
  14. 【原创】带下划线单选菜单栏-标签Tab
  15. 主视图和左视图算体积最大最小值
  16. java文件压缩与解压_Java实现文件压缩与解压
  17. Simple java里面的paint(Graphics g)的理解
  18. python数据记录_python 数据处理中的记录
  19. 解决Android studio 编译问题(版本不对问题)Unable to resolve dependency for******
  20. ngRx 官方示例分析 - 2. Action 管理

热门文章

  1. Echarts将数据进行排名 Echarts排行榜 鼠标进行缩放
  2. VirtualBox中出现UUID have already exists ,并且数字键盘numlock效果相反
  3. PL/SQL dev使用指南
  4. three.js几何体的_UV_、法向属性以及BufferGeometry类介绍
  5. 电商vs物流 谁动谁的奶酪(上)
  6. 三上初识计算机教学设计,三上  秒的认识教学设计及反思
  7. Map集合例题(存入城市及城市等级)(键遍历与键值对遍历)
  8. 服务器主控系统,服务器控制管理
  9. 关于mysql的中文乱码全解 java方式
  10. 视频会议系统属于服务器吗,解析视频会议系统结构