css制作弹球
CSS 制作弹球效果
弹球效果可以通过 CSS 动画和关键帧实现,以下是一个完整的实现方法。
HTML 结构
创建一个简单的 HTML 结构,包含一个弹球元素和一个容器:
<div class="container">
<div class="ball"></div>
</div>
CSS 样式
通过 CSS 定义弹球的样式和动画效果:
.container {
width: 300px;
height: 300px;
border: 2px solid #333;
position: relative;
overflow: hidden;
background: #f0f0f0;
}
.ball {
width: 50px;
height: 50px;
background: linear-gradient(135deg, #ff6b6b, #4ecdc4);
border-radius: 50%;
position: absolute;
animation: bounce 2s infinite cubic-bezier(0.5, 0.05, 0.5, 1);
}
@keyframes bounce {
0%, 100% {
bottom: 0;
left: 0;
transform: scale(1);
}
25% {
bottom: 250px;
left: 75px;
transform: scale(0.9);
}
50% {
bottom: 0;
left: 150px;
transform: scale(1.1);
}
75% {
bottom: 250px;
left: 225px;
transform: scale(0.9);
}
}
动画说明
@keyframes bounce定义了弹球的运动路径:- 从容器左下角开始弹起。
- 在 25% 和 75% 的关键帧中,弹球到达最高点。
- 在 50% 的关键帧中,弹球落回底部并向右移动。
cubic-bezier(0.5, 0.05, 0.5, 1)控制弹跳的缓动效果,模拟真实弹球运动。
进阶优化
为弹球添加阴影效果,增强立体感:
.ball {
box-shadow: 0 10px 20px rgba(0, 0, 0, 0.2);
}
调整动画时间或路径可以改变弹球的运动轨迹,例如增加横向移动距离或弹跳高度。







