首页 > 作文

css3实现蒙版弹幕功能

更新时间:2023-04-07 03:58:59 阅读: 评论:0

最近在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的时候会完全显示下面的内容。效果大概是这样:

关于mask的更多属性及参数这里就不一一研究了,具体可以看这篇文章:

好了,有了这个属性我们就可以愉快的实现蒙版弹幕了

首先,需要一张底图,模拟为视频的某一帧的图片

然后我们需要一个蒙版,遮住背景中的人物

显示代码如下:

html部分:

<div class="container">    <div class="barrage-wrapper">    </div>  </div>

css部分:

.container {  width: 900px;  慈祥的近义词height: 506px;  ba全国学籍网ckground: 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.querylector('.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.appendchi关于阅兵的作文ld(block)    }

再看看效果

总结

以上所述是www.887551.com给大家介绍的基于css3实现蒙版弹幕功能,希望对大家有所帮助

本文发布于:2023-04-07 03:58:57,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/ed64f928dd22ebe08e32841aef32c6da.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:css3实现蒙版弹幕功能.doc

本文 PDF 下载地址:css3实现蒙版弹幕功能.pdf

标签:弹幕   护体   厚颜无耻   见过
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图