http://www.w3.org/1999/xhtml">
charset="UTF-8" >
程序员用HTML5制作的爱心树表白动画- 柯乐义 http://keleyi.com/keleyi/phtml/html5/" />
http://keleyi.com/keleyi/phtml/html5/31/renxi/default.css">
http://keleyi.com/keleyi/pmedia/jquery/jquery-1.11.2.min.js">>
http://keleyi.com/keleyi/phtml/html5/31/renxi/jscex.min.js">>
http://keleyi.com/keleyi/phtml/html5/31/renxi/jscex-parser.js">>
http://keleyi.com/keleyi/phtml/html5/31/renxi/jscex-jit.js">>
http://keleyi.com/keleyi/phtml/html5/31/renxi/jscex-builderbase.min.js">>
http://keleyi.com/keleyi/phtml/html5/31/renxi/jscex-async.min.js">>
http://keleyi.com/keleyi/phtml/html5/31/renxi/jscex-async-powerpack.min.js">>
本页面采用HTML5技术,目前您的浏览器无法显示,请使用支持HTML5的浏览器查看本页。
亲爱的何文琪:
曾经,
有一份真挚的爱情摆在我面前,
我没有珍惜,
等到我失去的时候才后悔莫及,
人世间最痛苦的事莫过于此......
如果上天能够给我一个再来一次的机会,
我会对那个女孩子说六个字:
何文琪我爱你!
如果非要在这份爱上加一个期限,
我希望是.....
一万年!
-- 爱你的柯乐义--
<script><br>
(fonction(){<br>
var toile = $('#ke' 'leyi');<br>
si (!canvas[0].getContext) {<br>
$("#erreur").show();<br>
renvoie faux ; ><br>
var largeur = toile.width();<br>
var hauteur = toile.hauteur(); <br>
canvas.attr("largeur", largeur);<br>
canvas.attr("hauteur", hauteur);<br>
var opts = {<br>
graine : {<br>
x : largeur / 2 - 20,<br>
couleur : "rgb(190, 26, 37)",<br>
échelle : 2<br>
},<br>
succursale : [<br>
[535, 680, 570, 250, 500, 200, 30, 100, [<br>
[540, 500, 455, 417, 340, 400, 13, 100, [<br>
[450, 435, 434, 430, 394, 395, 2, 40]<br>
]],<br>
[550, 445, 600, 356, 680, 345, 12, 100, [<br>
[578, 400, 648, 409, 661, 426, 3, 80]<br>
]],<br>
[539, 281, 537, 248, 534, 217, 3, 40],<br>
[546, 397, 413, 247, 328, 244, 9, 80, [<br>
[427, 286, 383, 253, 371, 205, 2, 40],<br>
[498, 345, 435, 315, 395, 330, 4, 60]<br>
]],<br>
[546, 357, 608, 252, 678, 221, 6, 100, [<br>
[590, 293, 646, 277, 648, 271, 2, 80]<br>
]]<br>
]] <br>
],<br>
floraison : {<br>
numéro : 700,<br>
largeur : 1080,<br>
hauteur : 650,<br>
},<br>
pied de page : {<br>
largeur : 1200,<br>
hauteur: 5,<br>
vitesse : 10,<br>
><br>
><br>
var tree = new Tree(canvas[0], width, height, opts);<br>
var graine = arbre.seed;<br>
var pied = arbre.footer;<br>
var hold = 1;<br>
toile.clic(fonction(e) {<br>
var offset = canvas.offset(), x, y;<br>
x = e.pageX - offset.left;<br>
y = e.pageY - offset.top;<br>
if (seed.hover(x, y)) {<br>
tenir = 0 ; <br>
canvas.unbind("cliquez");<br>
canvas.unbind("mousemove");<br>
canvas.removeClass('hand');<br>
><br>
}).mousemove(function(e){<br>
var offset = canvas.offset(), x, y;<br>
x = e.pageX - offset.left;<br>
y = e.pageY - offset.top;<br>
canvas.toggleClass('hand', seed.hover(x, y));<br>
});<br>
var seedAnimate = eval(Jscex.compile("async", function () {<br>
seed.draw();<br>
pendant que (maintenir) {<br>
$attendre(Jscex.Async.sleep(10));<br>
><br>
while (seed.canScale()) {<br>
graine.scale(0.95);<br>
$attendre(Jscex.Async.sleep(10));<br>
><br>
while (seed.canMove()) {<br>
graine.move(0, 2);<br>
foot.draw();<br>
$attendre(Jscex.Async.sleep(10));<br>
><br>
}));<br>
var growAnimate = eval(Jscex.compile("async", function () {<br>
faire {<br>
arbre.grow();<br>
$attendre(Jscex.Async.sleep(10));<br>
} while (tree.canGrow());<br>
}));<br>
var flowAnimate = eval(Jscex.compile("async", function () {<br>
faire {<br>
arbre.fleur(2);<br>
$attendre(Jscex.Async.sleep(10));<br>
} while (tree.canFlower());<br>
}));<br>
var moveAnimate = eval(Jscex.compile("async", function () {<br>
arbre.snapshot("p1", 240, 0, 610, 680);<br>
while (tree.move("p1", 500, 0)) {<br>
foot.draw();<br>
$attendre(Jscex.Async.sleep(10));<br>
><br>
foot.draw();<br>
arbre.snapshot("p2", 500, 0, 610, 680);<br>
// 会有闪烁不得意这样做, (>﹏<)<br>
canvas.parent().css("background", "url(" tree.toDataURL('image/png') ")");<br>
canvas.css("background", "#ffe");<br>
$attendre(Jscex.Async.sleep(300));<br>
canvas.css("background", "aucun");<br>
}));<br>
var jumpAnimate = eval(Jscex.compile("async", function () {<br>
var ctx = arbre.ctx;<br>
tandis que (vrai) {<br>
tree.ctx.clearRect(0, 0, largeur, hauteur);<br>
arbre.jump();<br>
foot.draw();<br>
$attendre(Jscex.Async.sleep(25));<br>
><br>
}));<br>
var textAnimate = eval(Jscex.compile("async", function () {<br>
$("#code").show().typewriter();<br>
}));<br>
var runAsync = eval(Jscex.compile("async", function () {<br>
$attendre(seedAnimate());<br>
$attendre(growAnimate());<br>
$attendre(flowAnimate());<br>
$attendre(moveAnimate());<br>
textAnimate().start();<br>
$attendre(jumpAnimate());<br>
}));<br>
runAsync().start();<br>
})();<br>
</script>