查看原文
其他

为什么B站的弹幕可以不挡人物?

大家好,我是鱼皮。经常用 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属性吧

https://developer.mozilla.org/zh-CN/docs/Web/CSS/mask-image

  Experimental: 这是一个实验中的功能

在开发需求的时候可以把它当成一个亮点使用,但是不能强依赖于这个属性做需求。它还有一系列的属性,有兴趣的话可以挨个试一下。

文章来源:https://juejin.cn/post/7141012605535010823



欢迎学编程的朋友们加入鱼皮的 
编程知识星球 ,我会 1 对 1 解决你的问题,并且直播带大家开发完整项目(第三期项目进行中,已完结 4 集)。可以加我微信 yupi5927,备注【加入星球】和自己的情况领取优惠加入星球,不备注不通过,非诚勿扰谢谢。

往期推荐

我的学习小圈子

自我介绍,千万别来虚的!

马斯克终于认错:裁掉他们是我最大的错误!

同事吐槽我的接口性能差,原来它是真凶!

突然好奇,韩国技术面试卷不卷?

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存