javascript异步编程系列——Jscex模拟重力场与google苹果logo的比较
重力场:地球重力作用的空间。在该空间中,每一点都有惟一的一个重力矢量与之相对应。
各种网络游戏,不管是3D的还是第一视角的,或者横版游戏(如冒险岛),模拟一个重力场是必须的。
先回顾一下谷歌在牛顿诞辰,logo换成了自由落体的苹果。
<html>
<script language="javascript">
var h = 0, v = 1;
window.setTimeout(aa, 2000);
function aa() {
var i = self.setInterval("bb()", 25);
}
function bb() {
var f = document.getElementById('fall');
var r = parseInt(f.style.right) + h;
var b = parseInt(f.style.bottom) - v;
f.style.right = r + 'px';
f.style.bottom = b + 'px';
if (b > -210) {
v += 2;
} else {
h = (v > 9) ? v * 0.1 : 0;
v *= (v > 9) ? -0.3 : 0;
}
}
</script>
<body>
<div id="fall" style="position: relative; right: -300px; bottom: -46px">
apple
</div>
</body>
</html>
可以看到setTimeout和setInterval!不去仔细琢磨逻辑,光从代码语意上,是非常令人费解的。
在没有口语编程之前,我非常想把代码写成这样:
<html>
<script language="javascript">
function drop() {
//自由落体
code here
//撞击地面之后
code here
//苹果摔烂
code here
}
</script>
<body>
<div id="fall" style="position: relative; right: -300px; bottom: -46px">
apple
</div>
<script language="javascript">
drop();
</script>
</body>
</html>
也只有这样的代码才能调用以后的口语编程接口!那么怎么才能写出这样漂亮的代码?
这个时候【jxcex】 闪亮登场!
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<title>Jscex Animation</title>
<script language="javascript" type="text/javascript" src="lib/uglifyjs-parser.js"></script>
<script language="javascript" type="text/javascript" src="src/jscex.js"></script>
<script language="javascript" type="text/javascript" src="src/jscex.builderBase.js"></script>
<script language="javascript" type=
- 发表评论
-
- 最新评论 更多>>