css3实现蒙版弹幕功能
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
css3实现蒙版弹幕功能
最近在b站上看到⼀种弹幕效果叫做智能防挡弹幕,也就是传说中的蒙版弹幕,打开之后效果⼤概是这样的
再也不⽤担⼼男神⼥神的绝世容颜被花⾥胡哨的弹幕挡住啦,是不是感觉很神奇。
实现原理其实就是类似于ps的蒙版,也就是说将图像的⼀部分 “隐藏”。
这⾥我们需要⽤到的是css3的mask遮罩属性。
CSS mask
CSS mask遮罩属性的历史⾮常久远了,远到⽐CSS3 border-radius等属性还要久远,最早是出现在Safari浏览器上的,差不多可以追溯到09年。
但是那个时候还是ie的天下,考虑到兼容性,所有没有被推⼴起来。
不过现在,ie已经是过去式了,所以可以放⼼使⽤了。
使⽤起来也⽐较简单
<img src="ps1.jpg" class="mask-image">
css代码如下:
.mask-image {
width: 250px;
height: 187.5px;
-webkit-mask-image: url(mask.png);
mask-image: url(mask.png);
}
蒙板可以是 CSS3 渐变或者半透明的PNG图⽚,蒙板元素的alpha值为0的时候会覆盖下⾯的元素,为1的时候会完全显⽰下⾯的内容。
效果⼤概是这样:
好了,有了这个属性我们就可以愉快的实现蒙版弹幕了⾸先,需要⼀张底图,模拟为视频的某⼀帧的图⽚
然后我们需要⼀个蒙版,遮住背景中的⼈物
显⽰代码如下:
html部分:
<div class="container">
<div class="barrage-wrapper">
</div>
</div>
css部分:
.container {
width: 900px;
height: 506px;
background: url(banner.jpg) no-repeat center;
background-size: cover;
}
.barrage-wrapper {
width: 100%;
height: 100%;
position: relative;
mask-image: url(mask.png);
-webkit-mask-image: url(mask.png);
}
先看下效果:
好吧,什么也看不出来。
不过实际上⼈物已经加上了蒙版加点弹幕试试效果。
添加弹幕动画效果和样式
@keyframes barrage{
from{
left:100%;
transform:translateX(0);
}
to{
left:0;
transform:translateX(-100%);
}
}
.block{
position:absolute;
top: 50%;
left: 100%;
width: 100%;
color: #fff;
}
添加弹幕的js脚本
// ⽣成⼀个0~range的随机数
const geneNumber = range => Math.floor(Math.random() * range)
var barrages = [
'空降成功', '真⾹警告', '温馨提⽰,前⽅请调⾼⾳量/赶紧戴⽿机', '弹幕护体!弹幕护体!弹幕护体!', ' 以上企业均已破产', '前⽅⾼能', '我从未见过如此厚颜⽆耻之⼈', '完结撒花', '空降成功', '真⾹警告', '温馨提⽰,前⽅请调⾼⾳量/赶紧戴⽿机', '弹幕护体!弹幕护体!弹幕护体!', ' 以上企业均已破产', '前⽅⾼能', '我从未见过如此厚颜⽆耻之⼈', '完结撒花', '空降成功', '真⾹警告', '温馨提⽰,前⽅请调⾼⾳量/赶紧戴⽿机', '弹幕护体!弹幕护体!弹幕护体!', ' 以上企业均已破产', '前⽅⾼能', '我从未见过如此厚颜⽆耻之⼈', '完结撒花', '空降成功', '真⾹警告', '温馨提⽰,前⽅请调⾼⾳量/赶紧戴⽿机', '弹幕护体!弹幕护体!弹幕护体!', ' 以上企业均已破产', '前⽅⾼能', '我从未见过如此厚颜⽆耻之⼈', '完结撒花', '空降成功', '真⾹警告', '温馨提⽰,前⽅请调⾼⾳量/赶紧戴⽿机', '弹幕护体!弹幕护体!弹幕护体!', ' 以上企业均已破产', '前⽅⾼能', '我从未见过如此厚颜⽆耻之⼈', '完结撒花', '空降成功', '真⾹警告', '温馨提⽰,前⽅请调⾼⾳量/赶紧戴⽿机', '弹幕护体!弹幕护体!弹幕护体!', ' 以上企业均已破产', '前⽅⾼能', '我从未见过如此厚颜⽆耻之⼈', '完结撒花', '空降成功', '真⾹警告', '温馨提⽰,前⽅请调⾼⾳量/赶紧戴⽿机', '弹幕护体!弹幕护体!弹幕护体!', ' 以上企业均已破产', '前⽅⾼能', '我从未见过如此厚颜⽆耻之⼈', '完结撒花', ]
const wrapper = document.querySelector('.barrage-wrapper')
for (const item of barrages) {
const block = document.createElement('div')
block.classList.add('block')
block.style.top = geneNumber(486) + 'px' // 弹幕的位置不能超过容器的⾼度
block.style.animation = `barrage ${geneNumber(20)}s linear ${geneNumber(60)}s` // 随机动画效果
block.textContent = item
wrapper.appendChild(block)
}
再看看效果
总结
以上所述是⼩编给⼤家介绍的基于css3实现蒙版弹幕功能,希望对⼤家有所帮助,如果⼤家有任何疑问欢迎给我留⾔,⼩编会及时回复⼤家的!。