手游菱形地图解决方案.doc_第1页
手游菱形地图解决方案.doc_第2页
手游菱形地图解决方案.doc_第3页
手游菱形地图解决方案.doc_第4页
手游菱形地图解决方案.doc_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

最早的有很多的2D游戏,地图看起来就像是俯视图一样,地图整体形状是个矩形的,地图的每一格也是个矩形,很多早期的RPG游戏就是这样。这样的地图实现起来很方便,地图的信息一般就存储在一个二维数组中,描画、定位也很方便。不过这样的缺点就是不太逼真,所以在3D技术出现之前(或者是因为出于效率的原因只能使用2D的情况下)有人想出了用2D的方式来模拟视觉上3D的效果,就是使用斜角地图块拼出的地图,这个斜角地图块的形状一般都是一个菱形,拼出后整块的地图也是个菱形,如下图:然后地图上有放置物体,比如建筑啊,自然物体,人物走动啊之类的,不少的游戏就是使用的这样的方式,比如:帝国时代;其实对于这样的斜角地图,地图网格数据依然是存储在一个二维数组之中的。仔细看这个地图其实就相当于把一块正放的图以左上角为圆星逆时针旋转了45度而已(这只是一种理解方式,也可以认为是以左上角为圆心顺时针转了45度,区别在于写转换屏幕坐标和网格坐标的转换模块时不同)只不过描画时按照特定的方式来描画,也就是给出地图的某一块格子,要知道这块画在屏幕上的坐标;反过来得到屏幕上的一个坐标点,如果这个坐标点正好位于地图之中,要知道这个点对应的是二维数组中的哪块。解决了这个屏幕坐标到地图网格之间的映射关系的问题,实现一个2.5D斜角地图就变得相当容易了,噢,还有就是美工上的要求就是把原本四方的地图单元格画成中间一个菱形其余部分为透明的四方的地图单元格_由于之前写的flash游戏里有遇到这方面的问题,所以特别花了点时间想了下,大多数情况下这种2.5D斜角地图应该都是菱形的,虽然不是菱形理论上也可以做到,但我写的这个转换类的还是基于菱形的,语言用的是AS3,代码如下:/* .* author h* 2.5D斜角地图屏幕坐标及地图格转换器*/public class SquintAngleTranslator private var m_mapWid:int = 0; private var m_mapHei:int = 0; private var m_orgX:Number = 0; private var m_orgY:Number = 0; private var m_xincX:Number = 0; private var m_xincY:Number = 0; private var m_yincX:Number = 0; private var m_yincY:Number = 0; /初始化,设置地图网格横向纵向的数量及显示时大地图的范围 public function InitlalRhombusMap( mapWid:int, mapHei:int, mapRange:Rectangle ):void m_mapWid = mapWid; /地图的宽 m_mapHei = mapHei;/地图的高 var count: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; /重设地图原点位置的偏移(用于地图滑动) public function SetOrgin( xpos:Number, ypos:Number ):void m_orgX = xpos; m_orgY = ypos; /地图网格坐标转换到屏幕显示坐标(用于提供给描画用) public function GridToView( xpos:int, ypos:int ):Point var pos:Point = new Point(); pos.x = m_orgX + m_xincX * xpos + m_yincX * ypos; pos.y = m_orgY + m_xincY * xpos + m_yincY * ypos; return pos; /屏幕坐标转换到地图网格坐标(比如在即时战略中用于确定鼠标点击的是哪一块) public function ViewToGrid( xpos:Number, ypos:Number ):Point var pos:Point = new Point(); var coordX:Number = xpos - m_orgX; var coordY: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( pos.x ); pos.y = Math.round( pos.y ); return pos; /判断网格坐标是否在地图范围内 public function LegalGridCoord( xpos:int, ypos:int ):Boolean if ( xpos 0 | ypos = m_mapWid | ypos = m_mapHei ) return false; return true; /判断屏幕坐标是否在地图范围内 public function LegalViewCoord( xpos:Number, ypos:Number ):Boolean var pos:Point = ViewToGrid( xpos, ypos ); return LegalGridCoord( pos.x, pos.y ); /格式化屏幕坐标,即返回最接近该坐标的一个格子的标准屏幕坐标(通常用于在地图中拖动建筑物对齐网格用) public function FormatViewPos( xpos:Number, ypos:Number ):Point var pos:Point = Vie

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

最新文档

评论

0/150

提交评论