CSS 使用 SVG 绘制动态皮筋与小球交互动画

2024-04-12 05:44

本文主要是介绍CSS 使用 SVG 绘制动态皮筋与小球交互动画,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CSS 使用 SVG 绘制动态皮筋与小球交互动画

效果展示

在这里插入图片描述

CSS 知识点

  • 使用 animation 控制 SVG 的 path 属性执行动画
  • 使用 CSS 设置 SVG 部分属性

整体页面布局

<div class="elasic"><!-- 小球 --><div class="ball"></div><!-- 皮筋的阴影部分 --><svg><path></path></svg><!-- 皮筋部分 --><svg><path></path></svg>
</div>

绘制固定皮筋的两个小点

.elasic {position: relative;width: 400px;height: 400px;display: flex;justify-content: center;align-items: flex-end;
}.elasic::before {content: "";position: absolute;bottom: 62.5px;left: 5px;width: 15px;height: 15px;background: #fff;border-radius: 50%;z-index: 2;
}.elasic::after {content: "";position: absolute;bottom: 62.5px;right: 5px;width: 15px;height: 15px;background: #fff;border-radius: 50%;z-index: 2;
}

实现上述代码后,页面效果如下:

在这里插入图片描述

绘制 SVG 皮筋

.elasic svg {position: absolute;width: 400px;height: 150px;fill: none;
}.elasic svg:nth-child(2) {filter: blur(25px);
}.elasic svg path {width: 100%;stroke: #ff0092;stroke-width: 10;stroke-linecap: round;/* 设置SVG的形状 */d: path("M 10 80 Q 190 80 390 80");
}

实现 SVG 皮筋动画

.elasic svg path {/* 添加动画 */animation: animate 2.5s linear infinite, animateColor 2.5s linear infinite;
}@keyframes animate {/* 这里我只是会绘制了0~60%的动画,正在动画执行时效果不是很好,可以自行补充剩余的动画步骤 *//* 因为我们只是简单绘制了一个矩形,所以我们要呈现皮筋的运动效果的话,只要修改 path 属性中的对应属性就可以(简单来说就是修改倒数第三个和第二个参数就可以形成上下运动的皮筋效果) */0% {d: path("M 10 80 Q 190 80 390 80");}10% {d: path("M 10 80 Q 190 160 390 80");}20% {d: path("M 10 80 Q 190 20 390 80");}30% {d: path("M 10 80 Q 190 120 390 80");}35% {d: path("M 10 80 Q 190 100 390 80");}40% {d: path("M 10 80 Q 190 80 390 80");}50% {d: path("M 10 80 Q 190 100 390 80");}55% {d: path("M 10 80 Q 190 90 390 80");}60% {d: path("M 10 80 Q 190 80 390 80");}
}/* 改变皮筋的颜色的动画 */
@keyframes animateColor {0%,100% {stroke: #ff0092;}33.33% {stroke: #0f0;}66.66% {stroke: #ff0;}
}

完成上述代码后,皮筋就可以开始运动,效果图如下:

在这里插入图片描述

绘制小球和小球动画

.ball {position: relative;width: 60px;height: 60px;background-color: #fff;border-radius: 50%;box-shadow: inset 0 -15px 20px rgba(0, 0, 0, 0.5);animation: animateBall 2.5s linear infinite;
}@keyframes animateBall {0%,100% {/* 控制小球的动画起始位置和结束位置,必须和皮筋开始时的位置保持一致,具体可以调整参数来实现 */transform: translateY(-72.5px);}10%,11.5% {transform: translateY(-40px);}50% {transform: translateY(-350px);}
}

完成上述代码后就可以完成所有效果。

完整代码下载

完整代码下载

这篇关于CSS 使用 SVG 绘制动态皮筋与小球交互动画的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/896259

相关文章

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

使用DeepSeek搭建个人知识库(在笔记本电脑上)

《使用DeepSeek搭建个人知识库(在笔记本电脑上)》本文介绍了如何在笔记本电脑上使用DeepSeek和开源工具搭建个人知识库,通过安装DeepSeek和RAGFlow,并使用CherryStudi... 目录部署环境软件清单安装DeepSeek安装Cherry Studio安装RAGFlow设置知识库总

Python FastAPI入门安装使用

《PythonFastAPI入门安装使用》FastAPI是一个现代、快速的PythonWeb框架,用于构建API,它基于Python3.6+的类型提示特性,使得代码更加简洁且易于绶护,这篇文章主要介... 目录第一节:FastAPI入门一、FastAPI框架介绍什么是ASGI服务(WSGI)二、FastAP

Spring-AOP-ProceedingJoinPoint的使用详解

《Spring-AOP-ProceedingJoinPoint的使用详解》:本文主要介绍Spring-AOP-ProceedingJoinPoint的使用方式,具有很好的参考价值,希望对大家有所帮... 目录ProceedingJoinPoijsnt简介获取环绕通知方法的相关信息1.proceed()2.g

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML

JAVA虚拟机中 -D, -X, -XX ,-server参数使用

《JAVA虚拟机中-D,-X,-XX,-server参数使用》本文主要介绍了JAVA虚拟机中-D,-X,-XX,-server参数使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录一、-D参数二、-X参数三、-XX参数总结:在Java开发过程中,对Java虚拟机(JVM)的启动参数进

Java中使用注解校验手机号格式的详细指南

《Java中使用注解校验手机号格式的详细指南》在现代的Web应用开发中,数据校验是一个非常重要的环节,本文将详细介绍如何在Java中使用注解对手机号格式进行校验,感兴趣的小伙伴可以了解下... 目录1. 引言2. 数据校验的重要性3. Java中的数据校验框架4. 使用注解校验手机号格式4.1 @NotBl

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

HTML5 data-*自定义数据属性的示例代码

《HTML5data-*自定义数据属性的示例代码》HTML5的自定义数据属性(data-*)提供了一种标准化的方法在HTML元素上存储额外信息,可以通过JavaScript访问、修改和在CSS中使用... 目录引言基本概念使用自定义数据属性1. 在 html 中定义2. 通过 JavaScript 访问3.

Python使用DeepSeek进行联网搜索功能详解

《Python使用DeepSeek进行联网搜索功能详解》Python作为一种非常流行的编程语言,结合DeepSeek这一高性能的深度学习工具包,可以方便地处理各种深度学习任务,本文将介绍一下如何使用P... 目录一、环境准备与依赖安装二、DeepSeek简介三、联网搜索与数据集准备四、实践示例:图像分类1.