1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-16 02:47:36 +02:00

* poprawna obsługa podziemi, przełączanie widoku przez "u"

* naprawione nagłówki
* okno ma tytuł
This commit is contained in:
Michał W. Urbańczyk 2007-06-09 02:32:43 +00:00
parent 081b2ec024
commit 7b84806588
9 changed files with 90 additions and 21 deletions

View File

@ -1,5 +1,5 @@
#include "stdafx.h"
#include "CAbilityHandler.h"
#include <fstream>
void CAbilityHandler::loadAbilities()
{

View File

@ -1,7 +1,6 @@
#include "stdafx.h"
#include "CAmbarCendamo.h"
#include "CSemiDefHandler.h"
#include <fstream>
#include <set>
CAmbarCendamo::CAmbarCendamo (const char * tie)
{
@ -290,9 +289,9 @@ void CAmbarCendamo::deh3m()
}
if (map.twoLevel) // read underground terrain
{
for (int z=0; z<map.width; z++) // reading terrain
for (int c=0; c<map.width; c++) // reading terrain
{
for (int c=0; c<map.height; c++)
for (int z=0; z<map.height; z++)
{
map.undergroungTerrain[z][c].tertype = (EterrainType)(bufor[i++]);
map.undergroungTerrain[z][c].terview = bufor[i++];
@ -344,13 +343,20 @@ void CAmbarCendamo::loadDefs()
{
for (int j=0; j<map.width; j++)
{
if (loadedTypes.find(map.terrain[i][j].tertype)==loadedTypes.end())
{
CSemiDefHandler *sdh = new CSemiDefHandler();
sdh->openDef(("H3sprite.lod\\"+sdh->nameFromType(map.terrain[i][j].tertype)).c_str());
loadedTypes.insert(map.terrain[i][j].tertype);
defs.push_back(sdh);
}
if (loadedTypes.find(map.terrain[i][j].tertype)==loadedTypes.end())
{
CSemiDefHandler *sdh = new CSemiDefHandler();
sdh->openDef(("H3sprite.lod\\"+sdh->nameFromType(map.terrain[i][j].tertype)).c_str());
loadedTypes.insert(map.terrain[i][j].tertype);
defs.push_back(sdh);
}
if (loadedTypes.find(map.undergroungTerrain[i][j].tertype)==loadedTypes.end())
{
CSemiDefHandler *sdh = new CSemiDefHandler();
sdh->openDef(("H3sprite.lod\\"+sdh->nameFromType(map.undergroungTerrain[i][j].tertype)).c_str());
loadedTypes.insert(map.undergroungTerrain[i][j].tertype);
defs.push_back(sdh);
}
}
}
};

View File

@ -1,5 +1,5 @@
#include "stdafx.h"
#include "CArtHandler.h"
#include <fstream>
void CArtHandler::loadArtifacts()
{

View File

@ -1,5 +1,5 @@
#include "stdafx.h"
#include "CCreatureHandler.h"
#include <fstream>
void CCreatureHandler::loadCreatures()
{

View File

@ -1,4 +1,4 @@
#include <fstream>
#include "stdafx.h"
#include "CHeroHandler.h"
void CHeroHandler::loadHeroes()

13
CMT.cpp
View File

@ -24,6 +24,7 @@
#endif
#define CHUNK 16384
#define pi 3.14159
const char * NAME = "VCMI 0.1";
#include "CAmbarCendamo.h"
@ -196,7 +197,7 @@ void SDL_PutPixel(SDL_Surface *ekran, int x, int y, Uint8 R, Uint8 G, Uint8 B)
}
int _tmain(int argc, _TCHAR* argv[])
{
int xx=0, yy=0;
int xx=0, yy=0, zz=0;
SDL_Event sEvent;
srand ( time(NULL) );
SDL_Surface *screen, *temp;
@ -223,6 +224,7 @@ int _tmain(int argc, _TCHAR* argv[])
// def(zr,ko,i);
// fclose(ko);fclose(zr);
//}
SDL_WM_SetCaption(NAME,"");
THC timeHandler tmh;
CArtHandler * arth = new CArtHandler;
arth->loadArtifacts();
@ -295,9 +297,16 @@ int _tmain(int argc, _TCHAR* argv[])
return 0;
break;
}
case (SDLK_u):
{
if (zz)
zz--;
else zz++;
break;
}
}
SDL_FillRect(ekran, NULL, SDL_MapRGB(ekran->format, 0, 0, 0));
SDL_Surface * help = mh->terrainRect(xx,yy,32,24);
SDL_Surface * help = mh->terrainRect(xx,yy,32,24,zz);
SDL_BlitSurface(help,NULL,ekran,NULL);
SDL_FreeSurface(help);
SDL_Flip(ekran);

View File

@ -55,8 +55,60 @@ void mapHandler::init()
}
}
}
if (reader->map.twoLevel)
{
undTerrainBitmap = new SDL_Surface **[reader->map.width];
for (int ii=0;ii<reader->map.width;ii++)
undTerrainBitmap[ii] = new SDL_Surface*[reader->map.height]; // allocate memory
for (int i=0; i<reader->map.width; i++)
{
for (int j=0; j<reader->map.height;j++)
{
TerrainTile zz = reader->map.undergroungTerrain[i][j];
std::string name = CSemiDefHandler::nameFromType(reader->map.undergroungTerrain[i][j].tertype);
for (int k=0; k<reader->defs.size(); k++)
{
try
{
if (reader->defs[k]->defName != name)
continue;
else
{
SDL_Surface * n;
int ktora = reader->map.undergroungTerrain[i][j].terview;
undTerrainBitmap[i][j] = reader->defs[k]->ourImages[ktora].bitmap;
//TODO: odwracanie
switch ((reader->map.undergroungTerrain[i][j].siodmyTajemniczyBajt)%4)
{
case 1:
{
undTerrainBitmap[i][j] = CSDL_Ext::rotate01(undTerrainBitmap[i][j]);
break;
}
case 2:
{
undTerrainBitmap[i][j] = CSDL_Ext::hFlip(undTerrainBitmap[i][j]);
break;
}
case 3:
{
undTerrainBitmap[i][j] = CSDL_Ext::rotate03(undTerrainBitmap[i][j]);
break;
}
}
//SDL_BlitSurface(undTerrainBitmap[i][j],NULL,ekran,NULL); SDL_Flip(ekran);SDL_Delay(50);
break;
}
}
catch (...)
{ continue; }
}
}
}
}
}
SDL_Surface * mapHandler::terrainRect(int x, int y, int dx, int dy)
SDL_Surface * mapHandler::terrainRect(int x, int y, int dx, int dy, int level)
{
#if SDL_BYTEORDER == SDL_BIG_ENDIAN
int rmask = 0xff000000;
@ -81,8 +133,10 @@ SDL_Surface * mapHandler::terrainRect(int x, int y, int dx, int dy)
sr->y=by*32;
sr->x=bx*32;
sr->h=sr->w=32;
SDL_BlitSurface(terrainBitmap[bx+x][by+y],NULL,su,sr);
if (!level)
SDL_BlitSurface(terrainBitmap[bx+x][by+y],NULL,su,sr);
else
SDL_BlitSurface(undTerrainBitmap[bx+x][by+y],NULL,su,sr);
delete sr;
//SDL_BlitSurface(su,NULL,ekran,NULL);SDL_Flip(ekran);
}

View File

@ -5,7 +5,7 @@ public:
CAmbarCendamo * reader;
SDL_Surface *** terrainBitmap;
SDL_Surface *** undTerrainBitmap; // used only if there is underground level
SDL_Surface * terrainRect(int x, int y, int dx, int dy);
SDL_Surface * terrainRect(int x, int y, int dx, int dy, int level=0);
SDL_Surface mirrorImage(SDL_Surface *src);
void init();
};

View File

@ -11,6 +11,6 @@
#include <tchar.h>
#include <string>
#include <vector>
#include <fstream>
// TODO: reference additional headers your program requires here