瀏覽代碼

lepsze przewijanie, wczytywanie większej ilosci tekstów

mateuszb 18 年之前
父節點
當前提交
bc7532e4dd
共有 6 個文件被更改,包括 359 次插入18 次删除
  1. 2 0
      CArtHandler.cpp
  2. 181 0
      CCreatureHandler.cpp
  3. 11 0
      CCreatureHandler.h
  4. 81 0
      CHeroHandler.cpp
  5. 16 0
      CHeroHandler.h
  6. 68 18
      CMT.cpp

+ 2 - 0
CArtHandler.cpp

@@ -201,6 +201,8 @@ void CArtHandler::loadArtifacts()
 		while(nart.desc2[nart.desc2.size()-1]!='"' ||
 			( (nart.name==std::string("£uk Penetracji")||nart.name==std::string("Bow of Seeking")) && bowCounter<4) ); //do - while end
 		//if(nart.name!=std::string("-1") && nart.name!=std::string("-2"))
+		nart.description += "\n\n";
+		nart.description += nart.desc2;
 		this->artifacts.push_back(nart);
 		delete[10000] read;
 	}

+ 181 - 0
CCreatureHandler.cpp

@@ -25,7 +25,10 @@ void CCreatureHandler::loadCreatures()
 	while(i<buf.size())
 	{
 		if(creatures.size()>190 && buf.substr(i, buf.size()-i).find('\r')==std::string::npos)
+		{
+			loadAnimationInfo();
 			break;
+		}
 
 		CCreature ncre;
 
@@ -261,3 +264,181 @@ void CCreatureHandler::loadCreatures()
 	}
 }
 
+void CCreatureHandler::loadAnimationInfo()
+{
+	std::ifstream inp("H3bitmap.lod\\CRANIM.TXT", std::ios::in|std::ios::binary);
+	inp.seekg(0,std::ios::end); // na koniec
+	int andame = inp.tellg();  // read length
+	inp.seekg(0,std::ios::beg); // wracamy na poczatek
+	char * bufor = new char[andame]; // allocate memory 
+	inp.read((char*)bufor, andame); // read map file to buffer
+	std::string buf = std::string(bufor);
+	delete [andame] bufor;
+	int i=0; //buf iterator
+	int hmcr=0;
+	for(i; i<andame; ++i)
+	{
+		if(buf[i]=='\r')
+			++hmcr;
+		if(hmcr==2)
+			break;
+	}
+	i+=2;
+	for(int dd=0; dd<creatures.size(); ++dd)
+	{
+		loadUnitAnimInfo(creatures[dd], buf, i);
+	}
+	return;
+}
+
+void CCreatureHandler::loadUnitAnimInfo(CCreature & unit, std::string & src, int & i)
+{
+	int befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.timeBetweenFidgets = atof(src.substr(befi, i-befi).c_str());
+	++i;
+
+	while(unit.timeBetweenFidgets == 0.0)
+	{
+		for(i; i<src.size(); ++i)
+		{
+			if(src[i]=='\r')
+				break;
+		}
+		i+=2;
+		befi=i;
+		for(i; i<src.size(); ++i)
+		{
+			if(src[i]=='\t')
+				break;
+		}
+		unit.timeBetweenFidgets = atof(src.substr(befi, i-befi).c_str());
+		++i;
+	}
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.walkAnimationTime = atof(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.attackAnimationTime = atof(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.flightAnimationDistance = atof(src.substr(befi, i-befi).c_str());
+	++i;
+
+	///////////////////////
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.upperRightMissleOffsetX = atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.upperRightMissleOffsetY = atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.rightMissleOffsetX = atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.rightMissleOffsetY = atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.lowerRightMissleOffsetX = atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.lowerRightMissleOffsetY = atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	///////////////////////
+
+	for(int jjj=0; jjj<12; ++jjj)
+	{
+		befi=i;
+		for(i; i<src.size(); ++i)
+		{
+			if(src[i]=='\t')
+				break;
+		}
+		unit.missleFrameAngles[jjj] = atof(src.substr(befi, i-befi).c_str());
+		++i;
+	}
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.troopCountLocationOffset= atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	befi=i;
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\t')
+			break;
+	}
+	unit.attackClimaxFrame = atoi(src.substr(befi, i-befi).c_str());
+	++i;
+
+	for(i; i<src.size(); ++i)
+	{
+		if(src[i]=='\r')
+			break;
+	}
+	i+=2;
+}

+ 11 - 0
CCreatureHandler.h

@@ -13,6 +13,15 @@ public:
 	std::string abilityText; //description of abilities
 	std::string abilityRefs; //references to abilities, in textformat
 	int idNumber;
+
+	///animation info
+	float timeBetweenFidgets, walkAnimationTime, attackAnimationTime, flightAnimationDistance;
+	int upperRightMissleOffsetX, rightMissleOffsetX, lowerRightMissleOffsetX, upperRightMissleOffsetY, rightMissleOffsetY, lowerRightMissleOffsetY;
+	float missleFrameAngles[12];
+	int troopCountLocationOffset, attackClimaxFrame;
+	///end of anim info
+
+
 	//TODO - zdolnoœci - na typie wyliczeniowym czy czymœ
 };
 
@@ -29,6 +38,8 @@ class CCreatureHandler
 public:
 	std::vector<CCreature> creatures;
 	void loadCreatures();
+	void loadAnimationInfo();
+	void loadUnitAnimInfo(CCreature & unit, std::string & src, int & i);
 };
 
 #endif //CCREATUREHANDLER_H

+ 81 - 0
CHeroHandler.cpp

@@ -185,3 +185,84 @@ void CHeroHandler::loadBiographies()
 		i+=2;
 	}
 }
+
+void CHeroHandler::loadHeroClasses()
+{
+	std::ifstream inp("H3bitmap.lod\\HCTRAITS.TXT", std::ios::in | std::ios::binary);
+	inp.seekg(0,std::ios::end); // na koniec
+	int andame = inp.tellg();  // read length
+	inp.seekg(0,std::ios::beg); // wracamy na poczatek
+	char * bufor = new char[andame]; // allocate memory 
+	inp.read((char*)bufor, andame); // read map file to buffer
+	std::string buf = std::string(bufor);
+	delete [andame] bufor;
+	int i = 0; //buf iterator
+	int hmcr = 0;
+	for(i; i<andame; ++i) //omitting rubbish
+	{
+		if(buf[i]=='\r')
+			++hmcr;
+		if(hmcr==2)
+			break;
+	}
+	i+=2;
+	for(int ss=0; ss<18; ++ss) //18 classes of hero (including conflux)
+	{
+		CHeroClass * hc = new CHeroClass;
+		int befi=i;
+		for(i; i<andame; ++i)
+		{
+			if(buf[i]=='\t')
+				break;
+		}
+		hc->name = buf.substr(befi, i-befi);
+		++i;
+
+		befi=i;
+		for(i; i<andame; ++i)
+		{
+			if(buf[i]=='\t')
+				break;
+		}
+		hc->aggression = atof(buf.substr(befi, i-befi).c_str());
+		++i;
+
+		befi=i;
+		for(i; i<andame; ++i)
+		{
+			if(buf[i]=='\t')
+				break;
+		}
+		hc->initialAttack = atoi(buf.substr(befi, i-befi).c_str());
+		++i;
+
+		befi=i;
+		for(i; i<andame; ++i)
+		{
+			if(buf[i]=='\t')
+				break;
+		}
+		hc->initialDefence = atoi(buf.substr(befi, i-befi).c_str());
+		++i;
+
+		befi=i;
+		for(i; i<andame; ++i)
+		{
+			if(buf[i]=='\t')
+				break;
+		}
+		hc->initialPower = atoi(buf.substr(befi, i-befi).c_str());
+		++i;
+
+		befi=i;
+		for(i; i<andame; ++i)
+		{
+			if(buf[i]=='\t')
+				break;
+		}
+		hc->initialKnowledge = atoi(buf.substr(befi, i-befi).c_str());
+		++i;
+
+
+	}
+}

+ 16 - 0
CHeroHandler.h

@@ -19,6 +19,20 @@ public:
 	bool operator<(CHero& drugi){if (ID < drugi.ID) return true; else return false;}
 };
 
+class CHeroClass
+{
+public:
+	std::string name;
+	float aggression;
+	int initialAttack, initialDefence, initialPower, initialKnowledge;
+	int proAttack[2]; //probability of gaining attack point on levels [0]: 2 - 9; [1]: 10+  (out of 100)
+	int proDefence[2]; //probability of gaining defence point on levels [0]: 2 - 9; [1]: 10+ (out of 100)
+	int proPower[2]; //probability of gaining power point on levels [0]: 2 - 9; [1]: 10+ (out of 100)
+	int proKnowledge[2]; //probability of gaining knowledge point on levels [0]: 2 - 9; [1]: 10+ (out of 100)
+	std::vector<int> proSec; //probabilities of gaining secondary skills (out of 112), in id order
+	int selectionProbability[9]; //probability of selection in towns
+};
+
 class CHeroInstance
 {
 public:
@@ -32,9 +46,11 @@ class CHeroHandler
 {
 public:
 	nodrze<CHero> heroes;
+	std::vector<CHeroClass> heroClasses;
 	void loadHeroes();
 	void loadSpecialAbilities();
 	void loadBiographies();
+	void loadHeroClasses();
 };
 
 

+ 68 - 18
CMT.cpp

@@ -240,15 +240,15 @@ int _tmain(int argc, _TCHAR* argv[])
 		CArtHandler * arth = new CArtHandler;
 		arth->loadArtifacts();
 		cgi->arth = arth;
-		CHeroHandler * heroh = new CHeroHandler;
-		heroh->loadHeroes();
-		cgi->heroh = heroh;
 		CCreatureHandler * creh = new CCreatureHandler;
 		creh->loadCreatures();
 		cgi->creh = creh;
 		CAbilityHandler * abilh = new CAbilityHandler;
 		abilh->loadAbilities();
 		cgi->abilh = abilh;
+		CHeroHandler * heroh = new CHeroHandler;
+		heroh->loadHeroes();
+		cgi->heroh = heroh;
 		CSpellHandler * spellh = new CSpellHandler;
 		spellh->loadSpells();
 		cgi->spellh = spellh;
@@ -281,6 +281,10 @@ int _tmain(int argc, _TCHAR* argv[])
 		//SDL_Surface * ss = ac->defs[0]->ourImages[0].bitmap;
 		//SDL_BlitSurface(ss, NULL, ekran, NULL);
 
+		bool scrollingLeft = false;
+		bool scrollingRight = false;
+		bool scrollingUp = false;
+		bool scrollingDown = false;
 		for(;;) // main loop
 		{
 			try
@@ -295,26 +299,22 @@ int _tmain(int argc, _TCHAR* argv[])
 						{
 						case SDLK_LEFT:
 							{
-								if(xx>0)
-									xx--;
+								scrollingLeft = true;
 								break;
 							}
 						case (SDLK_RIGHT):
 							{
-								if(xx<ac->map.width-25)
-									xx++;
+								scrollingRight = true;
 								break;
 							}
 						case (SDLK_UP):
 							{
-								if(yy>0)
-									yy--;
+								scrollingUp = true;
 								break;
 							}
 						case (SDLK_DOWN):
 							{
-								if(yy<ac->map.height-18)
-									yy++;
+								scrollingDown = true;
 								break;
 							}
 						case (SDLK_q):
@@ -332,18 +332,68 @@ int _tmain(int argc, _TCHAR* argv[])
 								break;
 							}
 						}
-						SDL_FillRect(ekran, NULL, SDL_MapRGB(ekran->format, 0, 0, 0));
-						SDL_Surface * help = mh->terrainRect(xx,yy,25,18,zz);
-						SDL_BlitSurface(help,NULL,ekran,NULL);
-						SDL_FreeSurface(help);
-						SDL_Flip(ekran);
-					}
+					} //keydown end
+					else if(sEvent.type==SDL_KEYUP) 
+					{
+						switch (sEvent.key.keysym.sym)
+						{
+						case SDLK_LEFT:
+							{
+								scrollingLeft = false;
+								break;
+							}
+						case (SDLK_RIGHT):
+							{
+								scrollingRight = false;
+								break;
+							}
+						case (SDLK_UP):
+							{
+								scrollingUp = false;
+								break;
+							}
+						case (SDLK_DOWN):
+							{
+								scrollingDown = false;
+								break;
+							}
+						}
+					}//keyup end
+				} //event end
+
+				/////////////// scrolling terrain
+				if(scrollingLeft)
+				{
+					if(xx>0)
+						xx--;
+				}
+				if(scrollingRight)
+				{
+					if(xx<ac->map.width-25)
+						xx++;
+				}
+				if(scrollingUp)
+				{
+					if(yy>0)
+						yy--;
+				}
+				if(scrollingDown)
+				{
+					if(yy<ac->map.height-18)
+						yy++;
 				}
+				
+				SDL_FillRect(ekran, NULL, SDL_MapRGB(ekran->format, 0, 0, 0));
+				SDL_Surface * help = mh->terrainRect(xx,yy,25,18,zz);
+				SDL_BlitSurface(help,NULL,ekran,NULL);
+				SDL_FreeSurface(help);
+				SDL_Flip(ekran);
+				/////////
 			}
 			catch(...)
 			{ continue; }
 
-			SDL_Delay(30); //give time for other apps
+			SDL_Delay(25); //give time for other apps
 		}
 		return 0;
 	}