欢迎来到天天文库
浏览记录
ID:38704583
大小:52.00 KB
页数:7页
时间:2019-06-17
《手游菱形地图解决方案》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、最早的有很多的2D游戏,地图看起来就像是俯视图一样,地图整体形状是个矩形的,地图的每一格也是个矩形,很多早期的RPG游戏就是这样。这样的地图实现起来很方便,地图的信息一般就存储在一个二维数组中,描画、定位也很方便。不过这样的缺点就是不太逼真,所以在3D技术出现之前(或者是因为出于效率的原因只能使用2D的情况下)有人想出了用2D的方式来模拟视觉上3D的效果,就是使用斜角地图块拼出的地图,这个斜角地图块的形状一般都是一个菱形,拼出后整块的地图也是个菱形,如下图:然后地图上有放置物体,比如建筑啊,自然物体,人物走动啊之类的,不少的游戏就是使用的这样的方式,比如:帝国
2、时代;其实对于这样的斜角地图,地图网格数据依然是存储在一个二维数组之中的。仔细看这个地图其实就相当于把一块正放的图以左上角为圆星逆时针旋转了45度而已(这只是一种理解方式,也可以认为是以左上角为圆心顺时针转了45度,区别在于写转换屏幕坐标和网格坐标的转换模块时不同)只不过描画时按照特定的方式来描画,也就是给出地图的某一块格子,要知道这块画在屏幕上的坐标;反过来得到屏幕上的一个坐标点,如果这个坐标点正好位于地图之中,要知道这个点对应的是二维数组中的哪块。解决了这个屏幕坐标到地图网格之间的映射关系的问题,实现一个2.5D斜角地图就变得相当容易了,噢,还有就是美工上
3、的要求就是把原本四方的地图单元格画成中间一个菱形其余部分为透明的四方的地图单元格^_^由于之前写的flash游戏里有遇到这方面的问题,所以特别花了点时间想了下,大多数情况下这种2.5D斜角地图应该都是菱形的,虽然不是菱形理论上也可以做到,但我写的这个转换类的还是基于菱形的,语言用的是AS3,代码如下:/***...*@authorh*2.5D斜角地图屏幕坐标及地图格转换器*/publicclassSquintAngleTranslator{privatevarm_mapWid:int=0;privatevarm_mapHei:int=0;privatevarm
4、_orgX:Number=0;privatevarm_orgY:Number=0;privatevarm_xincX:Number=0;privatevarm_xincY:Number=0;privatevarm_yincX:Number=0;privatevarm_yincY:Number=0;//初始化,设置地图网格横向纵向的数量及显示时大地图的范围publicfunctionInitlalRhombusMap(mapWid:int,mapHei:int,mapRange:Rectangle):void{m_mapWid=mapWid;//地图的宽m_ma
5、pHei=mapHei;//地图的高varcount:Number=mapWid+mapHei;m_orgX=mapRange.left+mapRange.width/count;m_orgY=mapRange.top+mapWid*mapRange.height/count;m_xincX=mapRange.width/count;m_xincY=-mapRange.height/count;m_yincX=mapRange.width/count;m_yincY=mapRange.height/count;}//重设地图原点位置的偏移(用于地图滑动)pub
6、licfunctionSetOrgin(xpos:Number,ypos:Number):void{m_orgX=xpos;m_orgY=ypos;}//地图网格坐标转换到屏幕显示坐标(用于提供给描画用)publicfunctionGridToView(xpos:int,ypos:int):Point{varpos:Point=newPoint();pos.x=m_orgX+m_xincX*xpos+m_yincX*ypos;pos.y=m_orgY+m_xincY*xpos+m_yincY*ypos;returnpos;}//屏幕坐标转换到地图网格坐标(比如
7、在即时战略中用于确定鼠标点击的是哪一块)publicfunctionViewToGrid(xpos:Number,ypos:Number):Point{varpos:Point=newPoint();varcoordX:Number=xpos-m_orgX;varcoordY:Number=ypos-m_orgY;pos.x=(coordX*m_yincY-coordY*m_yincX)/(m_xincX*m_yincY-m_xincY*m_yincX);pos.y=(coordX-m_xincX*pos.x)/m_yincX;pos.x=Math.round
8、(pos.x);pos.y=Math.
此文档下载收益归作者所有