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

开发者(KaiFaX)

面向全栈工程师的开发者
专注于前端、Java/Python/Go/PHP的技术社区

经常用 B 站看视频的小伙伴应该都知道 B 站有个神奇的功能,那就是弹幕可以不挡人物,如下图:

c939299f05991bb08ca22904269baad8.jpeg


具体是怎么实现的呢?高端的效果,往往只需要采用最朴素的实现方式,忙碌了两个半小时,皮师傅打开了F12,豁然开朗。一张图片+一个属性,直接搞定。

a3084653f76f16b0eef8538eafebe59b.png

8b706e133b9bfc0d67e022222ed12e19.png为了印证我的想法,我决定自己写一个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>

效果是这样的:

17bf7fd027305a96178355f983668b05.png加一个红背景,看的清楚一些:

9f69760e2e2d12db249d9b11b2042b45.png至此我们就实现了B站同款的不遮挡人物的弹幕。至于这张图片是怎么来的,肯定是AI识别出来然后生成的,一张图片也就一两K,一次加载很多张也不会造成很大的负担。最后来看看这个神奇的css属性吧

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

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

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

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


1. 回复“m”可以查看历史记录;

2. 回复“h”或者“帮助”,查看帮助;

   开发者已开通多个技术群交流学习,请加若飞微信:1321113940  (暗号k)进开发群学习交流

  说明:我们都是开发者。视频或文章来源于网络,如涉及版权或有误,请您与若飞(1321113940)联系,将在第一时间删除或者修改,谢谢!

c3a78deeee7b3b00eff3c73e250c13f7.jpeg

开 发 者 : KaiFaX

面向全栈工程师的开发者
专注于前端、Java/Python/Go/PHP的技术社区

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值