html5箱子游戏源代码,html5 canvas绘制小人推箱子小游戏源码
特效描述:html5 canvas 小人推箱子 小游戏源码。html5 canvas绘图,原生JavaScript编写算法,html5推箱子小游戏,小人推箱子游戏源码下载。
代码结构
1. 引入JS
2. HTML代码
Document
*{
margin:0px;
padding:0px;
}
body{
overflow:hidden;
}
.game{
width:560px;
margin:50px auto;
}
var can = document.getElementById("canvas");
var msg = document.getElementById("msg");
var cxt = can.getContext("2d");
var w = 35,h = 35;
var curMap;//当前的地图
var curLevel;//当前等级的地图
var curMan;//初始化小人
var iCurlevel = 0;//关卡数
var moveTimes = 0;//移动了多少次
//预加载所有图片
var oImgs = {
"block" : "images/block.gif",
"wall" : "images/wall.png",
"box" : "images/box.png",
"ball" : "images/ball.png",
"up" : "images/up.png",
"down" : "images/down.png",
"left" : "images/left.png",
"right" : "images/right.png",
}
function imgPreload(srcs,callback){
var count = 0,imgNum = 0,images = {};
for(src in srcs){
imgNum++;
}
for(src in srcs ){
images[src] = new Image();
images[src].onload = function(){
//判断是否所有的图片都预加载完成
if (++count >= imgNum)
{
callback(images);
}
}
images[src].src = srcs[src];
}
}
var block,wall,box,ball,up,down,left,right;
imgPreload(oImgs,function(images){
//console.log(images.block);
block = images.block;
wall = images.wall;
box = images.box;
ball = images.ball;
up = images.up;
down = images.down;
left = images.left;
right = images.right;
init();
});
//初始化游戏
function init(){
//InitMap();
//DrawMap(levels[0]);
initLevel();//初始化对应等级的游戏
showMoveInfo();//初始化对应等级的游戏数据
}
//绘制地板
function InitMap(){
for (var i=0;i<16 ;i++ )
{
for (var j=0;j<16 ;j++ )
{
cxt.drawImage(block,w*j,h*i,w,h);
}
}
}
//小人位置坐标
function Point(x,y){
this.x = x;
this.y = y;
}
var perPosition = new Point(5,5);//小人的初始标值
//绘制每个游戏关卡地图
function DrawMap(level){
for (var i=0;i
{
for (var j=0;j
{
var pic = block;//初始图片
switch (level[i][j])
{
case 1://绘制墙壁
pic = wall;
break;
case 2://绘制陷进
pic = ball;
break;
case 3://绘制箱子
pic = box;
break;
case 4://绘制小人
pic = curMan;//小人有四个方向 具体显示哪个图片需要和上下左右方位值关联
//获取小人的坐标位置
perPosition.x = i;
perPosition.y = j;
break;
case 5://绘制箱子及陷进位置
pic = box;
break;
}
//每个图片不一样宽 需要在对应地板的中心绘制地图
cxt.drawImage(pic,w*j-(pic.width-w)/2,h*i-(pic.height-h),pic.width,pic.height)
}
}
}
//初始化游戏等级
function initLevel(){
curMap = copyArray(levels[iCurlevel]);//当前移动过的游戏地图
curLevel = levels[iCurlevel];//当前等级的初始地图
curMan = down;//初始化小人
InitMap();//初始化地板
DrawMap(curMap);//绘制出当前等级的地图
}
//下一关
function NextLevel(i){
//iCurlevel当前的地图关数
iCurlevel = iCurlevel + i;
if (iCurlevel<0)
{
iCurlevel = 0;
return;
}
var len = levels.length;
if (iCurlevel > len-1)
{
iCurlevel = len-1;
}
initLevel();//初始当前等级关卡
moveTimes = 0;//游戏关卡移动步数清零
showMoveInfo();//初始化当前关卡数据
}
//小人移动
function go(dir){
var p1,p2;
switch (dir)
{
case "up":
curMan = up;
//获取小人前面的两个坐标位置来进行判断小人是否能够移动
p1 = new Point(perPosition.x-1,perPosition.y);
p2 = new Point(perPosition.x-2,perPosition.y);
break;
case "down":
curMan = down;
p1 = new Point(perPosition.x+1,perPosition.y);
p2 = new Point(perPosition.x+2,perPosition.y);
break;
case "left":
curMan = left;
p1 = new Point(perPosition.x,perPosition.y-1);
p2 = new Point(perPosition.x,perPosition.y-2);
break;
case "right":
curMan = right;
p1 = new Point(perPosition.x,perPosition.y+1);
p2 = new Point(perPosition.x,perPosition.y+2);
break;
}
//若果小人能够移动的话,更新游戏数据,并重绘地图
if (Trygo(p1,p2))
{
moveTimes ++;
showMoveInfo();
}
//重绘地板
InitMap();
//重绘当前更新了数据的地图
DrawMap(curMap);
//若果移动完成了进入下一关
if (checkFinish())
{
alert("恭喜过关!!");
NextLevel(1);
}
}
//判断是否推成功
function checkFinish(){
for (var i=0;i
{
for (var j=0;j
{
//当前移动过的地图和初始地图进行比较,若果初始地图上的陷进参数在移动之后不是箱子的话就指代没推成功
if (curLevel[i][j] == 2 && curMap[i][j] != 3 || curLevel[i][j] == 5 && curMap[i][j] != 3)
{
return false;
}
}
}
return true;
}
//判断小人是否能够移动
function Trygo(p1,p2){
if(p1.x<0) return false;//若果超出地图的上边,不通过
if(p1.y<0) return false;//若果超出地图的左边,不通过
if(p1.x>curMap.length) return false;//若果超出地图的下边,不通过
if(p1.y>curMap[0].length) return false;//若果超出地图的右边,不通过
if(curMap[p1.x][p1.y]==1) return false;//若果前面是墙,不通过
if (curMap[p1.x][p1.y]==3 || curMap[p1.x][p1.y]==5)
{//若果小人前面是箱子那就还需要判断箱子前面有没有障碍物(箱子/墙)
if (curMap[p2.x][p2.y]==1 || curMap[p2.x][p2.y]==3)
{
return false;
}
//若果判断不成功小人前面的箱子前进一步
curMap[p2.x][p2.y] = 3;//更改地图对应坐标点的值
//console.log(curMap[p2.x][p2.y]);
}
//若果都没判断成功小人前进一步
curMap[p1.x][p1.y] = 4;//更改地图对应坐标点的值
//若果小人前进了一步,小人原来的位置如何显示
var v = curLevel[perPosition.x][perPosition.y];
if (v!=2)//若果刚开始小人位置不是陷进的话
{
if (v==5)//可能是5 既有箱子又陷进
{
v=2;//若果小人本身就在陷进里面的话移开之后还是显示陷进
}else{
v=0;//小人移开之后之前小人的位置改为地板
}
}
//重置小人位置的地图参数
curMap[perPosition.x][perPosition.y] = v;
//若果判断小人前进了一步,更新坐标值
perPosition = p1;
//若果小动了 返回true 指代能够移动小人
return true;
}
//判断是否推成功
//与键盘上的上下左右键关联
function doKeyDown(event){
switch (event.keyCode)
{
case 37://左键头
go("left");
break;
case 38://上键头
go("up");
break;
case 39://右箭头
go("right");
break;
case 40://下箭头
go("down");
break;
}
}
//完善关卡数据及游戏说明
function showMoveInfo(){
msg.innerHTML = "第" + (iCurlevel+1) +"关 移动次数: "+ moveTimes;
}
//游戏说明
var showhelp = false;
function showHelp(){
showhelp = !showhelp;
if (showhelp)
{
msg.innerHTML = "用键盘上的上、下、左、右键移动小人,把箱子全部推到小球的位置即可过关。箱子只可向前推,不能往后拉,并且小人一次只能推动一个箱子。";
}else{
showMoveInfo();
}
}
//克隆二维数组
function copyArray(arr){
var b=[];//每次移动更新地图数据都先清空再添加新的地图
for (var i=0;i
{
b[i] = arr[i].concat();//链接两个数组
}
return b;
}
html5箱子游戏源代码,html5 canvas绘制小人推箱子小游戏源码相关推荐
- 推箱子android源代码,android自定义view实现推箱子小游戏
本文实例为大家分享了android推箱子游戏的具体实现代码,供大家参考,具体内容如下 自定义view: package com.jisai.materialdesigndemo.tuixiangzhi ...
- java多线程围棋小游戏代码,java小游戏源代码(java开发的50个小游戏)
<扫雷>是一款大家类的益智类游戏,游戏训练目标是在最少的時间内依据点一下方格出現的数据找到全部非雷方格,另外防止爆雷,碰到一个雷即满盘皆输. 经典推箱子,目地是在训炼你的逻辑性思索工作能力 ...
- python3小游戏源代码_如何用python3代码玩小游戏?
在大家的印象中,程序员似乎一直是在码代码的,做着枯燥无聊的生活,殊不知,他们其实也有很多在编程中的快乐.小编最羡慕的就是他们能写一段小程序运行出来,好玩又好看,看起来还很高大上!为了照顾众多pytho ...
- 基于HTML(canvas)的推箱子游戏
基于HTML(canvas)的推箱子游戏.zip 有积分的自己自行下载吧,没有积分的兄弟可以评论留邮箱,看到后会给你们发过去. 游戏截图 设计过程 1. 设计目标:推箱子游戏2. 设计思路 ...
- java计算机毕业设计HTML5互动游戏新闻网站设计与实现MyBatis+系统+LW文档+源码+调试部署
java计算机毕业设计HTML5互动游戏新闻网站设计与实现MyBatis+系统+LW文档+源码+调试部署 java计算机毕业设计HTML5互动游戏新闻网站设计与实现MyBatis+系统+LW文档+源码 ...
- java计算机毕业设计HTML5游戏网站设计与实现MyBatis+系统+LW文档+源码+调试部署
java计算机毕业设计HTML5游戏网站设计与实现MyBatis+系统+LW文档+源码+调试部署 java计算机毕业设计HTML5游戏网站设计与实现MyBatis+系统+LW文档+源码+调试部署 本源 ...
- html5制作端午节游戏,零代码怎么制作一个端午节H5小游戏页面?
不光端午节,任何小游戏类型都可以轻松搞定! 六月已经过了三分之一,"粽子节"也马上要到了,每当这时候,又到新媒体运营人和设计师头秃的时刻,在传统的节日里,如何把传统的节日使用互联网 ...
- HTML5期末大作业:花店购物网站设计——花店购物网站源码(27页) 学生动花店购物页设计模板下载 植物大学生HTML网页制作作品 简单网页设计成品 dreamweaver学生网站模板
HTML5期末大作业:花店购物网站设计--花店购物网站源码(27页) 学生动花店购物页设计模板下载 植物大学生HTML网页制作作品 简单网页设计成品 dreamweaver学生网站模板 常见网页设计作 ...
- java计算机毕业设计HTML5“守护萌宠”网站设计与实现MyBatis+系统+LW文档+源码+调试部署
java计算机毕业设计HTML5"守护萌宠"网站设计与实现MyBatis+系统+LW文档+源码+调试部署 java计算机毕业设计HTML5"守护萌宠"网站设计与 ...
- 《uni-app》一个非canvas的飞机对战小游戏实现-碰撞检测的实现
这是一个没有套路的前端博主,热衷各种前端向的骚操作,经常想到哪就写到哪,如果有感兴趣的技术和前端效果可以留言-博主看到后会去代替大家踩坑的-接下来的几篇都是uni-app的小实战,有助于我们更好的去学 ...
最新文章
- Java项目:在线考试系统(单选,多选,判断,填空,简答题)(java+Springboot+ssm+mysql+html+maven)
- java协变返回类型_Java中的协变返回类型
- Redis之key的淘汰策略
- Spring AOP切入点
- idea 创建多模块项目子模块为灰色
- N划分成若干个奇正整数之和的分法有多少种---动态规划
- 浏览器同源策略及其规避方法
- 网站改版进行时,需要注意的
- c语言编程中句柄无效怎么解决,句柄无效,小编教你句柄无效怎么解决
- linux系统中ulimit命查看/设置堆栈空间大小
- 【Monkey Run】Excel编程 VBA
- 什么时候要进行大小端字节序的转换?
- 对敏捷管理模式核心价值的解读
- 百度松果 买礼物(贪心)
- 支付宝客户端架构分析:自动化日志收集及分析 1
- 数据挖掘:探索性数据分析(EDA)
- 团队开发背景及团队分工
- 人工智能将如何助力5G的发展?
- 网上赚钱的门路方法,大部分人都是利用这三种方法!
- 计算机网络之TCP粘包、拆包