kity
Version:
Kity Graphic Library
59 lines (50 loc) • 2.05 kB
HTML
<html>
<head>
<title>Animate</title>
<script src="../dist/kity.js"></script>
<script>
window.onload = function () {
var paper = new kity.Paper(document.body);
paper.setViewBox(0, 0, 1200, 600);
// 定义反弹动画器
var bounce = new kity.Animator(0, 400, function(target, y, timeline) {
target.translate(0, timeline.getDelta());
});
// 定义颜色动画器
var colorChanger = new kity.Animator({
beginValue: function(target) {
return target.color;
},
finishValue: function(target) {
return target.color.inc('h', 90)
},
setter: function(target, color) {
target.fill(color);
}
});
// 定义形变函数
function atternuate(e) {
e.target.scale(1 + Math.sign((Math.random() - 0.5)) * Math.random());
}
for(var i = 0; i < 200; i++) {
var color = kity.Color.createHSL(i * 30 % 360, 80, 50);
var copy = new kity.Rect(5, 20, 0, 10).translate( i * 5, 0 );
copy.color = color;
copy.fill(color);
paper.addShape(copy);
bounce.start(copy, 500, 'easeInQuad', Math.random() * 5000).repeat(true, true).on('rollback', atternuate);
colorChanger.start(copy, 500, 'linear').repeat(true, true);
copy.fxTranslate(0, 300, '1s', 'easeInQuad', Math.random() * 5000);
copy.fxTranslate(100, -100, '0.1s', 'easeOutQuad');
copy.fxRotate(1080, '2s', 'linear', 500);
copy.fxScale(.5, .5, '0.8s', 'easeInElastic');
copy.fxTranslate(100, -200, '0.8s', 'easeOutElastic');
copy.fadeOut(300).fadeIn(1000).fadeTo(.5, 100);
}
};
</script>
</head>
<body>
</body>
</html>