LPL Ban/Pick 选人阶段的遮罩效果是如何实现的?

简介: LPL Ban/Pick 选人阶段的遮罩效果是如何实现的?

最近 S11 LPL 春季赛开赛,在看比赛的过程中,我发现新赛季的 Ban/Pick 选人阶段,出现了一种新的,有意思的遮罩效果,如下图所示:

32680b6c93d64187a1d8f54dd4c18b0e_tplv-k3u1fbpfcp-zoom-1.png


当然,它是一个动态的效果,当选人的过程中,会有一种呼吸的效果:


36344b9c22a744c4beacf07fa31cc3f3_tplv-k3u1fbpfcp-zoom-1.gif


Gif 图有点糊,总的而言,就是一种接近迷雾的遮罩效果。并且,他是能够动态变化的。

本文将探究,在 CSS 中,我们应该如何去实现类似的效果。


实现烟雾化遮罩效果



首先,我们来尝试实现这样一个动态遮罩:

12186130f55345b6bd315dde73de87f4_tplv-k3u1fbpfcp-watermark.gif


假设没有模糊的边缘,及烟雾化的效果,它其实就是一个渐变:


<div></div>
div {
    width: 340px;
    height: 180px;
    border: 2px solid #5b595b;
    background: linear-gradient(
        rgba(229, 23, 49, 1),
        rgba(229, 23, 49, .9) 48%,
        transparent 55%,
    );
}


经由上述代码,我们可得到:

77b63937a9524264b2ae72b17ee74bb1_tplv-k3u1fbpfcp-zoom-1.png


好吧,看着确实平平无奇,我们如何利用它,得到一个雾化的效果呢?


提到烟雾,聪明的同学应该能想到滤镜,当然,是 SVG 的 <feturbulence> 滤镜。


没错,又是它,<feturbulence> 确实太有意思了,我最近的两篇关于它的文章 -- Amazing!!CSS 也能实现烟雾效果?Amazing!!CSS 也能实现极光? 可以一并阅读。


<feturbulence> 的 type="fractalNoise" 在模拟云雾效果时非常好用。该滤镜利用 Perlin 噪声函数创建了一个图像,能够实现半透明的烟熏或波状图像,用于实现一些特殊的纹理。


这里,我们利用 <feturbulence> 滤镜简单处理一下上述图形:


<div></div>
<svg width="0">
  <filter id="filter">
    <feTurbulence id="turbulence" type="fractalNoise" baseFrequency=".03" numOctaves="20" />
    <feDisplacementMap in="SourceGraphic" scale="30" />
  </filter>
</svg>

CSS 中,可以利用 filter: url() 对对应的元素引入该滤镜:


div {
    ...
    filter: url(#smoke);
}


作用了滤镜的元素的效果:

46eff8fcfc7f4b57bd96e50056b86d7a_tplv-k3u1fbpfcp-zoom-1.png


由于我给元素加了边框,整个边框也被雾化了,这不是我们想要的,可以使用伪元素改造一下,边框作用于容器,使用伪元素实现渐变,将滤镜作用于伪元素:


div {
    position: relative;
    width: 340px;
    height: 180px;
    border: 2px solid #5b595b;
    &::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        right: 0;
        bottom: 0;
        background: linear-gradient(
            30deg,
            rgba(229, 23, 49, 1),
            rgba(229, 23, 49, .9) 48%,
            transparent 55%,
        );
        filter: url(#smoke);
    }
}


改造后的效果如下:

a34db6b4c83c4744b361c7b0d59d5372_tplv-k3u1fbpfcp-zoom-1.png


好,又接近了一步,但是四周有很多瑕疵没有被填满。问题不大,我们改变一下定位的 top \ left\ right \ bottom,让伪元素超出父容器,父容器设置 overflow: hidden 即可:


div {
    ....
    overflow: hidden;
    &::before {
        ....
        left: -20px;
        top: -10px;
        right: -20px;
        bottom: -20px;
        background: linear-gradient(
            30deg,
            rgba(229, 23, 49, 1),
            rgba(229, 23, 49, .9) 48%,
            transparent 55%,
        );
        filter: url(#smoke);
    }
}


调整之后,看看效果:


5d17236c486940ddb9b1f46a31d1e0e1_tplv-k3u1fbpfcp-zoom-1.png

有点那感觉了,下一步,只需要让烟雾元素动起来,为了让整个效果连贯(由于 SVG 动画本身不支持类似 animation-fill-mode: alternate 这种特性),我们还是需要写一点 JavaScript 代码,控制动画的整体循环。


大概的代码是这样:


const filter = document.querySelector("#turbulence");
let frames = 1;
let rad = Math.PI / 180;
let bfx, bfy;
function freqAnimation() {
    frames += .35;
    bfx = 0.035;
    bfy = 0.015;
    bfx += 0.006 * Math.cos(frames * rad);
    bfy += 0.004 * Math.sin(frames * rad);
    bf = bfx.toString() + " " + bfy.toString();
    filter.setAttributeNS(null, "baseFrequency", bf);
    window.requestAnimationFrame(freqAnimation);
}
window.requestAnimationFrame(freqAnimation);


这段代码做的事情,其实只有一个,就是让 SVG 的 #turbulence 滤镜的 baseFrequency 属性,在一个区间内无限循环,仅此而已。通过改变 baseFrequency,让整个烟雾不断变化。


至此,我们就得到了一幅完整的,会动的烟雾遮罩:

5397a608f79f43c2944c635871f065ef_tplv-k3u1fbpfcp-watermark.gif


补充下框内的图片,就能得到一开始给出的效果图效果:


c7bce574d1124fec8ea6a85bf445da44_tplv-k3u1fbpfcp-watermark.gif


完整的代码,你可以戳这里 -- CodePen Demos -- LPL BAN PICK MASK Effect

实现呼吸状态的遮罩效果



在上述基础上,再加入呼吸的效果,其实就非常简单了。


我们只需要去改变渐变的一个位置即可,方法非常多,这里我给一个较为优雅但是兼容性可能没那么好的方法 -- CSS @property。


简单改造上述代码:


@property --per {
    syntax: "<percentage>";
    inherits: false;
    initial-value: 22%;
}
div::before {
    ...
    background: linear-gradient(
        30deg,
        #ff0020,
        rgba(229, 23, 49, .9) var(--per),
        transparent calc(var(--per) + 8%),
    );
    filter: url(#smoke);
    animation: change 2s infinite ease-out;
}
@keyframes change {
    50% {
        --per: 18%;
    }
}


这样,呼吸效果就实现了:

9dc6a460a5134b09bc8662164a014cb4_tplv-k3u1fbpfcp-zoom-1.gif

完整的代码,你可以戳这里 -- CodePen Demos -- LPL BAN PICK MASK Effect

目录
相关文章
|
4月前
Force Yc团队最新第五次创作引导页源码
Force Yc团队最新第五次创作引导页源码 此源码可以播放自己的音乐 无法播放视频背景!~ 音乐修改:music 音乐名称:bgm.mp3 LOGO修改:images 图片名字:top-logo.mp4 文本修改:index.html Notepad++编辑
50 10
Force Yc团队最新第五次创作引导页源码
|
5月前
|
JSON JavaScript 前端开发
震惊!JS如何悄无声息追踪你的每一步?揭秘页面访问与关闭的超级上报大法,让数据说话,优化体验不再难!
【8月更文挑战第4天】在Web开发中,跟踪用户行为对提升体验与留存至关重要。本文以在线学习平台为例,介绍如何用JavaScript监听页面访问及关闭,并上报数据。通过`window.onload`监测页面加载,记录用户访问;利用`navigator.sendBeacon`在用户离开时发送少量数据至服务器,无需担心请求失败。需注意隐私合规、性能影响及浏览器兼容性。此技术有助于深入理解用户行为,为产品迭代提供依据。
230 8
|
6月前
|
定位技术
高德局部刷新标记点,bug解决
将接口返回的经纬集合点在高德地图上标记展示, 如果实时刷新地图标记点,不加优化,则会造成过多的带宽消耗 所以,地图只需加载一次,局部更新标记点就好了。
|
5月前
|
程序员 开发工具 git
Git提交错了?别慌,学会直接删除提交记录
【8月更文挑战第7天】在日常的开发工作中,使用Git进行版本控制几乎是每位程序员的必修课。然而,即使是经验丰富的开发者,也难免会遇到“哎呀,我不小心提交了一些不该提交的内容!”的尴尬时刻。面对这样的错误,不必惊慌失措,Git提供了强大的功能来帮助我们修正这些错误,包括直接删除错误的提交记录。
422 0
|
8月前
|
JSON API 数据格式
dragonBones5.6.300解析关键帧的actions异常的bug
dragonBones5.6.300解析关键帧的actions异常的bug
84 0
【PR】如何做一个图片动画出场
【PR】如何做一个图片动画出场
169 0
【PR】如何做一个图片动画出场
|
JavaScript
Cypress系列(26)- 聚焦与失焦命令的详解
Cypress系列(26)- 聚焦与失焦命令的详解
422 0
Cypress系列(26)- 聚焦与失焦命令的详解
|
JavaScript 容器 前端开发
一些JS事件小片段代码整理收集(持续)
一、js实现 1 2 3 4 5 function AcceptData(num){ 6 document.getElementById("accepDate").value+=num; 7 } 8 9 10 11 12 13 14 15 16  二、input输入框的value传值显示 input输入框中用户输入的值,点击按钮显示在另一个容器之中。
1055 0

热门文章

最新文章