B站视频弹幕不挡住人脸效果
创始人
2024-03-02 03:47:09
0

前言

有天在B站看二舅的视频时,密密麻麻的弹幕居然没有二舅的人脸,很好奇是怎么做到的,于是决定一探究竟。
在这里插入图片描述

高端的效果,往往只需要采用最朴素的实现方式,琢磨了好一会儿,打开了F12,豁然开朗。一张图片+一个属性,直接搞定。
在这里插入图片描述
在这里插入图片描述

mask-image属性

mask-image CSS属性用于设置元素上遮罩层的图像。
https://developer.mozilla.org/zh-CN/docs/Web/CSS/mask-image

在这里插入图片描述
在这里插入图片描述

mask-image demo

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


Title
二舅,你怎么看
你难道就是传说中的二舅
你好,我是二舅
二舅好帅

效果如下:
在这里插入图片描述
至此我们就实现了B站同款的不遮挡人物的弹幕。至于这张图片是怎么来的,那是AI识别出来然后生成的,一张图片也就一两K,连续加载也不会造成很大的负担。

相关框架 Barrage UI

https://barrage-ui.netlify.app/
基于相关接口,可精确定义每一帧渲染。可快速实现 B 站(bilibili.com)风格的『蒙版弹幕』效果。
在这里插入图片描述

Barrage UI demo

html


js

import Barrage from 'barrage-ui';
import example from 'barrage-ui/example.json'; // 组件提供的示例数据// 加载弹幕
const barrage = new Barrage({container: document.getElementById('container'), // 父级容器data: example, // 弹幕数据// beforeRender: (ctx, progress) => {// 用于获取当前进度对应蒙版的方法// const imageData = getMask(progress); // barrage.setMask(imageData);// },config: {// 全局配置项duration: 20000, // 弹幕循环周期(单位:毫秒)defaultColor: '#fff', // 弹幕默认颜色},
});// 设置蒙版图像
const img = require("../assets/mask.svg");
barrage.setMask(img); // 传入蒙版图像的 url// 新增一条弹幕
barrage.add({key: 'fctc651a9pm2j20bia8j', // 弹幕的唯一标识time: 1000, // 弹幕出现的时间(单位:毫秒)text: '这是新增的一条弹幕', // 弹幕文本内容fontSize: 24, // 该条弹幕的字号大小(单位:像素),会覆盖全局设置color: '#0ff', // 该条弹幕的颜色,会覆盖全局设置
});// 播放弹幕
barrage.play();

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...