您现在所在的位置:首页 >关于奇酷 > 行业动态 > 为什么 B 站的弹幕可以不挡人物?

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

来源:奇酷教育 发表于:

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

  B 站的弹幕如何实现不挡人物?

 
  高端的效果,往往只需要采用最朴素的实现方式。

 
  一张图片+一个属性,就可以直接搞定。

 
  代码如下:
 
html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Titletitle>
  <style>
    .video {
      width668px;
      height376px;
      position: relative;
      -webkit-mask-imageurl("mask.svg");
      -webkit-mask-size668px 376px;
    }
    .bullet {
      position: absolute;
      font-size20px;
    }
  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: 这是一个实验中的功能
 
  所以在开发需求的时候可以把它当成一个亮点使用,但是不能强依赖于这个属性做需求。
 
  它还有一系列的属性,有兴趣的话可以挨个试一下。
html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Titletitle>
  <style>
    .video {
      width668px;
      height376px;
      position: relative;
      -webkit-mask-imageurl("mask.svg");
      -webkit-mask-size668px 376px;
    }
    .bullet {
      position: absolute;
      font-size20px;
    }
  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>
复制代码