纯CSS3实现萧瑟深秋中律动的音乐之火

2024-01-15 13:40

本文主要是介绍纯CSS3实现萧瑟深秋中律动的音乐之火,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

楔子

这是一篇活泼向的技术分享,目的是为了制作一个随着音乐节奏起舞的律动器,主要涉及以下知识点: div的垂直与水平居中方式flex布局backgroundImage的径向渐变背景css3 Animation相关属性

实现

古话讲叫 大音希声 大象无形,虽然音乐是很难通过具象的东西去表达的,但音律可以通过具象的符号去表达,本文就是通过纯CSS的方式,去尝试模拟音符的律动。

  • 音盒 承载我们音柱的容器,这里我们涉及到一个知识点就是一个元素的垂直与水平居中,下面我来简单的罗列一下,实现方式有脱离文档流和不脱离文档流两大类,
  • 不脱离文档流的实现有:
  • flex布局, 通过外层套容器写flex布局的方式来实现水平和垂直居中
display: flex;
justify-content: center; // 主轴居中
align-items: center; // 交叉轴居中 
  • grid布局 与flex布局类似,为了避免水字数的嫌疑,略
  • 脱离文档流的实现
  • 绝对定位+margin auto 适用于宽高已经设置的情形【注意:假如宽高未指定,margin:auto会拉开直至撑满容器】
position: absolute;top: 0;left: 0;right: 0;bottom: 0;margin: auto; 
  • 绝对定位 + transform 平移变换 【绝对定位的百分比是相对有定位属性的父级,而transform的百分比是相对自身】
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%); 
  • 音柱 主要涉及到一个径向渐变,径向渐变第一个参数是角度,表示渐变方向,后续是渐变的颜色
.music-box div{height: 200px;flex: none;width: 50px;background-image: linear-gradient(90deg, #80D6FF, #FF7EA5, #FFED3B,#8aD6FF);background-size: 500%;} 
  • 律动 律动的实现我们通过css3的animation属性来实现,主要是通过高度变化来模拟音乐律动,这里涉及三个知识点,一个是nth-child 伪类选择器 一个是1n 这种倍数选择器,还有就是动画的属性
.music-box div:nth-child(1n){animation: jump .3s linear 0s infinite alternate;}.music-box div:nth-child(2n){animation: jump .5s linear 0s infinite alternate;}.music-box div:nth-child(3n){animation: jump .8s linear 0s infinite alternate;}.music-box div:nth-child(5n){animation: jump 1s linear 0s infinite alternate;}@keyframes jump {10%{height: 20%;}20% {height: 50%;background-position: -100% 0;}40%{height: 30%;}60%{height: 25%;}80%{height: 0;}100%{height: 50%;}} 
  • 动画属性 animation: name duration timing-function delay iteration-count direction fill-mode; 从左到右属性依次是: 属性名称 持续时间 动画方式 延迟 次数 方向 填充模式,其中重点需要讲以下几个
  • 动画方式: 内置的有一些,比如leaner ease 等, 也可以传入一个贝塞尔函数
  • 方向: 就是从哪里开始
  • 填充模式 就是 当动画完成恢复时是否还需要动画

tips:通过上面的代码实现的音乐之火是倒着的,还需要将容器进行旋转180度,才能看到一个正常律动的音柱

结尾

通过上面的代码,我们就实现了一个音乐之火,萧瑟深秋,让这个音乐之火随着你的律动跳跃吧~

最后

最近还整理一份JavaScript与ES的笔记,一共25个重要的知识点,对每个知识点都进行了讲解和分析。能帮你快速掌握JavaScript与ES的相关知识,提升工作效率。



有需要的小伙伴,可以点击下方卡片领取,无偿分享

这篇关于纯CSS3实现萧瑟深秋中律动的音乐之火的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/qq_53225741/article/details/127659412
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/609084

相关文章

Java实现MD5加密的四种方式

《Java实现MD5加密的四种方式》MD5是一种广泛使用的哈希算法,其输出结果是一个128位的二进制数,通常以32位十六进制数的形式表示,MD5的底层实现涉及多个复杂的步骤和算法,本文给大家介绍了Ja... 目录MD5介绍Java 中实现 MD5 加密方式方法一:使用 MessageDigest方法二:使用

mysql删除无用用户的方法实现

《mysql删除无用用户的方法实现》本文主要介绍了mysql删除无用用户的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 1、删除不用的账户(1) 查看当前已存在账户mysql> select user,host,pa

Nginx配置location+rewrite实现隐性域名配置

《Nginx配置location+rewrite实现隐性域名配置》本文主要介绍了Nginx配置location+rewrite实现隐性域名配置,包括基于根目录、条件和反向代理+rewrite配置的隐性... 目录1、配置基于根目录的隐性域名(就是nginx反向代理)2、配置基于条件的隐性域名2.1、基于条件

Linux配置IP地址的三种实现方式

《Linux配置IP地址的三种实现方式》:本文主要介绍Linux配置IP地址的三种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录环境RedHat9第一种安装 直接配置网卡文件第二种方式 nmcli(Networkmanager command-line

Java实现将Markdown转换为纯文本

《Java实现将Markdown转换为纯文本》这篇文章主要为大家详细介绍了两种在Java中实现Markdown转纯文本的主流方法,文中的示例代码讲解详细,大家可以根据需求选择适合的方案... 目录方法一:使用正则表达式(轻量级方案)方法二:使用 Flexmark-Java 库(专业方案)1. 添加依赖(Ma

使用EasyExcel实现简单的Excel表格解析操作

《使用EasyExcel实现简单的Excel表格解析操作》:本文主要介绍如何使用EasyExcel完成简单的表格解析操作,同时实现了大量数据情况下数据的分次批量入库,并记录每条数据入库的状态,感兴... 目录前言固定模板及表数据格式的解析实现Excel模板内容对应的实体类实现AnalysisEventLis

Mybatis从3.4.0版本到3.5.7版本的迭代方法实现

《Mybatis从3.4.0版本到3.5.7版本的迭代方法实现》本文主要介绍了Mybatis从3.4.0版本到3.5.7版本的迭代方法实现,包括主要的功能增强、不兼容的更改和修复的错误,具有一定的参考... 目录一、3.4.01、主要的功能增强2、selectCursor example3、不兼容的更改二、

如何使用C#串口通讯实现数据的发送和接收

《如何使用C#串口通讯实现数据的发送和接收》本文详细介绍了如何使用C#实现基于串口通讯的数据发送和接收,通过SerialPort类,我们可以轻松实现串口通讯,并结合事件机制实现数据的传递和处理,感兴趣... 目录1. 概述2. 关键技术点2.1 SerialPort类2.2 异步接收数据2.3 数据解析2.

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu

Qt把文件夹从A移动到B的实现示例

《Qt把文件夹从A移动到B的实现示例》本文主要介绍了Qt把文件夹从A移动到B的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录如何移动一个文件? 如何移动文件夹(包含里面的全部内容):如何删除文件夹:QT 文件复制,移动(