亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? mainbrain.cpp

?? BugBots是一個(gè)游戲
?? CPP
字號(hào):
#include "mainbrain.h"#include "utility.h"#include "food.h"#include "clump.h"#include <list>#include "sutil.h"#include <algorithm>#include <vector>#include "MapHandler.h"#include "soundmanager.h"extern MapHandler MH;const extern int SCREENHEIGHT;const extern int SCREENWIDTH;void MainBrain::SetMe(int i){     m_me = i;}int MainBrain::GetMe(){     return m_me;}MainBrain::MainBrain(){     m_resources = 30000;     m_pos = NoPosition;     m_me = -1;}void MainBrain::SetColors(int c1,int c2, int c3, int c4, int c5){     m_colors[0] = c1;     m_colors[1] = c2;     m_colors[2] = c3;     m_colors[3] = c4;     m_colors[4] = c5;}void MainBrain::ReportCorpse(int corpse){     using std::count;          if(!count(m_corpses.begin(),m_corpses.end(),corpse))     {	  m_corpses.push_back(corpse);     }}void MainBrain::ReportFood(int food){     using std::list;     using std::count;          int clump;     list<Food>::iterator foodit= MH.GetFoodIter(food);          if(!food) return;          clump = (*foodit).GetClump();     if(clump == -1 || (*foodit).IsCarried())     {	  return;     }     if(!count(m_clumps.begin(),m_clumps.end(),clump))     {	  m_clumps.push_back(clump);     }}bool MainBrain::InTargetZone(Position pos){     return (DistPTP(m_pos,pos) < float(TargetZoneSize)) ? true : false;}bool MainBrain::Feed(int bot){     using std::list;          list<BugBot>::iterator i = MH.GetBugBotIter(bot);          if(i ==0)     {	  return false;     }     int BotHealth = (*i).GetHealth();     if(CanFeed(BotHealth))     {	  (*i).FoodFromGod(1000-BotHealth);	  m_resources -= (1000-BotHealth);	  return true;     }     return false;}bool MainBrain::CanFeed(int bothealth){     if(m_resources - (1000-bothealth) >= 0)     {	  return true;     }     else     {	  return false;     }}int MainBrain::GetColor(Flag param){     if(param[CORPSE])     {	  return m_colors[4];     }     if(param[CANNIBAL])     {	  if(param[RENEGADE])	  {	       return m_colors[3];	  }	  else	  {	       return m_colors[2];	  }     }     if(param[RENEGADE])     {	  return m_colors[1];     }     else     {	  return m_colors[0];     }}void MainBrain::SweepTargetZone(){     using std::list;     for(int x = (m_pos.x - TargetZoneSize); x <= (m_pos.x + TargetZoneSize); x++)     {	  for(int y = (m_pos.y - TargetZoneSize); y <= (m_pos.y + TargetZoneSize); y++)	  {	       if(0 < y && y < SCREENHEIGHT && 0 < x && x < SCREENWIDTH)	       {		    if(DistPTP(m_pos, Position(x,y)) <= static_cast<float>(TargetZoneSize))		    {			 list<BugBot>::iterator Bot = MH.GetBugBotAt(Position(x,y));			 list<BugBot>::iterator Corpse = MH.GetCorpseAt(Position(x,y));			 list<Food>::iterator Food = MH.GetFoodAt(Position(x,y));			 if(Bot != 0 && (*Bot).GetTeam() == m_me)			 {			      (*Bot).ReachedTarget();			 }			 if(Corpse != 0)			 {			      Assimilate(Item((*Corpse).GetMe(),true));			 }			 if(Food  != 0)			 {			      Assimilate(Item((*Food).GetMe(),false));			 }		    }	       }//within range	  }     }}void MainBrain::Assimilate(Item item){     using std::list;     if(item.bot)     {	  m_resources+=CorpseValue;	  //if(GlobalBugBotList.count(item.bugbot))	  list<BugBot>::iterator botit = MH.GetBugBotIter(item.vnum);	  //GlobalMap[(*GetBugBotIt(item.vnum)).GetPos().x][(*GetBugBotIt(item.vnum)).GetPos().y].corpse=0;	  MH.SetCorpseAt((*botit).GetPos(),0);	  MH.EraseBugBot(item.vnum);     }     else     {	  list<Food>::iterator foodit = MH.GetFoodIter(item.vnum);	  int clump = (*foodit).GetClump();	  	  MH.SetFoodAt((*foodit).GetPos(),0);	  	  if(clump != -1 && !(*foodit).IsCarried())	  {	       list<Clump>::iterator cit = MH.GetClumpIter(clump);	       	       if(cit != 0)		    (*cit).RemoveFood((*foodit).GetMe());	  }	  m_resources+=FoodValue;	  MH.EraseFood(item.vnum);     }}bool MainBrain::RemoveBugBot(int bot){     using std::count;     using std::find;     using std::vector;     if(!count(m_bugbots.begin(),m_bugbots.end(),bot))     {	  return false;     }     vector<int>::iterator i = find(m_bugbots.begin(),m_bugbots.end(),bot);     m_bugbots.erase(i);     return true;}Position MainBrain::GetTargetPos(const Position &current_pos){     using std::list;     int clump = -1;     Position pos = NoPosition;     if(m_corpses.empty())     {	  float TotalFood = 0;	  float rnum = rand();	  int i;	  for(i = 0; i < m_clumps.size(); i++)	  {	       TotalFood += static_cast<float>((*MH.GetClumpIter(m_clumps[i])).GetFoodCount());	  }	  if(m_bugbots.size() > TotalFood)	  {	       if(rand() <= static_cast<float>(m_bugbots.size()-TotalFood)/TotalFood)	       {		    return NoPosition;	       }	  }	  TotalFood += TotalFood/20.0f;	  for(i = 0; i < m_clumps.size(); i++)	  {	       list<Clump>::iterator cit = MH.GetClumpIter(m_clumps[i]);	       if((*cit).HasFood())	       {		    if(rnum <= static_cast<float>((*cit).GetFoodCount())/TotalFood)		    {			 clump = i;			 break;		    }		    else		    {			 rnum -= static_cast<float>((*cit).GetFoodCount())/TotalFood;		    }	       }	  }	  if(clump != -1)	  {	       list<Clump>::iterator cit = MH.GetClumpIter(m_clumps[clump]);	       int food;	       food = (*cit).GetAFood();	       list<Food>::iterator foodit = MH.GetFoodIter(food);	       if(food != -1)		    pos = (*foodit).GetPos();				  }	  else	  {			return NoPosition;	  }     }     else     {	  //int bot = *(m_corpses.begin());	  //list<BugBot>::iterator botit = MH.GetBugBotNearest(current_pos);
	   Position tpos;
	   std::vector<Pixel> tpix;
	   int corpse = -1;

		 for(std::vector<int>::iterator i = m_corpses.begin(); i != m_corpses.end(); i++)
		 {
			 if(MH.GetBugBotIter(*i) != 0 && MH.GetBugBotIter(*i)->IsCorpse())
			 {

				tpos = MH.GetBugBotIter(*i)->GetPos();
				tpix.push_back(Pixel(tpos,DistPTP(tpos,current_pos)));
			 }
		 }

		 sort(tpix.begin(),tpix.end());

		 pos = tpix.begin()->Location;

		 if(MH.GetCorpseAt(pos) != 0)
		 {
		 corpse = MH.GetCorpseAt(pos)->GetMe();
		 }

	  if(corpse != -1)	  {		  vector<int>::iterator ci = find(m_corpses.begin(),m_corpses.end(),corpse);
		  if( ci != m_corpses.end())	       m_corpses.erase(ci);
		  return pos;	  } 
	  else return NoPosition;     
	 }     return pos;
}void MainBrain::CreateBugBot(){
     if(m_resources > 1000)     {

		SoundManager *manager = SoundManager::GetInstance();
		manager->PlaySound(SoundManager::SND_BORN);	  Position pos = MH.NoBot(m_pos);	  if(pos == NoPosition)	       return;	  	  m_bugbots.push_back((*MH.NewBugBot(m_me,pos)).GetMe());	  	  m_resources-=1000;	       }}void MainBrain::Update(){     //cout << "MB::Upd" << endl;     CreateBugBot();     //cout << "done creating bugbot, sweeping targetzone" << endl;     SweepTargetZone();     //cout << "L MB::Upd" << endl;}bool MainBrain::OwnerOf(int bot){     using std::count;     return count(m_bugbots.begin(),m_bugbots.end(),bot);}int MainBrain::NumberOfBotsControlled(){     return m_bugbots.size();}Position MainBrain::GetPos(){     return m_pos;}void MainBrain::SetPos(Position pos){     m_pos = pos;}void MainBrain::RemoveRefOfCorpse(int bot){     using std::count;     using std::find;     using std::vector;     if(count(m_corpses.begin(),m_corpses.end(),bot))     {	  vector<int>::iterator i = find(m_corpses.begin(),m_corpses.end(),bot);	  m_corpses.erase(i);     }}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本女优在线视频一区二区| 久久精品一区八戒影视| 亚洲精品乱码久久久久久黑人| www.日韩大片| 亚洲日穴在线视频| 欧美在线制服丝袜| 天天亚洲美女在线视频| 91精品国产一区二区三区 | 中文字幕不卡一区| 成人免费视频app| 一二三四社区欧美黄| 欧美日韩国产精选| 精品亚洲免费视频| 国产精品久久久久影院亚瑟| 色综合天天综合网国产成人综合天 | 欧美日本在线观看| 久久成人久久鬼色| 中文一区二区在线观看| 在线观看视频一区二区 | 久久亚洲精品小早川怜子| 国产成都精品91一区二区三| 亚洲黄色尤物视频| 欧美电视剧免费全集观看| 懂色中文一区二区在线播放| 亚洲图片自拍偷拍| 欧美成人午夜电影| 97se亚洲国产综合自在线观| 日本不卡一二三区黄网| 欧美激情中文不卡| 欧美猛男gaygay网站| 国产激情一区二区三区桃花岛亚洲| 中文字幕一区二区在线播放| 欧美精品在线视频| 成人aa视频在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅 | 91精品免费在线观看| 国产99久久久精品| 日韩国产一区二| 中文字幕乱码久久午夜不卡 | 欧美视频在线一区二区三区 | 国产日韩欧美电影| 欧美精品三级在线观看| 懂色一区二区三区免费观看| 日本特黄久久久高潮| 亚洲三级在线看| 久久中文娱乐网| 欧美欧美午夜aⅴ在线观看| 波多野洁衣一区| 久久国产精品99久久久久久老狼| 中文字幕亚洲欧美在线不卡| 欧美成人精品福利| 欧美日韩aaa| 欧美在线观看视频在线| 成人免费视频视频在线观看免费| 免费观看在线色综合| 夜色激情一区二区| 中文字幕制服丝袜成人av| 精品久久一区二区| 在线播放欧美女士性生活| 91在线国产观看| 国产又黄又大久久| 久久成人18免费观看| 亚洲成人先锋电影| 亚洲自拍偷拍麻豆| 亚洲精品欧美激情| 国产精品久久久久影视| 国产日本亚洲高清| 国产亚洲精品精华液| 久久一留热品黄| 精品欧美黑人一区二区三区| 日韩一级成人av| 欧美一区二区视频在线观看2020| 成a人片亚洲日本久久| 丁香另类激情小说| 风间由美一区二区三区在线观看| 亚洲欧美一区二区三区极速播放| 国产精品的网站| 国产精品不卡在线观看| 国产精品乱码人人做人人爱 | 成人黄色软件下载| 成人深夜在线观看| 99天天综合性| 91麻豆文化传媒在线观看| av一区二区不卡| 99精品视频一区二区| 97久久精品人人澡人人爽| 不卡在线观看av| 日本久久电影网| 欧美三级视频在线观看| 欧美一区二区三区在线观看视频| 欧美大片在线观看一区| 精品国产一区久久| 中文字幕第一页久久| 中文字幕亚洲一区二区av在线| 国产精品久久精品日日| 亚洲精品国产无天堂网2021| 亚洲大片精品永久免费| 日韩激情一区二区| 国产一区二区三区在线观看精品 | 日韩欧美国产电影| 久久午夜免费电影| 成人欧美一区二区三区小说| 一区二区久久久| 精品综合免费视频观看| 国产91在线观看丝袜| 欧美丝袜丝nylons| 欧美哺乳videos| 亚洲丝袜另类动漫二区| 亚洲777理论| 国产在线一区观看| 91久久国产最好的精华液| 欧美美女一区二区在线观看| 久久久国产一区二区三区四区小说| 亚洲国产成人在线| 日韩av网站免费在线| 国产精品性做久久久久久| 色婷婷精品大在线视频| 欧美成人激情免费网| 亚洲视频狠狠干| 卡一卡二国产精品 | 国产精品久久久久影院老司 | 懂色av中文一区二区三区| 91国偷自产一区二区三区观看| 91精品国产91久久久久久一区二区| 久久女同互慰一区二区三区| 亚洲在线成人精品| 国产成人免费xxxxxxxx| 欧美日韩一区二区三区四区五区| 久久久一区二区| 午夜电影网亚洲视频| 高清不卡一二三区| 欧美日本韩国一区二区三区视频| 中文一区在线播放| 麻豆精品一区二区三区| 欧美唯美清纯偷拍| 国产精品久久久久久一区二区三区| 日韩在线一区二区三区| 一本色道久久综合精品竹菊| 久久综合久久综合九色| 午夜精品免费在线| 91蝌蚪porny九色| www成人在线观看| 视频一区欧美精品| 91香蕉视频污在线| 欧美国产乱子伦| 国产一区在线不卡| 日韩精品中午字幕| 亚洲成a人v欧美综合天堂下载 | 国产在线看一区| 欧美欧美欧美欧美首页| 夜夜操天天操亚洲| 色综合久久久久网| 国产精品久久毛片av大全日韩| 国产精华液一区二区三区| 久久婷婷综合激情| 国产制服丝袜一区| 久久综合九色综合欧美98| 蜜桃视频一区二区三区| 制服丝袜亚洲播放| 五月天一区二区三区| 欧美日韩一区二区三区在线| 一级日本不卡的影视| 色网站国产精品| 亚洲一区影音先锋| 在线观看欧美精品| 亚洲综合图片区| 欧美浪妇xxxx高跟鞋交| 日韩制服丝袜av| 日韩一区二区三区在线| 久久99九九99精品| 久久久久久久网| 成人福利视频在线看| 国产精品久久久久久亚洲伦| 99精品热视频| 一区二区三区四区在线免费观看| 91福利在线免费观看| 亚洲伊人伊色伊影伊综合网 | 9191久久久久久久久久久| 亚洲国产日韩精品| 91麻豆精品国产自产在线观看一区 | 久久久精品综合| 成人福利视频网站| 中文字幕在线不卡一区| 91丨porny丨最新| 亚洲高清在线视频| 欧美电影免费观看高清完整版在线| 久久精品国产澳门| 欧美激情中文不卡| 在线一区二区视频| 首页亚洲欧美制服丝腿| 欧美xxxxx牲另类人与| 国产精品一区二区果冻传媒| 久久九九99视频| 一本色道久久综合精品竹菊| 亚洲成人免费影院| 久久久久久久久久久99999| 波多野结衣在线aⅴ中文字幕不卡| 亚洲欧美区自拍先锋| 制服丝袜亚洲网站| 福利视频网站一区二区三区|