基本信息
源码名称:html5 拼图游戏源码下载
源码大小:0.74M
文件格式:.zip
开发语言:CSS
更新时间:2017-05-13
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
<!DOCTYPE html>
<html lang="en">
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1">
<meta content="yes" name="apple-mobile-web-app-capable">
<meta content="yes" name="apple-touch-fullscreen">
<meta content="black" name="apple-mobile-web-app-status-bar-style">
<meta name="keywords" content="html5, 拼图, 游戏">
<meta name="description" content="疯狂动物城呢,去看看吧!">
<title>拼图小游戏</title>
<link rel="shortcut icon" type="image/x-icon" href="http://static.yangbai.me/images/favicon.ico">
<link rel="stylesheet" href="index.css">
<link rel="stylesheet" href="rem.css">
</head>
<body>
<div class="page1">
<img src="tuzi.jpg" alt="兔子" style="opacity: 0;width: 0;height: 0;">
<!--<h2 class="page1-tit" id="pageTitle"></h2>-->
<button id="reset" class="game-reset-btn" disabled>重新开始</button>
<div class="game-box">
<div class="game-pop-box ui-center play" id="layer">
<div class="game-warp">
<div class="game-pop-hd">
<h2>挑战失败!</h2>
<p>再接再厉!</p>
</div>
<a href="javascript:;" class="game-start-btn play-btn" id="start">开始</a>
</div>
</div>
<ul id="gameBox">
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
<li><img src="" alt=""></li>
</ul>
</div>
<span class="play-time" id="timing">?</span>
<p class="pages">
第 <strong id="level">?</strong> / <span id="levels">?</span> 关,
本关限时<span id="time">?</span>秒
</p>
</div>
<canvas id="canvas" style="display: none" width="300" height="300"></canvas>
<script type="text/javascript" src="zepto.js"></script>
<script type="text/javascript">
var doc = document;
var canvas = doc.getElementById('canvas');
var ctx = canvas.getContext('2d');
var $gameBox = $('#gameBox');
var $lis = $gameBox.find('li');
var image = new Image();
var oriArr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
var imgArr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
var App = {
timeHandle: null,
isComplete: false,
level: 0,
levels: [
{time: "60.00", image: "shulan.jpg"},
{time: "40.00", image: "tuzi.jpg"},
{time: "30.00", image: "together.jpg"}
],
bind: function() {
//阻止手机上浏览器的弹性下拉。。。
$('body').on('touchstart', function(e) {
e.preventDefault();
});
$lis.on('swipeLeft', function(e) {
e.preventDefault();
var $this = $(this);
var index = $this.index();
var html = $this.html();
var $prev = $this.prev();
if ($.inArray(index, [3, 6]) > -1 || $prev.size() <= 0) {
return false;
}
$this.html($prev.html());
$prev.html(html);
App.check();
});
$lis.on('swipeRight', function(e) {
e.preventDefault();
var $this = $(this);
var index = $this.index();
var html = $this.html();
var $next = $this.next();
if ($.inArray(index, [2, 5]) > -1 || $next.size() <= 0) {
return false;
}
$this.html($next.html());
$next.html(html);
App.check();
});
$lis.on('swipeUp', function(e) {
e.preventDefault();
var $this = $(this);
var html = $this.html();
var index = $this.index() - 3;
var $up = $lis.eq(index);
if (index >= 0 && $up.size() > 0) {
$this.html($up.html());
$up.html(html);
App.check();
}
});
$lis.on('swipeDown', function(e) {
e.preventDefault();
var $this = $(this);
var html = $this.html();
var index = $this.index() 3;
var $down = $lis.eq(index);
if (index < 9 && $down.size() > 0) {
$this.html($down.html());
$down.html(html);
App.check();
}
});
$('#start').on('tap', function() {
$('#reset').prop('disabled', false);
//再来一次的时候 顺序不变哦
if ($(this).html() !== '再来一次') {
App.randomImage(true);
} else {
App.randomImage();
}
App.resetData();
App.countdown();
$('#layer').hide();
});
$('#reset').on('tap', function() {
App.resetData();
App.countdown();
App.randomImage(true);
});
},
countdown: function() {
clearInterval(this.timeHandle);
this.timeHandle = setInterval(function() {
var $time = $('#timing');
var time = parseFloat($time.text());
var currTime = (time - 0.01).toFixed(2);
if (currTime < 0) {
clearInterval(App.timeHandle);
$time.text(parseInt(currTime).toFixed(2));
App.update();
} else {
$time.text(currTime);
}
}, 10);
},
resetData: function() {
var time = this.levels[this.level].time;
$('#timing').text(time);
$('#time').text(time);
$('#level').text(this.level 1);
$('#levels').text(this.levels.length);
},
init: function() {
$('#reset').prop('disabled', true);
this.resetData();
imgArr = [1, 2, 3, 4, 5, 6, 7, 8, 9];
this.render();
},
render: function() {
image.onload = function() {
App.randomImage();
}
image.src = this.levels[this.level].image;
},
randomImage: function(flag) {
flag = flag || false;
if (flag) {
imgArr.sort(function(a, b) {
return Math.random() - Math.random();
});
}
var index = 1;
for (var i=0; i<3; i ) {
for (var j=0; j<3; j ) {
ctx.drawImage(image, 300*j, 300*i, 300, 300, 0, 0, 300, 300);
$lis.eq(imgArr[index-1]-1).find('img').data('seq', index).attr('src', canvas.toDataURL('image/jpeg'));
index ;
}
}
},
check: function() {
var resArr = [];
$('#gameBox img').each(function(k, v) {
resArr.push(v.getAttribute("data-seq"));
});
if (resArr.join("") === oriArr.join("")) {
setTimeout(function() {
//App.isComplete = true;
window.clearInterval(App.timeHandle);
if (App.level >= App.levels.length-1) {
alert("哇塞,你居然通关了,好棒!");
App.destory();
} else {
if (confirm("恭喜过关,是否继续挑战?")) {
App.level ;
$('#layer').show();
App.init();
}
}
}, 300);
}
},
update: function() {
if (this.isComplete === false) {
alert("时间到,游戏结束!");
$('#layer').show();
$('#start').html("再来一次");
$('#reset').prop('disabled', true);
}
},
destory: function() {
$('#reset').prop('disabled', true);
$lis.off("swipeLeft");
$lis.off("swipeRight");
$lis.off("swipeUp");
$lis.off("swipeDown");
$lis.css('border', 0);
$gameBox.css('border', 0);
},
start: function() {
this.init();
this.render();
this.bind();
},
};
App.start();
</script>
</body>
</html>