几分钟教你实现一个酷炫的扫光效果

news2024/9/27 23:24:56

前言

话不多说,咱们先来看看本篇文章中我们实现的效果。
请添加图片描述
是不是发现这个效果非常的熟悉?没错,这经常能够在一些电商网站可以看到,那这究竟是怎么实现的呢?接下来由我来带领大家尝试做一个类似这样的效果出来。

实现

其实上面的样式实现起来都到差不差的,实际上都是利用一个位移动画将一个倾斜的光线从左到右移动给用户造成一种视觉的误差,怎么样?是不是把你也给骗到了😂。如果还不明白的话我将这条线设置为红色并关闭动画你就明白了。
在这里插入图片描述
这条线也可以根据不同的需求来进行调整,只需要将linear-gradient(45deg,xxxx)中的偏转角度修改一下即可,比如我修改为 125deg效果如下:
在这里插入图片描述

这里我将扫光的这条线设置为transform: translateX(20%),位移动画就是实际上就是将这条线从最左边移动到最右边去。那有的小伙伴可能就会问,那文字扫光呢?文版扫光其实也差不多的原理。接下来我们分别进行实现吧!

文本扫光

文本扫光的核心思想是利用background-clip: text属性和渐变色背景来创建动态的文本效果。通过设置文本颜色为透明,并使用currentColor来保持渐变色的一致性,初次之外我们还要将文本的颜色设置为透明,以便隐藏实际的文本颜色,让渐变背景色显示出来,即webkit-text-fill-color: transparent。具体实现如下:

<template>
     <h1 class="scan-txt">画一个圆</h1>
</template>

<style>
.scan-txt {
    font-weight: bold;
    color: #4781ff;
    -webkit-text-fill-color: transparent;
    background: linear-gradient(45deg, rgba(255, 255, 255, 0) 40%, rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 0) 60%) -100%/50% no-repeat currentColor;
    background-clip: text;
    animation: scan-txt 2s infinite;
}
@keyframes scan-txt {
    to {
        background-position: 200%;
    }
}
</style>

或者使用,两者实现起来都差不多的。

<template>
    <span class="scan-txt2">几分钟教你实现一个酷炫的扫光效果</span>
</template>

<style>
.scan-txt2 {
    background: #161515 linear-gradient(to left, transparent, #fff, transparent) no-repeat 0 0;
    background-size: 20% 100%;
    background-position: 0 0;
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    animation: scan-text2 2s infinite;
}

@keyframes scan-text2 {
    from {
        background-position: 0% 0%;
    }

    to {
        background-position: 100% 100%;
    }
}
</style>

实现效果:
请添加图片描述

图片扫光

图片扫光因为不能直接在背景进行扫光,那么我们可以另辟蹊径使用一个左右位移的伪元素来覆盖在图片容器上面也可以达到这个效果。

<template>
   <div class="scan-wrap card">
     <img src="./02.jpg" />
   </div>
</template>

<style>
.card {
    border-radius: 10px;
}
.scan-wrap {
    position: relative;
    overflow: hidden;
}

.scan-wrap::after {
    content: "";
    position: absolute;
    inset: -20%;
    background: linear-gradient(125deg,
            rgba(255, 255, 255, 0) 40%,
            rgba(255, 255, 255, 0.7),
            rgba(255, 255, 255, 0) 60%);
    animation: scan-wrap 2s infinite;
    transform: translateX(-20%);
}
@keyframes scan-wrap {
    to {
        transform: translateX(100%);
    }
}
</style>

效果如下:
请添加图片描述

不规则图片

不规则图片就比上面图片的方式多了一点处理方式—mask,如果不清楚这个属性的同学可以前往我的这篇文章学习一下都2024年了你还没有开始探索 CSS 属性 mask 吗?。

<tempalte>
   <div class="scan-wrap mask-gift">
     <img
       class="logo"
       src="https://raw.githubusercontent.com/XboxYan/tuchuang/main/img/3af9e8de.00uqxe.png"
     />
   </div>
</template>
<style>
.scan-wrap {
    position: relative;
    overflow: hidden;
}

.scan-wrap::after {
    content: "";
    position: absolute;
    inset: -20%;
    background: linear-gradient(125deg,
            rgba(255, 255, 255, 0) 40%,
            rgba(255, 255, 255, 0.7),
            rgba(255, 255, 255, 0) 60%);
    animation: scan-wrap 2s infinite;
    transform: translateX(-20%);
}
@keyframes scan-wrap {
    to {
        transform: translateX(100%);
    }
}
.mask-gift {
    mask: url(xxxx) 0 0/100%;
}
</style>

效果如下:
请添加图片描述

总结

以上就本文的全部内容了,接下来对本文的内容进行总结:

  • 扫光样式可以通过线性渐变来创建,这种方法简单且效果良好。
  • 扫光动画的实现通常需要改变元素的位置或背景位置,这可以通过 CSS 的 transformbackground-position 属性来实现。
  • 对于文本元素,可以通过改变 background-position 来实现扫光动画。但是,需要注意的是,如果背景尺寸等于容器尺寸,那么设置 background-position 的百分比将无效。
  • 对于普通的容器元素,如果直接使用背景来实现扫光效果,可能会被容器内的其他元素覆盖。这时,可以使用伪元素来创建扫光效果。
  • 对于不规则的图片,直接使用扫光效果可能会产生多余的部分。这时,可以使用 CSS 的 mask 属性来根据图片的形状裁剪掉多余的部分。
  • 在实现扫光动画时,还需要注意动画的性能问题。尽量使用硬件加速的 CSS 属性(如 transformopacity),避免触发页面的重排或重绘,以提高动画的性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1985246.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

浏览器采集黑屏 问题

chrome://flags/#use-angle Choose ANGLE graphics backend 选择OPENGL 然后重启浏览器 就可以了

美股市场波动与科技股动态

一、美股市场波动 周一&#xff0c;美股三大股指低开高走&#xff0c;但最终收盘时道指跌2.6%&#xff0c;纳指跌3.43%&#xff0c;标普跌3%。美国十年国债收益率涨0.053%&#xff0c;收报3.787%&#xff0c;恐慌指数VIX涨64.9%至38.57。现货黄金跌1.34%&#xff0c;报2409.42…

2024年有哪些好用的文件加密软件?十款常用加密软件推荐

在2024年&#xff0c;随着数据泄露和网络威胁的日益复杂&#xff0c;文件加密软件成为了保护敏感信息不可或缺的工具。无论是个人用户还是企业&#xff0c;选择合适的加密软件都是确保数据安全的重要一环。 1. 安秉加密软件 安秉加密软件专为企业设计&#xff0c;提供全面的信…

SpringBoot框架学习笔记(六):自定义转换器、内容协商 和 Thymeleaf

1 自定义转换器 1.1 基本介绍 &#xff08;1&#xff09;SpringBoot在响应客户端请求时&#xff0c;将提交的数据封装成对象时&#xff0c;使用了内置的转换器&#xff0c;一共提供了124个内置转换器&#xff0c;核心源码&#xff0c;在 GenericConverter 接口的内部类 Conve…

澳洲联储按兵不动,通胀阴霾难散

澳洲联储核心通胀率仍远高于目标水平&#xff0c;经济增长依然强劲&#xff0c;因此维持高利率是必要的。 鹰派立场坚定 澳洲联储的这一决定与全球其他央行的政策走向形成了鲜明对比。许多发达经济体的央行已经开始降息&#xff0c;以应对经济增长放缓的风险。然而&#xff0…

TapData 信创数据源 | 国产信创数据库 OceanBase 数据同步指南,加速国产化进程,推进自主创新建设

随着国家对自主可控的日益重视&#xff0c;目前在各个行业和区域中面临越来越多的国产化&#xff0c;采用有自主知识产权的国产数据库正在成为主流。长期以来&#xff0c;作为拥有纯国产自研背景的 TapData&#xff0c;自是非常重视对于更多国产信创数据库的数据连接器支持&…

WiFi模块无线通信交互,乐鑫ESP32物联网方案,启明云端乐鑫代理商

随着物联网(IoT)技术的飞速发展&#xff0c;我们正步入一个智能化、互联化的世界。在这一进程中&#xff0c;无线WiFi模块作为连接物理世界与数字世界的桥梁&#xff0c;扮演着至关重要的角色。 WiFi模块是一种基于WiFi协议的无线模块&#xff0c;它可以实现设备之间的无线通信…

ACM MM 2024 | 比SDXL和DALL-E·3更引人入胜!ReCorD:交互场景生成最新SOTA!

文章链接&#xff1a;https://arxiv.org/pdf/2407.17911 git链接&#xff1a;https://alberthkyhky.github.io/ReCorD/ 亮点直击&#xff1a; 引入了一种新颖的推理框架&#xff0c;将潜在扩散模型&#xff08;LDM&#xff09;与视觉语言模型&#xff08;VLM&#xff09;相结合…

私域成交的关键点

私域运营&#xff0c;私域团购&#xff0c;私域秒杀&#xff0c;私域发售

单张图像降噪Masked and Shuffled Blind Spot Denoising for Real-World Images

文章目录 Masked and Shuffled Blind Spot Denoising for Real-World Images1.噪声的空间相关性2.mask3.loss4.masking ratio 与 spatial correlation的关系5.空间噪声去相关6.Automated selection of the BSD masking ratio7.小结 Masked and Shuffled Blind Spot Denoising f…

深入 Dify 源码,洞察 Dify RAG 切片机制实现细节

背景介绍 最近测试时发现 Dify 的 RAG 分片效果一般&#xff0c;不管是使用之前 深入 Dify 源码&#xff0c;洞察 Dify RAG 核心机制 中有调研过的默认解析还是 Unstructured 解析。因此调研比较了 大量的开源框架 实现了特定格式的结构化解析方案&#xff0c;并与 Dify 现有解…

高通8255 Android Virtio Virtio-IIC 配置方法

目录 一&#xff1a;VirtIO和Passthrough的区别 方法一&#xff1a; passthrough 方法二&#xff1a;virtIO 二&#xff1a;配置逻辑 三&#xff1a;示例Virtio-I2C配置 Virtio-I2C框架 步骤一&#xff1a;QNX IIC资源配置 & 测试 配置 测试 步骤二&#xff1a;B…

干货整理: 什么软件能够监控电脑? 六大好用监控电脑软件抢手推荐

如何保障电脑的安全是许多企业用户关注的焦点。 除了常见的杀毒软件外&#xff0c;电脑监控软件也是一道重要的防线。 这些软件能够实时监控电脑的各项运行状况&#xff0c;及时发现并处理潜在的安全威胁&#xff0c;确保电脑的正常运行和用户数据的安全。 接下来&#xff0…

优思学院|防呆法的十大原理

防呆法&#xff08;Poka-Yoke&#xff09;&#xff0c;又称防错法&#xff08;Mistake-Proofing&#xff09;&#xff0c;是一种通过预防错误的发生来提高工作效率&#xff0c;也是精益管理、六西格玛中常用的管理工具。以下就是防呆法的十大原理&#xff1a; 1. 断根原理 断…

算法_链表专题---持续更新

文章目录 前言两数相加题目要求题目解析代码如下 两两交换链表中的结点题目要求题目解析代码如下 重排链表题目要求题目解析代码如下 合并K个升序链表题目要求题目解析 K个一组翻转链表题目要求题目解析代码如下 前言 本文将记录leetcode链表算法题解&#xff0c;包含题目有&a…

Why Memory Matters?(记忆力为何如此重要?)

What is memory? The general consensus is that memory is a multitude of cognitive systems which allow us to store information for certain periods of time so that we can learn from our past experiences and predict the future. 什么是记忆?人们普遍的共识是&am…

《PostgreSQL 数据库在国内的发展前景》

从DB-engines这张2024年8月的最新排名图上可以看出&#xff0c;PostgreSQL数据库的发展趋势还是非常好的&#xff0c;在国内&#xff0c;PostgreSQL数据库也展现出令人振奋的发展前景&#xff0c;非常明显的一种表现就是腾讯云、人大金仓、阿里云、华为等众多厂商都有基于Postg…

推荐一个uniapp选择文件上传的插件

插件地址&#xff1a;文件选择、文件上传组件&#xff08;图片&#xff0c;视频&#xff0c;文件等&#xff09; - DCloud 插件市场 支持 H5 / App / 微信小程序

警惕!SCI投稿也有“假网址”!3秒教你查询正确的期刊官网网址

【SciencePub学术】很多没有发表过SCI论文的学者&#xff0c;对于投稿是非常陌生的。首先第一步&#xff0c;对于寻找正确的SCI/SSCI期刊官网都是一项难题。 01 假网站泛滥 • 目前市面上很多假的期刊官网&#xff0c;甚至于界面都所差无几&#xff0c;但是网址仅仅相差一个“…

【两周年纪念日】我将竭尽全力,只为和最美丽的自己早日汇合

​ 您好&#xff0c;我是程序员小羊&#xff01; 存在有其原因&#xff0c;经历有其始终&#xff0c;年华有其始末&#xff0c;拼搏要有结果。 2023来去匆匆&#xff0c;2024奋斗始终&#xff0c;献出一份感情&#xff0c;收获一份心情&#xff0c;拼出一段经验&#xff0c;收获…