本文整理汇总了C++中UnitBase类的典型用法代码示例。如果您正苦于以下问题:C++ UnitBase类的具体用法?C++ UnitBase怎么用?C++ UnitBase使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了UnitBase类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: setTarget
void UnitBase::destroy() {
setTarget(NULL);
currentGameMap->removeObjectFromMap(getObjectID()); //no map point will reference now
currentGame->getObjectManager().removeObject(objectID);
currentGame->getHouse(originalHouseID)->decrementUnits(itemID);
unitList.remove(this);
if(isVisible()) {
if(currentGame->randomGen.rand(1,100) <= getInfSpawnProp()) {
UnitBase* pNewUnit = currentGame->getHouse(originalHouseID)->createUnit(Unit_Soldier);
pNewUnit->setHealth(pNewUnit->getMaxHealth()/2);
pNewUnit->deploy(location);
if(owner->getHouseID() != originalHouseID) {
// deviation is inherited
pNewUnit->owner = owner;
pNewUnit->graphic = pGFXManager->getObjPic(pNewUnit->graphicID,owner->getHouseID());
pNewUnit->deviationTimer = deviationTimer;
}
}
}
delete this;
}
示例2: unit_inout_fill
void MapPane::unit_inout_fill( UnitBase* punit, bool bin)
{
//玩家填充
for( UNITOBJ_MAP::iterator iter =players_.begin(); iter != players_.end(); ++iter)
{
UnitBase* pobj =iter->second;
//必须加载数据完成
if( pobj == punit || !pobj->is_initfinish())
continue;
ActorSceneExtPane* ext1 =punit->get_scene_ext<ActorSceneExtPane>();
ActorSceneExtPane* ext2 =pobj->get_scene_ext<ActorSceneExtPane>();
if( bin)
{
ext1->join_inview( pobj);
ext2->join_inview( punit);
}
else
{
ext1->join_outview( pobj);
ext2->join_outview( punit);
}
}
}
示例3: sendNextUnit
bool UnitSync::sendNextUnit(PlayerID toplayer)
{
UnitBase* unit;
do {
unit = iter.next();
if(unit == 0) {
playerid++;
if(playerid >= PlayerInterface::getMaxPlayers())
return false;
unitlist = UnitInterface::getUnitList(playerid);
iter = unitlist->getAsyncIterator();
}
} while(unit == 0);
iXY unit_map_loc;
MapInterface::pointXYtoMapXY(unit->unit_state.location, &unit_map_loc);
UnitIniSyncMessage sync_message;
sync_message.unit_type = unit->unit_state.unit_type;
sync_message.unit_id = unit->unit_id;
sync_message.location_x = unit_map_loc.x;
sync_message.location_y = unit_map_loc.y;
sync_message.unit_state = unit->unit_state.getNetworkUnitState();
SERVER->sendMessage(toplayer, &sync_message, sizeof(UnitIniSyncMessage), 0);
unit->syncUnit();
return true;
}
示例4: getUnit
void UnitInterface::selfDestructUnit(const UnitID unit_id)
{
UnitBase * unit = getUnit(unit_id);
if ( unit )
{
unit->selfDestruct();
}
}
示例5: destroyPlayerUnits
void UnitInterface::destroyPlayerUnits(PlayerID player_id)
{
PlayerUnitList& unitlist = playerUnitLists[player_id];
for(PlayerUnitList::iterator i = unitlist.begin();
i != unitlist.end(); ++i)
{
UnitBase* unit = *i;
unit->selfDestruct();
}
}
示例6: getUndergroundUnit
void Tile::blitUndergroundUnits(int xPos, int yPos) {
if(hasAnUndergroundUnit() && !isFogged(pLocalHouse->getHouseID())) {
UnitBase* current = getUndergroundUnit();
if(current->isVisible(pLocalHouse->getTeam())) {
if(location == current->getLocation()) {
current->blitToScreen();
}
}
}
}
示例7: destroyPlayerUnits
void UnitInterface::destroyPlayerUnits(PlayerID player_id)
{
UMesgSelfDestruct self_destruct;
self_destruct.setHeader(0, _umesg_flag_unique);
PlayerUnitList& unitlist = playerUnitLists[player_id];
for(PlayerUnitList::iterator i = unitlist.begin();
i != unitlist.end(); ++i) {
UnitBase* unit = *i;
unit->processMessage(&self_destruct);
}
}
示例8: weaponHit
void UnitInterface::weaponHit( const UnitID from_unit,
const iXY& location,
const Uint16 damage_factor)
{
for(Units::iterator i = units.begin(); i != units.end(); ++i)
{
UnitBase* unit = i->second;
if ( unit->unit_state.bounds(location) )
{
if ( unit->weaponHit( from_unit, damage_factor) )
{
unitKilled(unit, from_unit);
}
}
}
}
示例9: while
void UnitInterface::unitOpcodeMessage(const NetMessage *net_message, size_t size)
{
UnitOpcodeDecoder decoder;
decoder.setMessage(net_message, size);
UnitOpcode* opcode;
while(decoder.decode(&opcode)) {
UnitBase* unit = getUnit(opcode->getUnitID());
if(!unit) {
LOGGER.debug("Update for non-existant unit: %d",
opcode->getUnitID());
continue;
}
unit->evalCommandOpcode(opcode);
}
}
示例10: updateUnitStatus
void UnitInterface::updateUnitStatus()
{
for(Units::iterator i = units.begin(); i != units.end(); /*nothing*/ ) {
UnitBase* unit = i->second;
if (unit->unit_state.lifecycle_state == _UNIT_LIFECYCLE_INACTIVE) {
Units::iterator next = i;
++next;
removeUnit(i);
i = next;
continue;
}
unsigned long pre_update_bucket_index;
unsigned long post_update_bucket_index;
pre_update_bucket_index
= unit_bucket_array.worldLocToBucketIndex(
unit->unit_state.location );
unit->updateState();
post_update_bucket_index
= unit_bucket_array.worldLocToBucketIndex(
unit->unit_state.location );
if ( post_update_bucket_index != pre_update_bucket_index ) {
unit_bucket_array.moveUnit(unit->id,
pre_update_bucket_index, post_update_bucket_index );
}
++i;
}
if ( NetworkState::status == _network_state_server ) {
if (message_timer.count()) {
opcode_encoder.send();
}
}
}
示例11: getUnit
void
UnitInterface::sendMessage(const UnitMessage* message,const PlayerState* player)
{
if (message->isFlagged(_umesg_flag_unique)) {
UnitBase* unit = getUnit(message->getUnitID());
if(unit == 0)
return;
if(player && unit->player != player) {
LOGGER.warning(
"Terminal request for unit (%u) not owned by player (%u).\n",
unit->id, player->getID());
return;
}
unit->processMessage(message);
} else if (message->isFlagged( _umesg_flag_broadcast) ) {
if(message->message_id != _umesg_weapon_hit) {
LOGGER.warning("Broadcast flag only allowed for weapon hit.");
if(player) {
LOGGER.warning("from player %u.\n", player->getID());
}
return;
}
for(Units::iterator i = units.begin(); i != units.end(); ++i) {
UnitBase* unit = i->second;
unit->processMessage(message);
}
} else if (message->isFlagged( _umesg_flag_manager_request) ) {
if(player) {
LOGGER.warning(
"UnitManagerMessage sent out by player %u not allowed.",
player->getID());
return;
}
processManagerMessage(message);
}
}
示例12: if
void Player::skill_used( int skid, S_INT_64 targetid, CHRSTATE_TYPE_ENUM st)
{
USE_PROTOCOL_NAMESPACE;
S_INT_8 ret =0;
//1.检查当前状态
if( cur_state_->get_statetype() != st)
{
if( action_selector_.goto_state( st) == 0)
ret =4;
}
//2.检查技能是否合法
SkillRuntime* sr =0;
SkillDesc* pdesc =0;
if( ret == 0)
{
sr =myskills_.get_skillruntime( skid);
//技能是否可用
if( sr == 0)
ret =1;
else
{
pdesc =sr->get_skilldesc();
if( !pdesc->driving_)
{
//是否是主动技能
ret =6;
}
else if( !cur_state_->is_skillinstate( skid))
{
//技能是否存在于当前状态的技能列表中
ret =5;
}
else
{
//检查cooldown时间
if( !sr->is_cooldown())
ret =2;
}
}
}
//3.检查目标是否有效
if( ret == 0 && pdesc->singleattack_)
{
if( this->fight_target_obj_ == 0 || fight_target_obj_->get_uuid() != targetid)
{
UnitBase* pTarget =CONTENTSERVICE_INS->get_onlineentity( targetid);
if( pTarget == 0 || pTarget == this)
{
ret =3;
}
else
{
//目标是否能被攻击
if( !pTarget->can_beattacked( this))
{
ret =3;
}
else
{
//设置战斗对象
this->set_fighttargetobj( pTarget);
}
}
}
}
//4.执行脚本
if( ret == 0)
{
app::script::ScriptContext& context =CONTENTSERVICE_INS->get_scriptcontext();
try{
ret =luabind::call_function<char>( context.get_luastate(), "skill_use", pdesc->skillidsn_.c_str(), this, sr->get_runtimedata());
}
catch( ...){
lua_pop( context.get_luastate(), 1);
ret =-1;
}
}
if( ret == 0)
{
//是否是瞬发技能
if( !sr->is_immediate())
myskills_.set_curskill( sr);
//设置最后执行时间
sr->update_lastruntime();
//通知其他人触发技能
}
Pro_SkillUsed_ack* ack =PROTOCOL_NEW Pro_SkillUsed_ack();
PRO_UUID_FILL( ack, this->global_index_, this->uuid_);
ack->skillid_ =skid;
ack->curstate_ =cur_state_->get_statetype();
ack->target_unit_ =( fight_target_obj_?fight_target_obj_->get_uuid():NO_INITVALUE);
ack->ret_ =ret;
//.........这里部分代码省略.........
示例13: setType
void Tile::triggerSpecialBloom(House* pTrigger) {
if(isSpecialBloom()) {
setType(Terrain_Sand);
switch(currentGame->randomGen.rand(0,3)) {
case 0: {
// the player gets an randomly choosen amount of credits between 150 and 400
pTrigger->addCredits(currentGame->randomGen.rand(150, 400),false);
}
break;
case 1: {
// The house gets a Trike for free. It spawns beside the special bloom.
UnitBase* pNewUnit = pTrigger->createUnit(Unit_Trike);
if(pNewUnit != NULL) {
Coord spot = currentGameMap->findDeploySpot(pNewUnit, location);
pNewUnit->deploy(spot);
}
}
break;
case 2: {
// One of the AI players on the map (one that has at least one unit) gets a Trike for free. It spawns beside the special bloom.
int numCandidates = 0;
for(int i=0; i<NUM_HOUSES; i++) {
House* pHouse = currentGame->getHouse(i);
if(pHouse != NULL && pHouse->getTeam() != pTrigger->getTeam() && pHouse->getNumUnits() > 0) {
numCandidates++;
}
}
if(numCandidates == 0) {
break;
}
House* pEnemyHouse = NULL;
for(int i=0; i<NUM_HOUSES; i++) {
House* pHouse = currentGame->getHouse(i);
if(pHouse != NULL && pHouse->getTeam() != pTrigger->getTeam() && pHouse->getNumUnits() > 0) {
numCandidates--;
if(numCandidates == 0) {
pEnemyHouse = pHouse;
break;
}
}
}
UnitBase* pNewUnit = pEnemyHouse->createUnit(Unit_Trike);
if(pNewUnit != NULL) {
Coord spot = currentGameMap->findDeploySpot(pNewUnit, location);
pNewUnit->deploy(spot);
}
}
break;
case 3:
default: {
// One of the AI players on the map (one that has at least one unit) gets an Infantry unit (3 Soldiers) for free. The spawn beside the special bloom.
int numCandidates = 0;
for(int i=0; i<NUM_HOUSES; i++) {
House* pHouse = currentGame->getHouse(i);
if(pHouse != NULL && pHouse->getTeam() != pTrigger->getTeam() && pHouse->getNumUnits() > 0) {
numCandidates++;
}
}
if(numCandidates == 0) {
break;
}
House* pEnemyHouse = NULL;
for(int i=0; i<NUM_HOUSES; i++) {
House* pHouse = currentGame->getHouse(i);
if(pHouse != NULL && pHouse->getTeam() != pTrigger->getTeam() && pHouse->getNumUnits() > 0) {
numCandidates--;
if(numCandidates == 0) {
pEnemyHouse = pHouse;
break;
}
}
}
for(int i=0; i<3; i++) {
UnitBase* pNewUnit = pEnemyHouse->createUnit(Unit_Soldier);
if(pNewUnit != NULL) {
Coord spot = currentGameMap->findDeploySpot(pNewUnit, location);
pNewUnit->deploy(spot);
}
}
}
break;
}
}
}
示例14: sendManualFireCommand
//.........这里部分代码省略.........
box_press = world_pos;
box_release = world_pos;
}else{
}
}
} // ** _event_mbutton_down
if ( event.event == MouseEvent::EVENT_UP ) {
if (outpost_goal_selection != -1 ){
iXY temp;
MouseInterface::getMousePosition( &temp.x, &temp.y );
WorldViewInterface::clientXYtoWorldXY( world_win, temp, &world_pos );
Objective *objective;
PlayerID player_id = PlayerInterface::getLocalPlayerID();
int cs = ObjectiveInterface::quearyObjectiveLocationStatus( world_pos, player_id, &objective );
if ( (cs == _player_occupied_objective_found)
&& outpost_goal_selection == objective->objective_state.ID
) {
// we've let go of the mouse on the building so we're
// not changing the spawn point
selected_objective_id = CURRENT_SELECTED_OUTPOST_ID = objective->objective_state.ID;
activateVehicleSelectionView( selected_objective_id );
}
else {
TerminalOutpostOutputLocRequest term_mesg;
term_mesg.output_loc_request.set( outpost_goal_selection,
world_pos);
CLIENT->sendMessage( &term_mesg, sizeof(TerminalOutpostOutputLocRequest), 0 );
if ( NetworkState::status == _network_state_client ) {
ObjectiveInterface::sendMessage( &(term_mesg.output_loc_request) );
}
}
outpost_goal_selection = -1;
}
}
if ( (event.event == MouseEvent::EVENT_CLICK) &&
(left_button_hold_action_complete == false) ) {
WorldViewInterface::clientXYtoWorldXY( world_win, event.down_pos, &world_pos );
click_status = getCursorStatus( world_pos );
switch ( click_status ) {
case _cursor_player_unit : {
if( (KeyboardInterface::getKeyState( SDLK_LSHIFT ) == true) ||
(KeyboardInterface::getKeyState( SDLK_RSHIFT ) == true)
) {
working_list.addUnit( world_pos );
} else {
working_list.selectUnit( world_pos );
}
current_selection_list_bits=0;
current_selection_list_index = 0xFFFF;
if (working_list.unit_list.size() > 0) {
UnitBase *unit = UnitInterface::getUnit(working_list.unit_list[0]);
unit->soundSelected();
}
}
break;
case _cursor_move:
case _cursor_blocked: {
if(outpost_goal_selection == -1){
sendMoveCommand( world_pos );
}
}
break;
case _cursor_enemy_unit : {
sendAttackCommand( world_pos );
}
break;
case _cursor_make_allie : {
sendAllianceRequest( world_pos, true );
}
break;
case _cursor_break_allie : {
sendAllianceRequest( world_pos, false );
}
break;
} // ** switch
} // ** if _event_mbutton_click
} // ** else manual_control_state == false;
} // ** evalLeftMButtonEvents
示例15: switch
void Command::executeCommand() const {
switch(commandID) {
case CMD_PLACE_STRUCTURE: {
if(parameter.size() != 3) {
throw std::invalid_argument("Command::executeCommand(): CMD_PLACE_STRUCTURE needs 3 Parameters!");
}
ConstructionYard* pConstYard = dynamic_cast<ConstructionYard*>(currentGame->getObjectManager().getObject(parameter[0]));
if(pConstYard == NULL) {
return;
}
pConstYard->doPlaceStructure((int) parameter[1], (int) parameter[2]);
} break;
case CMD_UNIT_MOVE2POS: {
if(parameter.size() != 4) {
throw std::invalid_argument("Command::executeCommand(): CMD_UNIT_MOVE2POS needs 4 Parameters!");
}
UnitBase* unit = dynamic_cast<UnitBase*>(currentGame->getObjectManager().getObject(parameter[0]));
if(unit == NULL) {
return;
}
unit->doMove2Pos((int) parameter[1], (int) parameter[2], (bool) parameter[3]);
} break;
case CMD_UNIT_MOVE2OBJECT: {
if(parameter.size() != 2) {
throw std::invalid_argument("Command::executeCommand(): CMD_UNIT_MOVE2OBJECT needs 2 Parameters!");
}
UnitBase* unit = dynamic_cast<UnitBase*>(currentGame->getObjectManager().getObject(parameter[0]));
if(unit == NULL) {
return;
}
unit->doMove2Object((int) parameter[1]);
} break;
case CMD_UNIT_ATTACKPOS: {
if(parameter.size() != 4) {
throw std::invalid_argument("Command::executeCommand(): CMD_UNIT_ATTACKPOS needs 4 Parameters!");
}
UnitBase* unit = dynamic_cast<UnitBase*>(currentGame->getObjectManager().getObject(parameter[0]));
if(unit == NULL) {
return;
}
unit->doAttackPos((int) parameter[1], (int) parameter[2], (bool) parameter[3]);
} break;
case CMD_UNIT_ATTACKOBJECT: {
if(parameter.size() != 2) {
throw std::invalid_argument("Command::executeCommand(): CMD_UNIT_ATTACKOBJECT needs 2 Parameters!");
}
UnitBase* pUnit = dynamic_cast<UnitBase*>(currentGame->getObjectManager().getObject(parameter[0]));
if(pUnit == NULL) {
return;
}
pUnit->doAttackObject((int) parameter[1], true);
} break;
case CMD_INFANTRY_CAPTURE: {
if(parameter.size() != 2) {
throw std::invalid_argument("Command::executeCommand(): CMD_INFANTRY_CAPTURE needs 2 Parameters!");
}
InfantryBase* pInfantry = dynamic_cast<InfantryBase*>(currentGame->getObjectManager().getObject(parameter[0]));
if(pInfantry == NULL) {
return;
}
pInfantry->doCaptureStructure((int) parameter[1]);
} break;
case CMD_UNIT_SETMODE: {
if(parameter.size() != 2) {
throw std::invalid_argument("Command::executeCommand(): CMD_UNIT_SETMODE needs 2 Parameter!");
}
UnitBase* pUnit = dynamic_cast<UnitBase*>(currentGame->getObjectManager().getObject(parameter[0]));
if(pUnit == NULL) {
return;
}
pUnit->doSetAttackMode((ATTACKMODE) parameter[1]);
} break;
case CMD_DEVASTATOR_STARTDEVASTATE: {
if(parameter.size() != 1) {
throw std::invalid_argument("Command::executeCommand(): CMD_DEVASTATOR_STARTDEVASTATE needs 1 Parameter!");
}
Devastator* pDevastator = dynamic_cast<Devastator*>(currentGame->getObjectManager().getObject(parameter[0]));
if(pDevastator == NULL) {
return;
}
pDevastator->doStartDevastate();
} break;
case CMD_MCV_DEPLOY: {
if(parameter.size() != 1) {
throw std::invalid_argument("Command::executeCommand(): CMD_MCV_DEPLOY needs 1 Parameter!");
}
MCV* pMCV = dynamic_cast<MCV*>(currentGame->getObjectManager().getObject(parameter[0]));
if(pMCV == NULL) {
return;
}
//.........这里部分代码省略.........