分享使用CSS实现酷炫充电动画效果的小技巧

本篇文章给大家介绍一下巧用 css实现酷炫充电动画效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

分享使用CSS实现酷炫充电动画效果的小技巧

循序渐进,看看只使用 CSS ,可以鼓捣出什么样的充电动画效果。(学习视频分享:css视频教程)

画个电池

当然,电池充电,首先得用 CSS 画一个电池,这个不难,随便整一个:

立即学习“前端免费学习笔记(深入)”;

1.png

欧了,勉强就是它了。有了电池,那接下来直接充电吧。最最简单的动画,那应该是用色彩把整个电池灌满即可。

方法很多,代码也很简单,直接看效果:

2.gif

有内味了,如果要求不高,这个勉强也就能够交差了。通过蓝色渐变表示电量,通过色块的位移动画实现充电的动画。但是总感觉少了点什么。

增加阴影及颜色的变化

如果要继续优化的话,需要添加点细节。

我们知道,低电量时,电量通常表示为红色,高电量时表示为绿色。再给整个色块添加点阴影的变化,呼吸的感觉,让充电的效果看起来确实是在动。 

3.gif

知识点

到这里,其实只有一个知识点:

使用 filter: hue-rotate() 对渐变色彩进行色彩过渡变换动画

我们无法对一个渐变色直接进行 animation ,这里通过滤镜对色相进行调整,从而实现了渐变色的变换动画。

上述例子完整的 Demo: CodePen Demo — Battery Animation One

添加波浪

ok,刚刚算一个小里程碑,接下来再进一步。电量的顶部为一条直线有点呆呆的感觉,这里我们进行改造一下,如果能将顶部直线,改为波浪滚动,效果会更为逼真一点。

改造之后的效果: 

4.gif

使用 CSS 实现这种波浪滚动效果,其实只是用了一种障眼法,具体的可以我早期写的这篇文章:

纯 CSS 实现波浪效果!

知识点

这里的一个知识点就是上述说的使用 CSS 实现简易的波浪效果,通过障眼法实现,看看图就明白了:

5.gif

上述例子完整的 Demo: CodePen Demo — Battery Animation Two

OK,到这,上述效果加上数字变化已经算是一个比较不错的效果了。当然上面的效果看上去还是很 CSS 的,就是一眼看到就觉得用 CSS 是可以做到的。

使用强大的 CSS 滤镜实现安卓充电动画效果

那下面这个呢? 

6.png

用安卓手机的同学肯定不陌生,这个是安卓手机在充电的时候的效果。看到这个我就很好奇,使用 CSS 能做到吗?

经过一番尝试,发现使用 CSS 也是可以很好的模拟这种动画效果: 

7.gif

上述 Gif 录制的效果图是完全使用 CSS 模拟的效果。

上述例子完整的 Demo: HuaWei Battery Charging Animation

知识点

拆解一下知识点,最主要的其实是用到了 filter: contrast() 以及 filter: blur() 这两个滤镜,可以很好的实现这种融合效果。

单独将两个滤镜拿出来,它们的作用分别是:

filter: blur(): 给图像设置高斯模糊效果。filter: contrast(): 调整图像的对比度。

但是,当他们“合体”的时候,产生了奇妙的融合现象。

先来看一个简单的例子:

8.gif

仔细看两圆相交的过程,在边与边接触的时候,会产生一种边界融合的效果,通过对比度滤镜把高斯模糊的模糊边缘给干掉,利用高斯模糊实现融合效果。

当然,这种效果在之前的文章也多次提及过,更具体的,可以看看:

CSS 火焰?不在话下你所不知道的 CSS 滤镜技巧与细节

颜色的变换

当然,这里也是可以加上颜色的变换,效果也很不错: 

9.gif

上述例子完整的 Demo: HuaWei Battery Charging Animation

容易忽视的点

通过调节 filter: blur() 及 filter: contrast() 属性的值,动画效果其实会有很大程度的变化,好的效果需要不断的调试。当然,经验在其中也是发挥了很重要的作用,说到底还是要多尝试。

本文转载自:https://juejin.cn/post/6844904029336649741作者: ChokCoco

更多编程相关知识,请访问:编程视频!!

以上就是分享使用CSS实现酷炫充电动画效果的小技巧的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1619298.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 06:39:06
下一篇 2025年12月24日 06:39:27

相关推荐

  • css如何去除边框

    css去除边框的方法:1、使用“border:none”定义无边框样式;2、使用“border:1px solid transparent”设置边框透明;3、使用“border:1px solid 背景颜色值”设置边框颜色与背景颜色一样。 本教程操作环境:windows7系统、CSS3&&a…

    2025年12月24日 好文分享
    000
  • CSS如何设置页面背景色

    在css中,可以使用“background-color”属性设置页面背景色,语法“background-color:颜色值”。background-color属性设置元素的背景颜色,元素背景是元素的总大小,包括填充和边界(但不包括边距)。 本教程操作环境:windows7系统、CSS3&&a…

    2025年12月24日
    000
  • css如何设置删除线

    在css中,可以使用text-decoration属性设置删除线,语法“text-decoration:line-through”。text-decoration属性设置元素文本修饰,值为line-through时,定义穿过文本下的一条线。 本教程操作环境:windows7系统、CSS3&&…

    2025年12月24日
    000
  • css如何隐藏标签

    方法:1、使用“opacity:0”语句;2、使用“display:none”语句;3、使用“visibility:hidden”语句;4、使用position属性,配合top、bottom、left、right属性将元素标签移出视觉区域。 本教程操作环境:windows7系统、CSS3&&…

    2025年12月24日 好文分享
    000
  • css如何设置字间距

    在css中,可以使用“letter-spacing”属性设置字间距,语法“letter-spacing:间距值”。letter-spacing属性增加或减少字符间的空白,该属性定义了在文本字符框之间插入多少空间。 本教程操作环境:windows7系统、CSS3&&HTML5版、Del…

    2025年12月24日
    000
  • css如何设置图片位置

    方法:首先使用position属性规定元素的定位类型,语法“position:static|relative|fixed|absolute”;然后使用top、bottom、left和right属性定义图片元素的偏移位置,进行精确定位。 本教程操作环境:windows7系统、CSS3&&amp…

    2025年12月24日
    000
  • css如何设置文字超出省略号

    方法:首先使用“overflow:hidden”语句,设置内容超出后隐藏;然后使用“text-overflow:ellipsis”语句,设置内容超出显示为省略号;最后使用“white-space:nowrap”语句,设置文本不进行换行即可。 设置内容显示为一行,内容超出后显示为省略号。为cont类添…

    2025年12月24日
    000
  • css字体大小如何设置

    css字体大小设置的方法是使用【font-size】属性设置字体大小,实际上它设置的是字体中字符框的高度,实际的字符字形可能比这些框高或矮。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css字体大小设置的方法: css可以使用font-size属性设置字体大小,实际上它…

    2025年12月24日
    000
  • css怎么样清除浮动

    css清除浮动的方法是使用clear属性清除浮动,clear属性定义了元素的哪边上不允许出现浮动元素,代码为【img{float:left;clear:both;}】。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css清除浮动的方法: css可以使用clear属性清除浮…

    2025年12月24日
    000
  • css文字如何隐藏

    css文字的隐藏方法:1、使用【text-indent:-9999px;】方法;2、使用【line-height:0;】方法;3、加上span;4、使用【display:none】方法;5、使用【overflow:hidden】方法。 本教程操作环境:windows7系统、css3版,DELL G3…

    2025年12月24日
    000
  • css元素如何隐藏

    css元素隐藏的方法:1、opacity属性的意思是设置一个元素的透明度;2、Visibility将它的值设为hidden将隐藏我们的元素;3、display属性依照词义真正隐藏元素。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css元素隐藏的方法: 1、Opacity…

    2025年12月24日
    000
  • CSS如何实现各种形状

    CSS实现各种形状的方法:1、圆形在设置CSS时要设置宽度和高度相等,然后设置【border-radius】属性为宽度或高度的一半;2、正方形是CSS图形中最简单的图形之一,同样使用一个div,并设置一个ID。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 CSS实现各种形…

    2025年12月24日
    000
  • css如何让图片居中

    图片居中的方法:1、使用“background-position:图片宽度的一半 高度的一半;”语句;2、使用“background-position:50%”语句;3、使用“background-position:center;”语句。 本教程操作环境:windows7系统、css3版,DELL …

    2025年12月24日
    000
  • css不生效是什么原因

    css不生效的原因:1、html标签没写完整,漏了“”或者“/”等;2、样式表保存的编码错误;3、样式被层叠;4、CSS语法错误;5、选择器写错。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css不生效的原因: 一、html标签没写完整,漏了“”或者“/”等 这是版面设…

    2025年12月24日
    000
  • css如何设置不透明

    css设置不透明的方法是使用【css rgba()】设置颜色透明度,RGBA颜色值是RGB颜色值的扩展,带有一个alpha通道,语法为【rgba(R,G,B,A);】。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css设置不透明的方法: css rgba()设置颜色透明…

    2025年12月24日
    000
  • css如何修改字体

    css修改字体的方法是使用【font-family】规定元素的字体系列,【font-family】可以把多个字体名称作为一个【回退】系统来保存。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css修改字体的方法: font-family 规定元素的字体系列。 font-f…

    2025年12月24日
    000
  • css如何取消样式

    css取消样式的方法:1、移除全部样式使用【removeattr(“style”)】;2、移除单个样式使用【css(“属性”,“”)】。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css取消样式的方法: 1、移除全部样式使用removeattr(“style”); re…

    2025年12月24日
    000
  • css如何超出显示滚动条

    css超出显示滚动条的方法:1、使用三个容器包围起来,不需要计算滚动条的宽度;2、自定义滚动条的伪对象选择器【::webkit-scrollbar】。 本教程操作环境:windows7系统、css3版,DELL G3电脑。 css超出显示滚动条的方法: 方法1:使用三个容器包围起来,不需要计算滚动条…

    2025年12月24日
    000
  • css怎么设置边框为虚线样式

    在css中,可以使用border-style属性来设置边框为虚线样式,只需要给元素添加“border-style:dashed;”样式即可。border-style属性用于设置元素边框的样式,当值为“dashed”时,可定义虚线边框样式。 本教程操作环境:windows7系统、CSS3&&a…

    2025年12月24日
    000
  • css实现元素隐藏和显示的属性有哪些

    实现属性有:1、display属性,值为“none”时隐藏元素,为“block”时显示元素;2、visibility属性,值为“hidden”时隐藏元素,为“visible”时显示元素;3、overflow属性;4、opacity属性。 本教程操作环境:windows7系统、CSS3&&am…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信