效果演示:
代码目录:
主要代码实现:
部分HTML代码 :
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>悬挂摇摆的弹珠动画特效</title>
<script type="text/javascript" src="js/jquery.min.js"></script>
<style type="text/css">
html {
background: black;
}
body {
margin: 0;
padding: 0;
}
.swinger {
width: 1px;
height: 0px;
margin: 0 auto;
position: relative;
min-height: 400px;
}
li {
position: absolute;
top: 10px;
left: 50%;
width: 1px;
height: 1px;
list-style: none;
animation: swing alternate infinite ease-in-out;
}
.string {
display: block;
width: 1px;
background-color: rgba(255, 255, 255, 0.3);
}
.ball {
display: block;
width: 25px;
height: 25px;
-moz-border-radius: 30px;
-webkit-border-radius: 30px;
border-radius: 30px;
background: url('') -3px -5px;
background: -moz-radial-gradient(#bbb5c7, #737374 70%) -3px -5px;
background: -webkit-radial-gradient(#bbb5c7, #737374 70%) -3px -5px;
background: radial-gradient(#bbb5c7, #737374 70%) -3px -5px;
border: 1px solid #c8c8c8;
content: " ";
position: relative;
-moz-box-shadow: 0 2px 2px 1px rgba(0, 0, 0, 0.2), -2px -2px 4px 3px rgba(0, 0, 0, 0.1) inset;
-webkit-box-shadow: 0 2px 2px 1px rgba(0, 0, 0, 0.2), -2px -2px 4px 3px rgba(0, 0, 0, 0.1) inset;
box-shadow: 0 2px 2px 1px rgba(0, 0, 0, 0.2), -2px -2px 4px 3px rgba(0, 0, 0, 0.1) inset;
}
@keyframes swing {
from {
-moz-transform: rotate(-25deg);
-ms-transform: rotate(-25deg);
-webkit-transform: rotate(-25deg);
transform: rotate(-25deg);
}
to {
-moz-transform: rotate(25deg);
-ms-transform: rotate(25deg);
-webkit-transform: rotate(25deg);
transform: rotate(25deg);
}
}
</style>
</head>
<body>
<ul class="swinger"></ul>
<script>
var swinger = $(".swinger");
// Insert DOM
for (var i = 0; i < 15; i++) {
var stringContainer = document.createElement('li');
var string = document.createElement('span');
var ball = document.createElement('span');
stringContainer.className = 'no' + i;
string.className = "string";
ball.className = "ball";
swinger.append(stringContainer);
$(stringContainer).append(string, ball);
}
var g = 9.8; // gravity
var maxOsc = 15; // number of oscillations the longest pendulum performs in the cycle
var duration = 240; // duration of one cycle in seconds
// Calculate string heights
var height = [];
for (var j = 0; j < 15; j++) {
var length = g * duration / Math.pow((2 * Math.PI * (maxOsc + j)), 2); // equation to calculate string lengths for harmonic wave pendulum
height.push(length);
}
height.reverse();
var sizeCoeff = 150;
// Use harmonic pendulum equation to animate
var elements = $("li");
for (var k = 0; k < 15; k++) {
var that = elements[k];
var time = 2 * Math.PI * Math.sqrt(height[k] / g); // harmonic wave pendulum equation
var size = sizeCoeff * height[k];
$(".string", that).height(size * 10); // magic numbers for string length in px
$(".ball", that)
.height(size)
.width(size)
.css('left', (-1 / 2) * size);
$(that).attr("style", "animation-duration: " + time + "s;");
};
</script>
</body>
</html>
上面的jquery.min.js需要引入即可运行
源码获取
精彩推荐更新中:
HTML5大作业实战100套
打卡 文章 更新 37 / 100天
大家可以点赞、收藏、关注、评论我啦 、需要完整文件随时联系我或交流哟~!