最近在b站上看到一种弹幕效果叫做智能 防 挡弹幕,也就是传说中的 蒙版 弹幕, 打开之后效果大概是这样的
再也 不用 担心男神女神的绝世容颜被花里胡哨的弹幕挡住啦,是不是感觉很神奇。
实现原理 其实就是类似于ps的蒙版,也就是说将图像的一部分 [隐藏]。这里我们需要用到的是css3的mask遮罩属性。
CSS mask
CSS mask遮罩属性的历史非常久远了,远到比CSS3 border-radius等属性还要久远,最早是出现在Safari浏览器上的,差不多可以追溯到09年。但是那个时候还是ie的天下,考虑到兼容性,所有没有被 推广 起来。 不过 现在,ie已经是过去式了,所以可以放心使用了。
使用起来也比较 简单
< img src=" ps1 . jpg " class=" ;m ask -i mage">
css代码如下:
&nbs p;
.mask-image {
width: 250px;
h ei ght: 187.5px;
- webkit -mask-image: url(mask.png);
mask-image: url(mask.png);
}
蒙板可以是 CSS3 渐变 或者 半 透明的 png图片 ,蒙板元素的alpha值为0的时候会覆盖下面的元素,为1的时候会完全显示下面的内容。效果大概是这样:
关于mask的更多属性及参数这里就不一一研究了,具体可以看这篇 文章 : https://HdhCmsTestzhangxinxu测试数据/wordpress/2017/11/css-css3-mask-masks/
好了,有了这个属性我们就可以愉快的实现蒙版弹幕了
首先,需要一张底图,模拟为视频的某一帧的图片
然后我们需要一个蒙版,遮住背景中的 人物
显示代码如下:
ht ML 部分:
<div class="cont ai ner">
<div class="barrage-wrap PE r">
</div>
</div>
css部分:
.container {
width: 900px;
height: 506px;
background: url(banner.jpg) no-repeat center ;
background-size : cover;
}
.barrage-wrapper {
width: 100%;
height: 100%;
pos IT ion: relative;
mask-image: url(mask.png);
-webkit-mask-image: url(mask.png);
}
先看下效果:
好吧,什么也看不出来。不过实际上人物已经加上了蒙版
加点弹幕试试效果。
添加弹幕动画效果和样式
@keyfr am es barrage{
From {
left:100%;
transform:trans latex (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实现蒙版弹幕功能, 希望对大家有所帮助 ,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
总结
以上是 为你收集整理的 css3实现蒙版弹幕功能 全部内容,希望文章能够帮你解决 css3实现蒙版弹幕功能 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。