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

更新日期: 2022-10-23阅读: 2k标签: 弹幕

相信最近有很多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>

最终实现的效果:


链接: https://fly63.com/article/detial/12210

前端将数据转化为弹幕效果的实现方式

这个需求如题,大体上是将文章的评论数据,在文章的首图上面以弹幕的形式出现。实现弹幕的原理,并不算太复杂,耗费一些时间,怼一怼应该都可以做出来。获取弹幕数据,将弹幕设置为四个通道...

虎牙直播弹幕转换字幕格式 基于Node.js 的 huya-danmu

首先安装nodejs运行环境, 从 http://nodejs.cn/download/ 下载对应的版本, 安装 huya-danmu 模块, https://github.com/BacooTang/huya-danmu 有详细的安装方法,参照 huya-danmu 模块中 test.js 编写 huya.js 新文件,录视频的同时运行 huyaDanmu 批处理命令, 就不用在调整时间轴;

js实现弹幕效果

弹幕是一个很常见的功能,下面是本人封装的一个小小的实现方案,存在不足之处可以提出来或自由改进。直接上代码:效果如图:点击开启弹幕按钮:

B站自动填弹幕(附带createEvent消息机制)

经过我多次调试,发现B站的textarea需要触发一个keydown事件之后才能发送。Events 可以使用 Event 构造函数创建如下:请使用 event constructors 来替代.创建一个指定类型的事件。其返回的对象必须先初始化并可以被传递

DPlayer:H5视频播放器支持弹幕

DPlayer 是一个支持弹幕的 HTML5 视频播放器。支持 Bilibili 视频和 danmaku,支持HLS,FLV,MPEG DASH,WebTorrent以及其他视频格式,支持截屏、热键、切换清晰度以及字幕等。

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!