>  기사  >  웹 프론트엔드  >  jQuery와 HTML5_jquery를 결합하여 제작한 사랑나무 고백 애니메이션

jQuery와 HTML5_jquery를 결합하여 제작한 사랑나무 고백 애니메이션

WBOY
WBOY원래의
2016-05-16 16:16:473077검색

HTML 코드는 다음과 같습니다.

코드 복사 코드는 다음과 같습니다.


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">






本页面采用HTML5技术,目前您的浏览器无法显示,请使用支持HTML5的浏览器查看本页。




亲爱的何文琪:



曾经,

有一份真挚的爱情摆在我面前,

我没有珍惜,

等到我失去的时候才后悔莫及,
   
人世间最痛苦的事莫过于此......

如果上天能够给我一个再来一次的机会,

我会对那个女孩子说六个字:

何文琪我爱你!

如果非要在这份爱上加一个期限,

我希望是.....

一万年!

-- 爱你的柯乐义--











(함수(){
var 캔버스 = $('#ke' 'leyi');
if (!canvas[0].getContext) {
$("#error").show();
거짓을 반환; }
var 너비 = canvas.width();
var 높이 = canvas.height();
canvas.attr("너비", 너비);
canvas.attr("높이", 높이);
var 선택 = {
시드: {
x: 너비 / 2 - 20,
색상: "rgb(190, 26, 37)",
규모: 2
},
분기: [
[535, 680, 570, 250, 500, 200, 30, 100, [
[540, 500, 455, 417, 340, 400, 13, 100, [
[450, 435, 434, 430, 394, 395, 2, 40]
]],
[550, 445, 600, 356, 680, 345, 12, 100, [
[578, 400, 648, 409, 661, 426, 3, 80]
]],
[539, 281, 537, 248, 534, 217, 3, 40],
[546, 397, 413, 247, 328, 244, 9, 80, [
[427, 286, 383, 253, 371, 205, 2, 40],
[498, 345, 435, 315, 395, 330, 4, 60]
]],
[546, 357, 608, 252, 678, 221, 6, 100, [
[590, 293, 646, 277, 648, 271, 2, 80]
]]
]]
],
꽃: {
숫자: 700,
너비: 1080,
키: 650,
},
바닥글: {
너비: 1200,
키: 5,
속도: 10,
}
}
var tree = new Tree(canvas[0], 너비, 높이, opts);
var 씨앗 = tree.seed;
var foot = tree.footer;
varhold = 1;
canvas.click(함수(e) {
var 오프셋 = canvas.offset(), x, y;
x = e.pageX - offset.left;
y = e.pageY - offset.top;
if (seed.hover(x, y)) {
보유 = 0;
canvas.unbind("클릭");
canvas.unbind("mousemove");
canvas.removeClass('손');
}
}).mousemove(함수(e){
var 오프셋 = canvas.offset(), x, y;
x = e.pageX - offset.left;
y = e.pageY - offset.top;
canvas.toggleClass('hand', seed.hover(x, y));
});
var seedAnimate = eval(Jscex.compile("async", function () {
Seed.draw();
동안(길게 누르기) {
$await(Jscex.Async.sleep(10));
}
while (seed.canScale()) {
seed.scale(0.95);
$await(Jscex.Async.sleep(10));
}
while (seed.canMove()) {
seed.move(0, 2);
foot.draw();
$await(Jscex.Async.sleep(10));
}
}));
var 성장Animate = eval(Jscex.compile("async", function () {
하세요 {
tree.grow();
$await(Jscex.Async.sleep(10));
} while (tree.canGrow());
}));
var flowAnimate = eval(Jscex.compile("async", function () {
하세요 {
tree.flower(2);
$await(Jscex.Async.sleep(10));
} while (tree.canFlower());
}));
var moveAnimate = eval(Jscex.compile("async", function () {
tree.snapshot("p1", 240, 0, 610, 680);
while (tree.move("p1", 500, 0)) {
foot.draw();
$await(Jscex.Async.sleep(10));
}
foot.draw();
tree.snapshot("p2", 500, 0, 610, 680);
// 会有闪烁不得意这样做, (>﹏ canvas.parent().css("배경", "url(" tree.toDataURL('image/png') ")");
canvas.css("배경", "#ffe");
$await(Jscex.Async.sleep(300));
canvas.css("배경", "없음");
}));
var jumpAnimate = eval(Jscex.compile("async", function () {
var ctx = tree.ctx;
동안 (사실) {
tree.ctx.clearRect(0, 0, 너비, 높이);
tree.jump();
foot.draw();
$await(Jscex.Async.sleep(25));
}
}));
var textAnimate = eval(Jscex.compile("async", function () {
$("#code").show().typewriter();
}));
var runAsync = eval(Jscex.compile("async", function () {
$await(seedAnimate());
$await(growAnimate());
$await(flowAnimate());
$await(moveAnimate());
textAnimate().start();
$await(jumpAnimate());
}));
runAsync().start();
})();


适用浏览器:360、FireFox、Chrome、Safari、Opera、傲游、搜狗、世界之窗. 不支持IE8及以下浏览器。




성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.