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


    楔子

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

    实现

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

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

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

    结尾

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

    最后

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



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

  • 相关阅读:
    面向对象的设计(OOD)原则了解一下
    微信公众号后台管理
    多重背包问题 ← 规模小时可转化为0-1背包问题
    Prometheus黑盒测试模块,监控TCP端口+ HTTP/HTTPS路由状态
    Gimbal Lock欧拉角死锁问题
    (数字图像处理MATLAB+Python)第十章图像分割-第四,五节:分水岭分割和综合案例
    Flutter 类似onResume 监听,解决入场动画卡顿
    数据结构篇——KMP算法
    Kinsoku jikou desu新浪股票接口变动(php)
    部署kibana可视化平台
  • 原文地址:https://blog.csdn.net/qq_53225741/article/details/127659412