Cocos2d-x 3.2 大富翁游戏项目开发-第十六部分 相连地块缴纳过路费

当走到其他角色的地块时,根据当前地块是否连片,连片的话统一计算需要缴纳的过路费,连片的计算方式,是各个地块过路费总和。

首先获取当前行走角色路过的地块的x y坐标(Land layer层的坐标),然后获取角色的坐标(GL的坐标,需要转换成map中的坐标),

然后对这2个坐标值进行横向和纵向比较。

如图A位置:以寻找左边地块的方法为例分析

1、 把角色A坐标转换成map中的坐标

2、 把当前0号地块的sprite对象放入容器中,以便后面播放淡入淡出的动画

3、 0号地块x坐标同角色A的map坐标的x值是否相等,如果相等表示当前角色的上边或下边有对方的地块。

4、 取得0号地块左边相邻1号的坐标

5、 取得1号地块的GID值

6、 判断1号地块的GID值

7、 根据1号地块的GID等级,把过路费相加

8、 把1号地块sprite放入容器中

9、 继续查找左边相邻2号地块,处理方法同1号地块

10、如果左边没有地块了,退出寻找左边地块的循环,继续寻找右边地块



void GameBaseScene::payTolls(int payTag,float x,float y ,int playerTag)调用到displayArea方法
先说明一下参数
float x:表示在land Layer层中地块的横坐标值
float y:表示在land Layer层中地块的纵坐标值
RicherPlayer* player:当前行走的角色
int building_1_tiledID:路过的地块1等级
int building_2_tiledID:路过的地块2等级
int building_3_tiledID:路过的地块3等级
返回值表示除了当前地块的其他连片地块的过路费总和
int GameBaseScene::displayArea(float x,float y,RicherPlayer* player,int building_1_tiledID,int building_2_tiledID,int building_3_tiledID)
{
	int sumMoney =0;//过路费总和初始值
	float retX = Util::GL2map(player->getPosition(),_map).x; //把角色坐标转换成map中的坐标
	if(x == retX) //比较map坐标的x值是否相等,如果相等表示当前角色的上边或下边有对方的地块。
	{
		float leftX  = x - 1; //当前地块相邻左边的坐标
		float rightX = x + 1; //当前地块相邻右边的坐标
		int leftGID = landLayer->getTileGIDAt(ccp(leftX,y));//取得相邻左边地块的GID值
		int rightGID = landLayer->getTileGIDAt(ccp(rightX,y));//取得相邻右边地块的GID值
		displayVector.pushBack(landLayer->getTileAt(ccp(x,y))); //把当前地块的sprite对象放入容器中,以便后面播放淡入淡出的动画
		while(leftGID != 0 && (leftGID == building_1_tiledID || leftGID == building_2_tiledID || leftGID == building_3_tiledID))//判断相邻左边地块的GID
		{
			if(leftGID == building_1_tiledID)//如果相邻左边地块的GID是等级1的地块,把过路费相加
			{
				sumMoney += LAND_BLANK_MONEY;
			}
			if(leftGID == building_2_tiledID)//如果相邻左边地块的GID是等级2的地块,把过路费相加
			{
				sumMoney += LAND_LEVEL_1_MONEY;
			}
			if(leftGID == building_3_tiledID)//如果相邻左边地块的GID是等级3的地块,把过路费相加
			{
				sumMoney += LAND_LEVEL_2_MONEY;
			}
			displayVector.pushBack(landLayer->getTileAt(ccp(leftX,y))); //把相邻左边的地块sprite放入容器中
			leftX -= 1;//继续查找相邻左边地块
			leftGID = landLayer->getTileGIDAt(ccp(leftX,y));//取得地块GID值

			if(leftGID == 0)//如果左边没有地块了,退出寻找左边地块的循环
			{
				break;
			}
			log("leftGID: %d" ,leftGID);
		}
		while(rightGID != 0 && (rightGID == building_1_tiledID || rightGID == building_2_tiledID || rightGID == building_3_tiledID))//判断相邻右边地块的GID
		{
			if(rightGID == building_1_tiledID)//如果相邻右边地块的GID是等级1的地块,把过路费相加
			{
				sumMoney += LAND_BLANK_MONEY;
			}
			if(rightGID == building_2_tiledID)//如果相邻右边地块的GID是等级2的地块,把过路费相加
			{
				sumMoney += LAND_LEVEL_1_MONEY;
			}
			if(rightGID == building_3_tiledID)//如果相邻右边地块的GID是等级3的地块,把过路费相加
			{
				sumMoney += LAND_LEVEL_2_MONEY;
			}
			displayVector.pushBack(landLayer->getTileAt(ccp(rightX,y)));//把相邻右边的地块sprite放入容器中
			rightX += 1;//继续查找相邻右边地块
			rightGID = landLayer->getTileGIDAt(ccp(rightX,y));//取得地块GID值

			if(rightGID == 0)//如果右边没有地块了,退出寻找右边地块的循环
			{
				break;
			}
			log("rightGID: %d" ,rightGID);
		}					
	}
	//上下寻找地块的方法同左右逻辑一样,不再累述。
	........................
	//播放容器中sprite的动画,效果就是相邻的地块淡入淡出
	for(auto it=displayVector.begin();it!=displayVector.end();it++ )
	{					
		(Sprite*)(*it)->runAction(Sequence::create(landFadeOut->clone(),landFadeIn->clone(),NULL));
	}
	return sumMoney;
}

void GameBaseScene::payTolls(int payTag,float x,float y ,int playerTag)
{
			int money =0;
	        if(payTag == MSG_PAY_TOLLS_1_TAG)
			{
				money = LAND_BLANK_MONEY;
			}
		   if(payTag == MSG_PAY_TOLLS_2_TAG)
			{
				money = LAND_LEVEL_1_MONEY;
			}
			if(payTag == MSG_PAY_TOLLS_3_TAG)
			{
				money = LAND_LEVEL_2_MONEY;
			}
			//先把容器清空一下
			displayVector.clear();

			RicherPlayer* landOwner = getPlayerByTiled(buy_land_x,buy_land_y);
			

			switch(playerTag)
			{
				case PLAYER_1_TAG:
				{
					//取得地块过路费总和
					int retMoney = displayArea(x,y,player1,player2_building_1_tiledID,player2_building_2_tiledID,player2_building_3_tiledID);
					//更新角色相应的资金
					refreshMoneyLabel(landOwner,money + retMoney);
					refreshMoneyLabel(player1,-(money + retMoney));
					NotificationCenter::getInstance()->postNotification(MSG_PICKONE_TOGO,String::createWithFormat("%d",MSG_PICKONE_TOGO_TAG));
					break;
				}
				case PLAYER_2_TAG:
				{
					int retMoney = displayArea(x,y,player2,player1_building_1_tiledID,player1_building_2_tiledID,player1_building_3_tiledID);
					refreshMoneyLabel(landOwner,money + retMoney);
					refreshMoneyLabel(player2,-(money + retMoney));
					NotificationCenter::getInstance()->postNotification(MSG_PICKONE_TOGO,String::createWithFormat("%d",MSG_PICKONE_TOGO_TAG));
					break;
				}				
			}
}



点击下载代码  

http://download.csdn.net/detail/lideguo1979/8330609


未完待续..................

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值