html动画透明与音乐,css animation实现音乐震动条

效果如下

1460000022183905

实现

核心就是用关键帧keyframe在动画的不同阶段设置不同百分比高度,每个div的keyframe设置为一样,此时所有div的高度变化是一样的,要产生视觉上的差异,只要将每一段完成的时间设为不一样即可,一个先完成一个后完成,因为关键帧是一样的,所以只要设置动画完成的时间挨个逐渐不一样即可。

1.DOM结构

2.CSS样式

* {

margin: 0;

padding: 0;

}

.content {

width: 100px;

height: 80px;

position: absolute;

top: 30%;

left: 50%;

transform: translateX(-50%) rotateX(180deg);

}

.content .item {

width:15px;

height: 80px;

float: left;

background-color: #09f;

margin-right: 2px;

}

#last{

margin-right: 0;

}

此时效果如下:

1460000022183904

3.为每个div添加动画

.item {

animation: wave 0.8s linear infinite alternate;

}

@keyframes wave {

10% {

height: 20%;

}

20%{

height: 60%;

}

40%{

height: 40%;

}

50%{

height: 100%;

}

100%{

height: 50%;

}

}

此时全部的item都是一样动的

1460000022183907

4.让每个item之间产生差异

每一个item的动画都在重复且相同,因为动画完成相同是一样的。拿第一个和第二个举例子,如果要让他们产生先后,那么完成10%帧变化所需时间不同给,则高度达到20%的进度就不同,差异就显现了。要让完成10%帧变化所需时间不同,只要给他们的完成整个动画的时间不同即可,那么之后就永远不同。上述代码

.item {

animation: wave 0.8s linear infinite alternate;

}

改为

.item:nth-child(1) {

animation: wave 0.8s linear infinite alternate;

}

.item:nth-child(2) {

animation: wave 0.9s linear infinite alternate;

}

.item:nth-child(3) {

animation: wave 1s linear infinite alternate;

}

.item:nth-child(4) {

animation: wave 0.8s linear infinite alternate;

}

.item:nth-child(5) {

animation: wave 0.7s linear infinite alternate;

}

.item:nth-child(6) {

animation: wave 0.8s linear infinite alternate;

}

则效果如下

1460000022183906

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值