likes
comments
collection
share

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

作者站长头像
站长
· 阅读数 106

萧瑟深秋,不如点一把音乐的火,随着节奏摇摆

楔子

这是一篇活泼向的技术分享,目的是为了制作一个随着音乐节奏起舞的律动器,主要涉及以下知识点: 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度,才能看到一个正常律动的音柱

结尾

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

转载自:https://juejin.cn/post/7150250196062961677
评论
请登录