前端怎么实现 B 站的弹幕可以不挡人物 ?

共 1749字,需浏览 4分钟

 ·

2022-11-12 17:10

点击上方  前端技术编程 ,关注公众号

回复 加群 ,加入前端技术交流群

https://juejin.cn/post/7141012605535010823

eed6fe7e5c8a4bf334e118fe202bf272.webp那天在B站看视频的时候偶然发现当字幕遇到人物的时候就被裁切了,不会挡住人物,觉得很神奇,于是决定一探究竟。

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

c7ac01d29b5d6721a977cb0b20f28248.webpb17c77af766bc056dc359edff35935aa.webp

为了印证我的想法,我决定自己写一个demo

      
      <!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Title</title>
  <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>
复制代码

效果是这样的

e3e6aceda398e33d55ec7551e25356b9.webp

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

e3f05e4be74803ab9d05999344ce784f.webp

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

最后来看看这个神奇的css属性吧

developer.mozilla.org/zh-CN/docs/… [1]

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

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

它还有一系列的属性,有兴趣的话可以挨个试一下。

611e87510679fd37b828ca69983ccd88.webp

参考资料

[1]

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

d6d21ae7d6ea9423b2d7c2507d7bea95.webp

往期推荐


前端开发必备的抓包技能
4a95247b66b8b213e5812a7a87d44fd4.webp为什么你开发的网页不应该大于 14KB?
e540aed56ea8f4138ab5405df9fbcfc6.webp6 个最佳 Vim 插件管理器,你喜欢哪个?
e540aed56ea8f4138ab5405df9fbcfc6.webp

浏览 25
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报