“我报名参加金石计划1期挑战——瓜分10万奖池,这是我的第1篇文章,点击检查活动详情”

那天在B站看视频的时分偶然发现当字幕遇到人物的时分就被裁切了,不会挡住人物,觉得很神奇,所以决定一探终究。

高端的作用,往往只需要采用最朴素的完成方式,忙碌了两个小时,陈师傅打开了F12,豁然开朗。一张图片+一个特点,直接搞定。

为什么B站的弹幕能够不挡人物

为什么B站的弹幕能够不挡人物

为了印证我的想法,我决定自己写一个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站的弹幕能够不挡人物

加一个红布景,看的清楚一些

为什么B站的弹幕能够不挡人物

至此我们就完成了B站同款的不遮挡人物的弹幕。至于这张图片是怎样来的,肯定是AI识别出来然后生成的,一张图片也就一两K,一次加载许多张也不会形成很大的担负。

最终来看看这个神奇的css特点吧

developer.mozilla.org/zh-CN/docs/…

Experimental: 这是一个试验中的功用

所以在开发需求的时分能够把它当成一个亮点使用,但是不能强依赖于这个特点做需求。

它还有一系列的特点,有兴趣的话能够挨个试一下。

为什么B站的弹幕能够不挡人物