最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

HTML5游戏框架cnGameJS开发实录-游戏地图对象篇

来源:动视网 责编:小采 时间:2020-11-27 15:10:29
文档

HTML5游戏框架cnGameJS开发实录-游戏地图对象篇

HTML5游戏框架cnGameJS开发实录-游戏地图对象篇:1.什么场合需要用到游戏地图对象? 游戏地图对象适用于类似坦克大战,推箱子之类的游戏。这些游戏的地图都由一个个小格子组成,使用游戏地图对象,可以很方便地生成这种地图。2.示例:生成地图 使用地图对象,只需要很少的代码量就可以根据二维数组生成地图。
推荐度:
导读HTML5游戏框架cnGameJS开发实录-游戏地图对象篇:1.什么场合需要用到游戏地图对象? 游戏地图对象适用于类似坦克大战,推箱子之类的游戏。这些游戏的地图都由一个个小格子组成,使用游戏地图对象,可以很方便地生成这种地图。2.示例:生成地图 使用地图对象,只需要很少的代码量就可以根据二维数组生成地图。
 1.什么场合需要用到游戏地图对象?

  游戏地图对象适用于类似坦克大战,推箱子之类的游戏。这些游戏的地图都由一个个小格子组成,使用游戏地图对象,可以很方便地生成这种地图。

2.示例:生成地图

  使用地图对象,只需要很少的代码量就可以根据二维数组生成地图。

  代码:

<body>
<canvas id="gameCanvas">请使用支持canvas的浏览器查看</canvas>
</body>
<script src="http://files.cnblogs.com/Cson/cnGame_v1.0.js"></script>
<script>
/* 地图绘制test */

cnGame.init('gameCanvas',{width:200,height:200});
var gameObj={};
gameObj.initialize=function(){

 var mapMatrix=[ 
 [1,1,1,1,1],
 [1,0,1,0,1],
 [1,0,0,0,1],
 [1,1,0,0,1],
 [1,1,1,1,1]
 ];
 
 var map=cnGame.Map(mapMatrix,{cellSize:[40,40]});
 map.draw({"1":{src:"brick.gif",x:0,y:0},"0":{src:"floor.png",x:0,y:0}});
}
cnGame.loader.start(["brick.gif","floor.png"],gameObj);
</script>

  生成的地图:

  只要转入地图的二维矩阵,并告诉地图对象哪个值对应哪张图片,就可以生成地图。

3.实现

  接下来讲解如何用代码实现地图对象。首先看初始化函数:

map.prototype={
 /**
 *初始化
 **/ 
 init:function(mapMatrix,options){
 /**
 *默认对象
 **/ 
 var defaultObj={
 cellSize:[32,32], //方格宽,高
 beginX:0, //地图起始x
 beginY:0 //地图起始y
 
 };
 options=options||{};
 options=cg.core.extend(defaultObj,options);
 this.mapMatrix=mapMatrix;
 this.cellSize=options.cellSize;
 this.beginX=options.beginX;
 this.beginY=options.beginY;
 this.row=mapMatrix.length;//有多少行
 
 },

  要确定一个地图对象,首先需要确定的参数包括:地图格子的尺寸,地图的起始x坐标,起始y坐标。之后可以根据这些参数生成并绘制地图对象,之后再看看如何根据参数绘制地图:

/**
 *根据map矩阵绘制map
 **/ 
 draw:function(options){//options:{"1":{src:"xxx.png",x:0,y:0},"2":{src:"xxx.png",x:1,y:1}}
 var mapMatrix=this.mapMatrix;
 var beginX=this.beginX;
 var beginY=this.beginY;
 var cellSize=this.cellSize;
 var currentRow;
 var currentCol
 var currentObj;
 var row=this.row;
 var img;
 for(var i=beginY,ylen=beginY+row*cellSize[1];i<ylen;i+=cellSize[1]){ //根据地图矩阵,绘制每个方格
 currentRow=(i-beginY)/cellSize[1];
 for(var j=beginX,xlen=beginX+mapMatrix[currentRow].length*cellSize[0];j<xlen;j+=cellSize[0]){
 currentCol=(j-beginX)/cellSize[0];
 currentObj=options[mapMatrix[currentRow][currentCol]];
 img=cg.loader.loadedImgs[currentObj.src];
 cg.context.drawImage(img,currentObj.x,currentObj.y,cellSize[0],cellSize[1],j,i,cellSize[0],cellSize[1]);//绘制特定坐标的图像
 }
 }
 
 },

  在draw方法中,根据起始坐标和格子尺寸,逐个绘制地图格子。格子与二维矩阵的每个元素一一对应,图片选择的依据就是二维矩阵对应的值,在上面的例子中,1则绘制砖头,2则绘制地板。

/**
 *获取特定对象在地图中处于的方格的值
 **/
 getPosValue:function(elem){
 return this.mapMatrix[Math.floor(elem.y/this.cellSize[1])][Math.floor(elem.x/this.cellSize[0])];
 
 }

  另外可以通过getPosValue获取元素所在地图位置的值。该方法在判断游戏对象所处地图位置时很有用。

地图对象所有源码:

/**
 *
 *地图
 *
**/
cnGame.register("cnGame",function(cg){
 
 var map=function(mapMatrix,options){
 
 if(!(this instanceof arguments.callee)){
 return new arguments.callee(mapMatrix,options);
 }
 this.init(mapMatrix,options);
 }
 map.prototype={
 /**
 *初始化
 **/ 
 init:function(mapMatrix,options){
 /**
 *默认对象
 **/ 
 var defaultObj={
 cellSize:[32,32], //方格宽,高
 beginX:0, //地图起始x
 beginY:0 //地图起始y
 
 };
 options=options||{};
 options=cg.core.extend(defaultObj,options);
 this.mapMatrix=mapMatrix;
 this.cellSize=options.cellSize;
 this.beginX=options.beginX;
 this.beginY=options.beginY;
 this.row=mapMatrix.length;//有多少行
 
 },
 /**
 *根据map矩阵绘制map
 **/ 
 draw:function(options){//options:{"1":{src:"xxx.png",x:0,y:0},"2":{src:"xxx.png",x:1,y:1}}
 var mapMatrix=this.mapMatrix;
 var beginX=this.beginX;
 var beginY=this.beginY;
 var cellSize=this.cellSize;
 var currentRow;
 var currentCol
 var currentObj;
 var row=this.row;
 var img;
 for(var i=beginY,ylen=beginY+row*cellSize[1];i<ylen;i+=cellSize[1]){ //根据地图矩阵,绘制每个方格
 currentRow=(i-beginY)/cellSize[1];
 for(var j=beginX,xlen=beginX+mapMatrix[currentRow].length*cellSize[0];j<xlen;j+=cellSize[0]){
 currentCol=(j-beginX)/cellSize[0];
 currentObj=options[mapMatrix[currentRow][currentCol]];
 img=cg.loader.loadedImgs[currentObj.src];
 cg.context.drawImage(img,currentObj.x,currentObj.y,cellSize[0],cellSize[1],j,i,cellSize[0],cellSize[1]);//绘制特定坐标的图像
 }
 }
 
 },
 /**
 *获取特定对象在地图中处于的方格的值
 **/
 getPosValue:function(elem){
 return this.mapMatrix[Math.floor(elem.y/this.cellSize[1])][Math.floor(elem.x/this.cellSize[0])];
 
 }
 
 }
 this.Map=map;
 
});

文档

HTML5游戏框架cnGameJS开发实录-游戏地图对象篇

HTML5游戏框架cnGameJS开发实录-游戏地图对象篇:1.什么场合需要用到游戏地图对象? 游戏地图对象适用于类似坦克大战,推箱子之类的游戏。这些游戏的地图都由一个个小格子组成,使用游戏地图对象,可以很方便地生成这种地图。2.示例:生成地图 使用地图对象,只需要很少的代码量就可以根据二维数组生成地图。
推荐度:
标签: 游戏 对象 html5
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top