写点什么

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

  • 2018-08-13
  • 本文字数:1980 字

    阅读完需:约 6 分钟

身为 B 站老司机的你,是不是总会在自己喜爱的 UP 主或者热门的视频中遇到如下情况:

或者这样“前方高能”类型的挡脸弹幕:

说起来,我们当然知道弹幕刷屏是大家表达对 UP 主或者视频中人物喜爱的方式,但是作为粉丝,爱豆的颜被厚厚的弹幕挡得严严实实实在是不爽的体验啊!

(╯‵□′)╯︵┻━┻

有人可能会说:可以关弹幕啊。

But,在 B 站关弹幕看视频,那就完全丧失了乐趣好伐?!

Ummmmm,还挺难伺候。

于是,B 站为了提升各路用户老爷们的体验,推出了这样一种蒙版弹幕技术。这一技术背后的男人:光驱子,也被小编从社交平台上挖了出来 ( •̀ ω •́ )✧强行进行了一番采访。

光驱子,加入 B 站到现在已有三年,算得上是一个老员工。加入 B 站后,主要负责弹幕的相关工作,包括产品和运营,期间也曾主要负责过比如手机版主站,创作中心等等项目。

光驱子告诉我们,开发这一弹幕技术的初衷,除了为了满足用户的需求,还有一些个人体验方面的考虑。

他说:首先开发蒙版弹幕的目的不仅仅是因为刷屏这一个原因而存在的。想必之前大部分未曾使用过弹幕功能的用户都会觉得,弹幕这种东西,总是遮挡我想看的内容,真的非常讨厌。然而刷屏仅仅是遮挡的一种情况而已。实际只要想看的内容和弹幕正好重叠,就会产生和刷屏一样的问题。

所以,光驱子和团队的产品思路就已经非常明确了,那就是:只要弹幕不去遮挡想看的内容就可以了。

为什么叫它“蒙版弹幕”,光驱子告诉我们:“我们的前端实现方法就正如 PS 中的‘蒙版’一样,实心区域允许,空白区域拒绝。而技术的核心就在蒙版的生成上,所以将这个功能称之为‘蒙版弹幕’。”

同时,他还为我们揭露了一些技术原理:通过计算机视觉的技术,对视频内容进行分析,并将之前已经定义好的“视频主体内容”进行识别,生成蒙版并分发给客户端后,让客户端利用 CSS3 的特性进行渲染从而达成最终的效果。这样就形成了我们最终看到的,“不挡脸”弹幕效果:

弹幕“穿”雷总而过

妹子舞蹈的流畅动作再也不用担心看不清了!

不过,我们在测试的过程中还是产生了一些疑问:目前可供体验的视频基本上都是以三次元真实的人作为视频主体,难道说视频主体为二次元纸片人的时候,蒙版弹幕暂时不起作用?

光驱子答道:“确实,假设我们仅仅对一个单独的视频进行分析,可能我们就‘万策尽きた’(无计可施)了。但是我们可以作为视频主体内容判断的参考的不仅仅是视频本身。用户投稿的分区,标签,简介,甚至于 UP 主的过往投稿都会被我们作为参考。

举个例子,一位 UP 主在科技区中投稿了个评测视频,我们在视频中发现其中“手机”这个元素在视频的 50% 以上时长都出现了,那么我们就可以认为手机应该也是视频主体内容的一部分。生成蒙版时自然就可以起到同样的效果。”

光驱子说,二次元视频相对于三次元视频元素拥有更多艺术表现形式,也因此实际效果差异较大。但他们将持续进行算法调研,以便未来能够支持更大范围内的视频。

不过,据了解,不论视频主体是二次元还是三次元,总体的技术都是相同的,并无太大区别。 而可见的最大难点便是训练,这是相当费时费力的过程。

目前,蒙版弹幕技术已经在效果上最稳定,同时需求更迫切的舞蹈区进行小范围应用,之后将会逐步扩大使用范围。可供测试的视频见此链接(戳阅读原文可以直达视频页面哦  ( •̀ ω •́ )✧):

https://www.bilibili.com/read/cv534194

简单的说,它的开启方式是这样的: 

  • 第一步:打开特定的舞蹈区视频内容(web 端播放器需为 H5 播放器)

  • 第二步:在内心默念咒语 bilibili 干杯 233 遍

  • 第三步:在屏幕前连续打 call 大约 23 分钟

  • 第四步:在播放器弹幕开关内的设置选项中勾选:智能防挡弹幕  

以上都是逗你玩的 prprprpr

    功能发布之后,蒙版弹幕团队也收集到了很多用户反馈,包括移动端支持的需求,浏览器兼容性,以及一些蒙版不够完美的问题。

    收到众多宝贵意见的同时,大部分用户在站内专栏和微博上也都表达了出了对这个功能的惊艳感和对未来应用的期待。光驱子说:“我们可以说非常的开心和自豪,也非常感谢大家的支持。”

    光驱子还告诉我们,接下来蒙版弹幕技术团队将会加快这一技术在移动端的使用,短期内前端开发组的同学将会对性能和兼容性上进行优化,而蒙版生成方面我们仍将不停的优化调整算法。未来还将会把这一功能扩展到二次元内容和直播业务上。

    对于 B 站这样浓厚 ACG 氛围公司的技术团队,我们很是好奇他们的工作方式会有什么不同,所以在采访中,我们优先问了这样的问题,得到的回答也蛮有意思:

    “就工作流程上而言其实和其他的技术公司并无太大不同。但是因为我们都喜欢 ACGN,所以在工作中都会有意无意的像调味料一样,添加这些元素到我们所开发的产品里来。像使用角色名命名项目,评审需求时圈内骚话漫天飞等等等等。这些都让可能本来严肃紧张的工作变得更加轻松愉快起来。”

    2018-08-13 19:005690
    用户头像
    陈思 InfoQ编辑

    发布了 576 篇内容, 共 280.0 次阅读, 收获喜欢 1301 次。

    关注

    评论 1 条评论

    发布
    暂无评论
    发现更多内容

    软件测试 | 测试开发 | 你的期待薪资是多少?为什么?

    测吧(北京)科技有限公司

    测试

    华为云桌面远程办公,真香!

    爱科技的水月

    华为云会议,助力企业移动办公效率提升

    i生活i科技

    学生管理系统架构文档

    闲人Eric

    架构实战营

    跨平台应用开发进阶(三十六) :uniapp使用uni.request请求报错{“errMsg“:“request:fail abort statusCode:-1“}的解决办法

    No Silver Bullet

    uni-app 12月月更 跨平台应用开发 statusCode:-1“ request:fail abort

    2022中国产业数字化发展成熟度行业指数分析—— 重视差异,结合自身要素禀赋,推进产业精细化治理

    易观分析

    产业 产业数字化

    校招面试真题 | 你的期望薪资是多少?为什么?

    测试人

    从咖啡馆到世界,共赴下一个十年|写在EMQX开源十周年

    EMQ映云科技

    GitHub 开源 IoT emqx 12 月 PK 榜

    MySql索引下推知识分享

    京东科技开发者

    数据库 后端 索引 MySQL 数据库 索引原理

    低代码多分支协同开发的建设与实践

    阿里巴巴终端技术

    前端 低代码

    计算机科学通识-01-电子计算机发展史

    邱比特讲编程

    计算机基础 计算机 计算机教育

    随时随地一键开会,华为云会议大幅提升用户开会体验

    i生活i科技

    华为云桌面,企业云上办公为何都偏好它?

    i生活i科技

    阿里云香港节点全面故障给我们的启示

    laofo

    DevOps 研发效能 DevOps工具

    数字化办公,就选流畅、清晰的华为云桌面

    i生活i科技

    跨平台应用开发进阶(三十四) :uni-app 应用 Universal Link 实现 iOS 微信分享

    No Silver Bullet

    uni-app universal link 跨平台应用 12月月更 iOS 微信分享

    网络ping不通,试试这8招

    华为云开发者联盟

    开发 网络 服务器 华为云 12 月 PK 榜

    车载LED显示屏的4大性能指标

    Dylan

    LED显示屏 户外LED显示屏 led显示屏厂家

    华为云桌面协同办公,助力建筑行业数字化转型

    爱科技的水月

    这一篇让你搞懂电商平台中的商品 SPU 和 SKU

    产品海豚湾

    产品经理 产品设计 商品管理 电商平台 需求分析

    如何使用火焰图对 Rust 程序进行性能和内存占用分析

    Databend

    华为云会议助力大家保险提升沟通协作效能

    i生活i科技

    IntelliJ IDEA中我最爱的10个快捷操作

    JAVA旭阳

    Java IDEA

    教你用Python实现BMI计算器

    小院里的霍大侠

    Python 实战案例 初学者 入门实战

    4年“落子”8大城市,骥翀氢能产业布局背后精心下好“商业模式”先手棋

    硬科技星球

    跨平台应用开发进阶(三十七)uni-app前端监控方案 Sentry 探究

    No Silver Bullet

    uni-app sentry 12月月更 前端监控方案

    weidl x DeepRec:热门微博推荐框架性能提升实战

    阿里云大数据AI技术

    性能优化 AI技术 推荐引擎 12 月 PK 榜

    如何在云原生环境中实现安全左移?

    SEAL安全

    云原生 安全 DevSecOps 12 月 PK 榜

    MyBatis是如何初始化的

    华为云开发者联盟

    Java 开发 华为云 12 月 PK 榜

    搞定 Redis 数据存储原理,别只会 set、get 了

    小小怪下士

    Java redis

    更加灵活、经济、高效的训练 — 新一代搜推广稀疏大模型训练范式GBA

    阿里技术

    大模型 搜索推荐

    不挡脸,放肆看!B站黑科技蒙版弹幕揭秘_语言 & 开发_陈思_InfoQ精选文章