大佬教程收集整理的这篇文章主要介绍了cocos2dx《单机斗地主》源码解剖之四 玩家类的解剖,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
头文件
class Player : public CCObject { public: Player(); ~Player(); void updatePkWeiZhi();//设置牌的位置 private: CC_SYNTHESIZE(bool,m_isDiZhu,IsDiZhu);//是否为地主 CC_SYNTHESIZE(bool,m_isCall,Call);//是否已叫地主 CC_SYNTHESIZE(int,m_iCallNum,CallNum);//叫地主的分数 CC_SYNTHESIZE(CCArray*,m_arrPk,ArrPk);//手里拥有的扑克牌 CC_SYNTHESIZE(CCPoint,m_point,Point);//牌在桌面的初始位置 CC_SYNTHESIZE(int,m_iPlayerClass,PlayerClass);//玩家种类:0为玩家,1为电脑,2为显示的三张牌,3为玩家要出的牌,4为电脑1要出的牌,5为电脑2要出的牌 std::vector<PaiXing> m_vecPX;//保存牌型 CC_SYNTHESIZE(bool,m_isOutPk,IsOutPk);//玩家是否出牌true:出 false:不出 };
void Player::updatePkWeiZhi(){ CCSize size = CCDirector::sharedDirector()->getVisibleSize(); int x,y;
<span style="white-space:pre"> </span>//计算玩家牌和出的牌的初始位置 if(m_iPlayerClass == 0 || m_iPlayerClass == 3) { x = size.width/2-((m_arrPk->count()-1)*pkJianJu+pkWidth)/2; y = m_point.y; } else if(m_iPlayerClass == 1 || m_iPlayerClass == 4 || m_iPlayerClass == 5) { x = m_point.x; y = m_point.y; } else if(m_iPlayerClass == 2) { x = size.width/2-(m_arrPk->count()*pkWidth+(m_arrPk->count()-1)*pkJianJu)/2; y = m_point.y; } int num = 0; CCObject* object; //对牌进行排序 if(m_iPlayerClass != 3 && m_iPlayerClass != 4 && m_iPlayerClass != 5) for(int i=0; m_arrPk->count()!=0 && i<m_arrPk->count()-1; ++i) { for(int j=0; j<m_arrPk->count()-1-i; ++j) { Poker* pk1 = (Poker*)m_arrPk->objectATindex(j); Poker* pk2 = (Poker*)m_arrPk->objectATindex(j+1); if(pk1->getNum() < pk2->getNum()) m_arrPk->exchangeObject(pk1,pk2); } } //更新位置 CCARRAY_FOREACH(m_arrPk,object){ Poker* pk = (Poker*)object; if (m_iPlayerClass == 0 || m_iPlayerClass == 3) { pk->showFront(); pk->setPosition(ccp(x+num*pkJianJu+pkWidth/2,y)); } else if(m_iPlayerClass == 1 || m_iPlayerClass == 4 || m_iPlayerClass == 5) { pk->showFront(); if(m_iPlayerClass == 1) pk->showLast(); pk->setPosition(ccp(x,y-num*pkJianJu)); } else if(m_iPlayerClass == 2) { pk->setPosition(ccp(x+num*pkJianJu+num*pkWidth+pkWidth/2,y)); } ++num; } //改变牌的z值或牌的触摸优先 int i=m_arrPk->count()-1; CCARRAY_FOREACH(m_arrPk,object){ Poker* pk = (Poker*)object; //改变z值 if (m_iPlayerClass == 1 || m_iPlayerClass == 4 || m_iPlayerClass == 5) pk->setZOrder(size.height - pk->getPositionY()); if (m_iPlayerClass == 0 || m_iPlayerClass == 3) pk->setZOrder(pk->getPositionX()); //改变优先级 /* Poker* pk1 = (Poker *)m_arrPk->objectATindex(i--); pk->setTouchPriority(pk1->getPositionX());*/ } }
源码请前往前三章下载!
以上是大佬教程为你收集整理的cocos2dx《单机斗地主》源码解剖之四 玩家类的解剖全部内容,希望文章能够帮你解决cocos2dx《单机斗地主》源码解剖之四 玩家类的解剖所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。