Tiled地图编辑器支持普通视角地图和45度角地图, 它生成的地图数据文件cocos2d-x完美的支持,Tiled地图编辑器是一个以普通使用为目标地图编辑器,它使用简单而且能够轻松地在不同的游戏引擎中使用,其特性有:

1、使用基于XML编码形的地图数据文件使用能够在不同游戏引擎中通用

2、支持普通、45度两种视角

3、对象的放置位置能够精确到像素

4、支持图素、层次和对象等通用概念

5、自己主动又一次加载图素集

6、能够重置图素的大不和偏移

7、支持图章刷和填充等高效工具

8、支持以通用的格式输入输出来打开和存储文件

開始Tiled地图编辑器编辑地图

一、首先准备地图素材文件放至projectResources下,下载安装tiled-0.9.1-win32-setup.exe

地址:http://www.mapeditor.org/

二、启动Tiled,选择“文件-》新地图”,来新建地图project,弹出例如以下对话框设置地图的大小和图块大小和地图视角方向

三、选择“地图-》新图块”导入图素文件,弹出例如以下对话框设置图块的大小、边距、偏移量及图块名称、源路径

四、图块创建成功,右側显示图层名称及图块窗体中的图块,将图层名改动一下,点击工具栏上图章刷,点击一图块開始画地图

五、在图层窗体加入对象层并重命名,并在对象层加入对象,选中新建的对象层,点击工具栏上“插入矩形”在地图上画一个矩形,大小无关紧要,我们主要用来在地图

获取该x,y坐标,以在此放至精灵,右键刚刚加入矩形,选择对象属性,给它命个名称,然后点击确定。

六、点击保存地图命名*.tmx至Resources

七、编敲代码代码:

CCTMXTiledMap瓦片地图集类是cocos2d-x中支持Tiled地图编码数据文件形式的类,用于解析地图集的数据文件。開始使用地图,增加代码:

CCTMXTiledMap *pTMXTiledMap = CCTMXTiledMap::create("map.tmx");
pTMXTiledMap->setScale(0.8f);
pTMXTiledMap->setAnchorPoint( ccp(0.5f, 0.5f) );
pTMXTiledMap->setPosition(ccp(visibleSize.width/2 , visibleSize.height/2-300)); this->addChild(pTMXTiledMap);

执行结果:

八、Cocos2d-x 操作Tiled地图经常用法

显示Tiled地图

CCTMXTiledMap *map = CCTMXTiledMap::create("map3.tmx");
map->setAnchorPoint( ccp(0.5f, 0.5f) );
map->setPosition(ccp(visibleSize.width/2, visibleSize.height/2));
this->addChild(map);

获取地图像素大小, width等于地图宽度块数*每块宽度,height 等于地图高度块数*每块高度

	CCSize CC_UNUSED s = map->getContentSize();
CCLOG("ContentSize: %f, %f", s.width,s.height);

获取地图层

	CCTMXLayer *layer = map->layerNamed("layer1");//參数:地图层名称
CCSize m = layer->getLayerSize();//地图大小
CCLOG("LayerSize: %f, %f", m.width,m.height);

获取对象层

CCTMXObjectGroup *object = map->objectGroupNamed("object1");//參数:对象层名称

获取对象

CCDictionary *sprite_object = object->objectNamed("sprite1");//參数:对象名称

获取对象坐标

	float x = ((CCString*)sprite_object->objectForKey("x"))->floatValue();
float y = ((CCString*)sprite_object->objectForKey("y"))->floatValue();

在坐标处增加精灵

	CCSprite *sprite = CCSprite::create("sprite.png");
sprite->setScale(0.5f);
sprite->setAnchorPoint(ccp(0.0f, 0.0f));
sprite->setPosition(ccp(x, y));
this->addChild(sprite);

当有多个地图层时,遍历地图层

	CCArray* pChildrenArray = map->getChildren();
CCSpriteBatchNode* child = NULL;
CCObject* pObject = NULL;
CCARRAY_FOREACH(pChildrenArray, pObject)
{
child = (CCSpriteBatchNode*)pObject; if(!child)
break; child->getTexture()->setAntiAliasTexParameters();
}

当有对象层有多个对象时,遍历全部对象

	CCArray *obs = object->getObjects();
CCDictionary *dict=NULL;
CCObject *ob = NULL;
CCARRAY_FOREACH(obs, ob)
{
dict = (CCDictionary *)ob;
if (!dict)
break; int y = ((CCString*)dict->objectForKey("y"))->floatValue();
int x = ((CCString*)dict->objectForKey("x"))->floatValue();
int w = ((CCString*)dict->objectForKey("width"))->floatValue();
int h = ((CCString*)dict->objectForKey("height"))->floatValue();
CCLOG("sprite x: %d, y: %d, w: %d, h: %d", x, y, w, h);
}

最后结果图:

普通视角获取地图层四角图素

CCTMXLayer *layer = map->layerNamed("layer1") ;
CCSize s = layer->getLayerSize(); CCSprite* sprite;
sprite = layer->tileAt(ccp(0,0));
sprite->setScale(2);
sprite = layer->tileAt(ccp(s.width-1,0));
sprite->setScale(2);
sprite = layer->tileAt(ccp(0,s.height-1));
sprite->setScale(2);
sprite = layer->tileAt(ccp(s.width-1,s.height-1));
sprite->setScale(2);

将精灵作为了节点增加地图中

m_tamara = CCSprite::create("nan.png");
map->addChild(m_tamara, map->getChildren()->count() );//将精灵作为子节点增加

改动精灵与地图遮挡物关系

//改动z轴的值并排序
CCPoint p = m_tamara->getPosition();
p = CC_POINT_POINTS_TO_PIXELS(p);
CCNode *map = getChildByTag(kTagTileMap); int newZ = 4 - (p.y / 48);
newZ = max(newZ,0); map->reorderChild(m_tamara, newZ);

Cocos2d-x Tiled地图编辑器(一)基本使用的更多相关文章

  1. Tiled 地图编辑器使用教程-官方demo

    一.Tiled Map Editer 下载地址 http://www.mapeditor.org/download.html 二.官方教程查看 下载安装后,不管windows还是Mac系统都包含官方例 ...

  2. Tiled Map地图编辑器键盘快捷键

    Tiled是款不错的地图编辑器,不过快捷键真是隐蔽啊,不看github上得wiki根本不知道,用的过程中查英文文档总是觉得慢,所以翻译成了中文. 通用 右键点击图块(tile):复制图块到图章刷(拖动 ...

  3. 读取tiled地图

    原地址:http://www.unity蛮牛.com/thread-20854-1-1.html   Tile是一个非常好用的地图编辑器,一直以来我都在找支持tilemap的unity2D插件,但是找 ...

  4. 地图编辑器V1

    功能:1. 拖放地图元素至地图编辑器中2. 可设置参考图3. 背景图可平铺,中央,左上角等放置4. 地图上的元素可旋转,可删除,可拖动5. 保存地图数据时同时生成XML格式的地图信息 -------- ...

  5. X-UniTMX:导入大型Tiled地图文件(*.tmx)到Unity3d中比较好的插件

    因工作原因,需要导入格子数为1200x1200的Tiled地图文件(*.tmx)到Unity3d中显示出来.尝试过一些其它插件,后面发现X-UniTMX是比较好用的. X-UniTMXhttp://f ...

  6. 开源地图编辑器 MarbleMap,支持Cocos2d-x坐标系

    由9秒社团开发并维护的MarbleMap是支持Cocos2d-x坐标系和as3坐标系的地图编辑器,功能完善高效.这里详细介绍一下它的使用方法! 一.功能简述 由9秒社团开发并维护的MarbleMap是 ...

  7. 【Cocosd2d实例教程二】地图编辑器Tiled的安装使用

    (转载请注明出处:http://blog.csdn.net/buptgshengod) 我们知道cocos2d是一个基于2d效果的游戏引擎,那么如果制作一个2d手机游戏我们需要创建相应的游戏画面,而c ...

  8. cocos2dx进阶学习之瓦片地图编辑器

    之前学习了瓦片地图类,现在我们来学习下瓦片地图制作工具 这个是开源的工具,可以从网上下载,下面我们演示下怎么做地图 步骤1 将需要用到的图片放到一个目录下,比如我机器上就是d:\tiled,这些图片是 ...

  9. 该Tiled地图制作拿到项目~~这是偷懒,为了直接复制后写来

    1.现在,.h声明private: cocos2d::CCSprite* ninja; cocos2d::CCTMXTiledMap*  tileMap; 然后.cpp中增加tileMap = CCT ...

随机推荐

  1. 做自己的Android ROM,屏蔽对framework中的系统APK的签名检查

    最近两天一直在尝试更新Android中的关键库以达到定制ROM的效果,中间比较曲折,记录下来供自己和大家参考. 因为我需要基于Android的原生代码做一定的修改,所以如果无法将我自己编译出的APK或 ...

  2. 碰撞回避算法(一) Velocity Obstacle

    碰撞回避是机器人导航,游戏AI等领域的基础课题.几十年来,有很多算法被提出.注意这里主要指的是局部的碰撞回避算法.尽管和全局的路径规划算法(A*算法等)有千丝万缕的联系.可是还是有所不同的(局部的碰撞 ...

  3. Eclipse设置Android Logcat输出字体大小

    Window -> Preferences -> Android -> Logcat -> Display Font:点击"Change"button 如图 ...

  4. Linux IP代理筛选系统(shell+proxy)

    代理的用途 其实,除了抓取国外网页需要用到IP代理外,还有很多场景会用到代理: 通过代理访问一些国外网站,绕过被某国防火墙过滤掉的网站 使用教育网的代理服务器,可以访问到大学或科研院所的内部网站资源 ...

  5. uva 10603

    紫皮书的例题 照着敲了一遍,非原创 大题思路主要是三杯水,而水的总数是知道的,相当于知道第一第二杯水的体积,第三杯水的体积也就确定了. 用第一第二杯水的体积来标记数组是否遍历过 优先队列来找移动体积最 ...

  6. Swift - 文本输入框(UITextField)的用法

    1,文本框的创建,有如下几个样式: UITextBorderStyle.None:无边框 UITextBorderStyle.Line:直线边框 UITextBorderStyle.RoundedRe ...

  7. 【Demo 0011】多媒体播放器

    本章学习要点:       1.  掌握AVAudioPlayer 基本使用;       2.  掌握AVPlayer 基本使用;       3.  掌握系统声音播放以及震动;       4. ...

  8. memory引擎的索引失效一例

    memory引擎的索引失效一例 memory引擎的索引失效一例

  9. 基于Adaboost的人脸检测算法

    AdaBoost算法是一种自适应的Boosting算法,基本思想是选取若干弱分类器,组合成强分类器.根据人脸的灰度分布特征,AdaBoost选用了Haar特征[38].AdaBoost分类器的构造过程 ...

  10. SQL ---指令实例语句

    1 1 create database+数据库名字 创建数据库 2 2 create table+表的名字 创建表 3 表中的操作: 4 3 insert into 表名 (列名1,列名2··)val ...