cocos2d-x游戏实例(3)-获得地图索引

本文介绍如何在cocos2d-x中根据坐标计算普通地图和45度角地图的索引值,涉及坐标转换及三角函数计算。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


    

cocos2d-x游戏实例(3)-获得地图索引

       

我们不仅要显示地图,还要对地图进行一些逻辑操作,比如地图的碰撞等,要获得地图的属性,必须要获得地图的索引,就是地图的行列值,那么我们如何根据坐标获得地图的索引值呢?本文将介绍Tiles工具支持的两种地图中根据坐标获得地图的索引值,普通地图和45度角地图

首先普通地图比较简单,就是用坐标值除以图素的宽高即可,这也是一种比较常用的地图表现方法。

下面介绍45度角的根据坐标获得地图的索引值,首先来看一下45度角地图


就是一个菱形,我们从几何的角度来转换坐标,得到的像素宽高并不是真实的图素宽高,而是每个小图素块的菱形的对角线的长,这样一来问题就转变为求解这个菱形中点对应的菱形棱长的问题


首先抱歉,我的图画的不好,A就是我们的坐标点,整个地图就是这个菱形我们求出DCCB就分别就可以除以图素菱形棱长就可以求得对应索引坐标,这里要说明的是ABCD是个平行四边形(虽然看起来......),所以,对于三角形ADC,我们只要获得ADDC的长就可以(AD等于BC),我们可以通过正弦定理解得(AD/sinACD = AC/sinADC = DC/sinCAD)因为我们可以求出AC(两点距离公式),我们可以获得AC关于水平线的角,通过差角公式可以获得角ACD,角CAD,然后角CDA也就获得了,三角形也就解开了,我们分开A点在C点左和C点右的情况,代码如下mystatic5是根号5 mystatic2是根号2 mystatic是菱形棱长(图素高*根号5)


//坐标与地图位置的转换
CCPoint MapScene::convertto2d(float x,float y)
{
 CCTMXTiledMap* map = (CCTMXTiledMap*) getChildByTag(kTagTileMap);
 int mapWidth = map->getMapSize().width * map->getTileSize().width;
 int mapHeight = map->getMapSize().height * map->getTileSize().height;
 double distanse;
 double sin1;
 double sin11;
 double sin22;
 double cos11;
 double cos1;
 int d2x;
 int d2y;
 double mystatic5 = sqrt(5.0);//«Û∏˘∫≈5
 double mystatic = 16 * mystatic5;//–°ÕºøÈ¿‚≥§
 //char mch[256];
 if(x > mapWidth/2)
 {
    distanse = sqrt((x - mapWidth/2) * (x - mapWidth/2) + (mapHeight - y) * (mapHeight - y));
    sin1 = (mapHeight - y)/distanse;
    cos1 = (x - mapWidth/2)/distanse;
    sin11 = (sin1 * 2 - cos1) / mystatic5;
    cos11 = (sin1 + cos1 * 2) / mystatic5;
    d2y = distanse * 5 / 4 * sin11 / mystatic;
    sin22 = (2 * sin1 + cos1) / mystatic5;
    d2x = distanse * 5 / 4 * sin22 / mystatic;
    return ccp(d2x,d2y);
 }
 else
 {
    distanse = sqrt((mapWidth/2 - x) * (mapWidth/2 - x) + (mapHeight - y) * (mapHeight - y));
    sin1 = (mapHeight - y)/distanse;
    cos1 = (mapWidth/2 - x)/distanse;
    sin11 = (sin1 * 2 - cos1) / mystatic5;
    cos11 = (sin1 + cos1 * 2) / mystatic5;
    d2x = distanse * 5 / 4 * sin11 / mystatic;
    //sin22 = 4.0 * cos11 / 5 + 3.0 * sin11 / 5;
    sin22 = (2 * sin1 + cos1) / mystatic5;
    d2y = distanse * 5 / 4 * sin22 / mystatic;
    return ccp(d2x,d2y);
 }
}

如有错误之处,希望大家多多指正

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值