弹幕不挡人技术的出现其实是让大家有更好的观看体验。
同学们对于弹幕肯定不陌生,它是社区文化的重要体现之一,但是随着视频中弹幕的堆积,视频内容尤其是其中的人物形象往往不能被清晰的看到。
所以相关技术人员为了优化大家观看视频时的综合体验,就通过计算机视觉相关技术,就设计出【弹幕蒙版】的功能,这样的功能就可以平衡弹幕视频观看体验。
(图源知乎,侵删)
看完关于B站蒙版弹幕的实现原理,总结一下,蒙版弹幕基本的要点有以下:
1. 基于用户数据和一些机器学习的相关应用,可以提炼出视频的关键主题;
2. 服务端预先对视频进行处理,并生成相应的蒙版数据;
3. 客户端播放视频时,实时地加载对应资源;
4. 通过一些前端的技术手段,实现弹幕的蒙版处理。
下面这篇文章说到的是原理的一部分,当然不是B站的整个弹幕处理流程,因为视频画面是动态的,难道要按视频帧率刷新图片?那每个视频要配备多少名切图员?这篇主要是讲述前端的一些技术手段,学姐觉得他的操作实用性会更强一些。同学们可以在开发时当作一个亮点去使用。
那天在B站看视频的时候偶然发现当字幕遇到人物的时候就被裁切了,不会挡住人物,觉得很神奇,于是决定一探究竟。
高端的效果,往往只需要采用最朴素的实现方式,忙碌了两个小时,陈师傅打开了F12,豁然开朗。一张图片 一个属性,直接搞定。
为了印证我的想法,我决定自己写一个demo
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.video {
width: 668px;
height: 376px;
position: relative;
-webkit-mask-image: url("mask.svg");
-webkit-mask-size: 668px 376px;
}
.bullet {
position: absolute;
font-size: 20px;
}
</style>
</head>
<body>
<div class="video">
<div class="bullet" style="left: 100px; top: 0;">元芳,你怎么看</div>
<div class="bullet" style="left: 200px; top: 20px;">你难道就是传说中的奶灵</div>
<div class="bullet" style="left: 300px; top: 40px;">你好,我是胖灵</div>
<div class="bullet" style="left: 400px; top: 60px;">这是第一集,还没有舔灵</div>
</div>
</body>
</html>
复制代码
效果是这样的
加一个红背景,看的清楚一些
至此我们就实现了B站同款的不遮挡人物的弹幕。至于这张图片是怎么来的,肯定是AI识别出来然后生成的,一张图片也就一两K,一次加载很多张也不会造成很大的负担。
最后来看看这个神奇的css属性吧
developer.mozilla.org/zh-CN/docs/…
Experimental: 这是一个实验中的功能
所以在开发需求的时候可以把它当成一个亮点使用,但是不能强依赖于这个属性做需求。
它还有一系列的属性,有兴趣的话可以挨个试一下。
,Copyright © 2008-2022 秒下下载站
m.down10s.com .All Rights Reserved