在Cocos2D-x里面创建Tile Map地图是需要用到.tmx的地图文件的,那么创建Tile Map地图文件,我们可以通过地图编辑器来创建,地图编辑器可以在网站:http://www.mapeditor.org 上进行下载,然后通过地图编辑器就可以导入.tmx的地图文件。那么为什么我们不直接用图片作为地图呢,而是使用.tmx文件来创建地图。那么有一个很重要的原因就是因为使用Tile Map地图无论你的地图多大,内存占用只是每个不同Tile的总和,所以使用Tile Map是非常省内存的一种做法。当然了Tile Map地图的功能可以实现的效果要比单纯的图片要更加丰富,比如Tile Map是可以对地图进行分层等。

那么下面我们主要是讲怎么在游戏里面去使用地图文件。

1、在VS2012上面添加地图文件,这个和添加其他的图片资源文件的操作一样,复制到Asset文件夹,然后添加到项目里面,那么在这里要注意的一点是,把.tmx添加到项目的时候,它的content属性是false的,这时候需要我们手工把它改成true,否则地图会无法显示出来,如下图所示:

2、使用.tmx文件创建地图,然后就可以往地图上添加精灵了,操作精灵的运动,和把精灵在地图的那个一个层上面。

//创建地图

CCTMXTiledMap *map = CCTMXTiledMap::create("iso-test-zorder.tmx");

//在地图上添加精灵

map->addChild(cat, map->getChildren()->count() );

//更新精灵位于那个地图的层上

map->reorderChild(cat, newZ);

示例代码:

TestLayer::TestLayer()
{
//创建一个CCTMXTiledMap
CCTMXTiledMap *map = CCTMXTiledMap::create("iso-test-zorder.tmx");
addChild(map, , );
//获取地图的大小
CCSize s = map->getContentSize();
map->setPosition(ccp(,));
//在地图上添加精灵
cat = CCSprite::create("cat.png");
map->addChild(cat, map->getChildren()->count() );
//如果tile map中有多个层,把这些层加入其他对象中时一定要先retain
cat->retain();
int mapWidth = map->getMapSize().width * map->getTileSize().width;
cat->setPositionInPixels(ccp( mapWidth/,));
cat->setAnchorPoint(ccp(0.5f,)); //创建精灵运动的动画
CCActionInterval* move = CCMoveBy::create(, ccpMult(ccp(,), /CC_CONTENT_SCALE_FACTOR()));
CCActionInterval* back = move->reverse();
CCFiniteTimeAction* seq = CCSequence::create(move, back,NULL);
cat->runAction( CCRepeatForever::create((CCActionInterval*) seq) ); schedule( schedule_selector(TestLayer::repositionSprite) );
} void TestLayer::repositionSprite(ccTime dt)
{
CCPoint p = cat->getPositionInPixels();
CCNode *map = getChildByTag(); // there are only 4 layers. (grass and 3 trees layers)
// if tamara < 48, z=4
// if tamara < 96, z=3
// if tamara < 144,z=2 int newZ = - (p.y / );
newZ = max(newZ,);
//更新层次关系,底层会重新排序
map->reorderChild(cat, newZ);
}

运行的效果:

[Cocos2D-x For WP8]Tile Map创建地图的更多相关文章

  1. HTML5结合百度地图API创建地图应用

    具体的百度地图API的使用方法查看百度地图API里的DEMO <style> #div1{ width:400px; height:400px; border:1px #000 solid ...

  2. js调用百度地图API创建地图

    技术交流群:233513714 <html xmlns="http://www.w3.org/1999/xhtml"><head runat="serv ...

  3. js调用百度地图API创建地图,搜索位置

    实现代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <met ...

  4. 【百度地图API】如何快速创建带有标注的地图?——快速创建地图工具+如何标注商家

    原文:[百度地图API]如何快速创建带有标注的地图?--快速创建地图工具+如何标注商家 摘要: 如果你不会程序,如果你不想写代码. 如果你想拥有一张自己的地图,如果你想在该地图上标注出你商店的位置. ...

  5. 【百度地图API】建立全国银行位置查询系统(一)——如何创建地图

    原文:[百度地图API]建立全国银行位置查询系统(一)--如何创建地图 <摘要>你将在第一章中学会以下知识: 如何创建一个网页文件 怎样利用百度地图API建立一张2D地图,以及3D地图 如 ...

  6. 在slam_gmapping中使用Log数据创建地图

    本文介绍使用机器人记录的tf变换和激光扫描数据来建立2D地图.并在ROS的图形化模拟环境rviz中通过重新回放记录的数据作为机器人真实传感器采集的输入,来观测地图动态创建过程. 1.ROS gmapp ...

  7. 使用Leaflet创建地图模块

    背景 最近需要为某单位开发地图展示系统,因此开始涉略和使用Leaflet这个轻量级地图库. 创建基础地图需要以下几步 引入相关js和css文件,创建基础地图 <div id="map& ...

  8. 在 SharePoint 2013 中针对地理位置字段创建地图视图

    在 SharePoint 2013 中针对地理位置字段创建地图视图 了解如何通过在 SharePoint 2013 列表中使用地图视图来显示位置信息.您可以通过 SharePoint 用户界面 (UI ...

  9. cocos2dx - 创建地图及玩家(伪)

    接上一节内容:cocos2dx - 环境配置,项目创建 本节主要描述cocos中精灵的创建及点击事件的使用 打开创建好的test项目,看到下图的目录结构,真正的游戏逻辑路径在src下. AppDele ...

随机推荐

  1. 23.备忘录模式(Memento Pattern)

    using System; using System.Collections.Generic; namespace ConsoleApplication6 { /// <summary> ...

  2. mxnet环境搭建随记

    安装mxnet还是遇到不少麻烦事,现在简单记一下,挖个坑,后续详细补充,打算写一下我的mxnet探索之旅. 更新: 具体安装mxnet,cuda,opencv过程已经补坑——点击进入 不知道为什么,在 ...

  3. slf4i + logback 配置

    一.所需jar包: slf4j-api-1.6.1.jar logback-classic-0.9.24.jar logback-core-0.9.24.jar 二.logback.xml配置示例: ...

  4. Installing MySQL Server on CentOS

    MySQL is an open-source relational database. For those unfamiliar with these terms, a database is wh ...

  5. ORA-01041: 内部错误,hostdef 扩展名不存在

    在工作中打算将生产环境的数据库设置成归档模式时,遇到的问题. 一.重启数据库 Sql代码: shutdown immediate; startup mount; 也就是在我执行startup moun ...

  6. angularjs 菜鸟教程 版本1.4.6

    最简angularJS webstorm代码提示 在 head 里面添加:<script src="https://ajax.googleapis.com/ajax/libs/angu ...

  7. TI Zigbee Light Link 参考设计

    TI  Zigbee Light Link 参考设计 原文出处: http://processors.wiki.ti.com/index.php/Category:ZigBee_Light_Link ...

  8. Android开发如何去除标题栏title(转)

    去除标题栏title其实非常简单,他有两种方法,一种是在代码中添加,另一种是在AndroidManifest.xml中添加: 1.在代码中实现:在此方法setContentView(R.layout. ...

  9. ios程序播放音频文件

    1.控制器代码 #import "ViewController.h" #import <AVFoundation/AVFoundation.h> #import &qu ...

  10. 智能车学习(二十二)——浅谈速度控制

    一.经典PID控制       使用遇限反向PID会比较适合有加减速的车子,使用变速积分适合跑匀速的车子.然后这种方法的条件下,一定要尽可能缩短控制周期..   二.PID加棒棒控制       针对 ...