1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-26 03:52:01 +02:00

* Adventure Map interface elements configurable (new screen resolutions possible!)

* Data and Sprites subfolders will can be used for adding files not present in .lod archives
* version set to 0.65
This commit is contained in:
Michał W. Urbańczyk 2008-11-12 18:26:23 +00:00
parent d2db5ba18e
commit 89d8bdc069
13 changed files with 398 additions and 143 deletions

View File

@ -6,6 +6,7 @@
#include "hch/CPreGameTextHandler.h" #include "hch/CPreGameTextHandler.h"
#include "hch/CTownHandler.h" #include "hch/CTownHandler.h"
#include "CCallback.h" #include "CCallback.h"
#include "client/CConfigHandler.h"
#include "client/Graphics.h" #include "client/Graphics.h"
AdventureMapButton::AdventureMapButton () AdventureMapButton::AdventureMapButton ()
{ {
@ -32,6 +33,12 @@ AdventureMapButton::AdventureMapButton( const std::map<int,std::string> &Name, c
init(Callback, Name, HelpBox, playerColoredButton, defName, add, x, y, key); init(Callback, Name, HelpBox, playerColoredButton, defName, add, x, y, key);
} }
AdventureMapButton::AdventureMapButton( const std::string &Name, const std::string &HelpBox, const CFunctionList<void()> &Callback, config::ButtonInfo *info, int key/*=0*/ )
{
std::map<int,std::string> pom;
pom[0] = Name;
init(Callback, pom, HelpBox, info->playerColoured, info->defName, &info->additionalDefs, info->x, info->y, key);
}
void AdventureMapButton::clickLeft (tribool down) void AdventureMapButton::clickLeft (tribool down)
{ {
if(blocked) if(blocked)
@ -122,7 +129,7 @@ void AdventureMapButton::init(const CFunctionList<void()> &Callback, const std::
graphics->blueToPlayersAdv(imgs[curimg][i],LOCPLINT->playerID); graphics->blueToPlayersAdv(imgs[curimg][i],LOCPLINT->playerID);
} }
delete temp; delete temp;
if (add) if (add && add->size())
{ {
imgs.resize(imgs.size()+add->size()); imgs.resize(imgs.size()+add->size());
for (int i=0; i<add->size();i++) for (int i=0; i<add->size();i++)
@ -137,7 +144,7 @@ void AdventureMapButton::init(const CFunctionList<void()> &Callback, const std::
} }
delete temp; delete temp;
} }
delete add; //delete add;
} }
pos.x=x; pos.x=x;
pos.y=y; pos.y=y;

View File

@ -2,6 +2,9 @@
#include "CPlayerInterface.h" #include "CPlayerInterface.h"
#include "client/FunctionList.h" #include "client/FunctionList.h"
#include <boost/bind.hpp> #include <boost/bind.hpp>
namespace config{struct ButtonInfo;}
class AdventureMapButton class AdventureMapButton
: public ClickableR, public Hoverable, public KeyShortcut, public CButtonBase : public ClickableR, public Hoverable, public KeyShortcut, public CButtonBase
{ {
@ -22,6 +25,7 @@ public:
AdventureMapButton(); //c-tor AdventureMapButton(); //c-tor
AdventureMapButton( const std::map<int,std::string> &, const std::string &HelpBox, const CFunctionList<void()> &Callback, int x, int y, const std::string &defName, int key=0, std::vector<std::string> * add = NULL, bool playerColoredButton = false );//c-tor AdventureMapButton( const std::map<int,std::string> &, const std::string &HelpBox, const CFunctionList<void()> &Callback, int x, int y, const std::string &defName, int key=0, std::vector<std::string> * add = NULL, bool playerColoredButton = false );//c-tor
AdventureMapButton( const std::string &Name, const std::string &HelpBox, const CFunctionList<void()> &Callback, int x, int y, const std::string &defName, int key=0, std::vector<std::string> * add = NULL, bool playerColoredButton = false );//c-tor AdventureMapButton( const std::string &Name, const std::string &HelpBox, const CFunctionList<void()> &Callback, int x, int y, const std::string &defName, int key=0, std::vector<std::string> * add = NULL, bool playerColoredButton = false );//c-tor
AdventureMapButton( const std::string &Name, const std::string &HelpBox, const CFunctionList<void()> &Callback, config::ButtonInfo *info, int key=0);//c-tor
//AdventureMapButton( std::string Name, std::string HelpBox, boost::function<void()> Callback, int x, int y, std::string defName, bool activ=false, std::vector<std::string> * add = NULL, bool playerColoredButton = false );//c-tor //AdventureMapButton( std::string Name, std::string HelpBox, boost::function<void()> Callback, int x, int y, std::string defName, bool activ=false, std::vector<std::string> * add = NULL, bool playerColoredButton = false );//c-tor
void init(const CFunctionList<void()> &Callback, const std::map<int,std::string> &Name, const std::string &HelpBox, bool playerColoredButton, const std::string &defName, std::vector<std::string> * add, int x, int y, int key ); void init(const CFunctionList<void()> &Callback, const std::map<int,std::string> &Name, const std::string &HelpBox, bool playerColoredButton, const std::string &defName, std::vector<std::string> * add, int x, int y, int key );

View File

@ -30,7 +30,7 @@
#include <sstream> #include <sstream>
#pragma warning (disable : 4355) #pragma warning (disable : 4355)
extern TTF_Font * TNRB16, *TNR, *GEOR13, *GEORXX; //fonts extern TTF_Font * TNRB16, *TNR, *GEOR13, *GEORXX; //fonts
#define ADVOPT (conf.go()->ac)
using namespace boost::logic; using namespace boost::logic;
using namespace boost::assign; using namespace boost::assign;
using namespace CSDL_Ext; using namespace CSDL_Ext;
@ -44,15 +44,16 @@ CMinimap::CMinimap(bool draw)
int3 mapSizes = LOCPLINT->cb->getMapSize(); int3 mapSizes = LOCPLINT->cb->getMapSize();
statusbarTxt = CGI->preth->zelp[291].first; statusbarTxt = CGI->preth->zelp[291].first;
rcText = CGI->preth->zelp[291].second; rcText = CGI->preth->zelp[291].second;
pos.x=630; pos.x=ADVOPT.minimapX;//630
pos.y=26; pos.y=ADVOPT.minimapY;//26
pos.h=pos.w=144; pos.h=ADVOPT.minimapW;//144
pos.w=ADVOPT.minimapH;//144
int rx = (((float)19)/(mapSizes.x))*((float)pos.w), int rx = (((float)19)/(mapSizes.x))*((float)pos.w),
ry = (((float)18)/(mapSizes.y))*((float)pos.h); ry = (((float)18)/(mapSizes.y))*((float)pos.h);
radar = newSurface(rx,ry); radar = newSurface(rx,ry);
temps = newSurface(144,144); temps = newSurface(pos.w,pos.h);
SDL_FillRect(radar,NULL,0x00FFFF); SDL_FillRect(radar,NULL,0x00FFFF);
for (int i=0; i<radar->w; i++) for (int i=0; i<radar->w; i++)
{ {
@ -124,7 +125,8 @@ void CMinimap::draw()
{ {
for (int jj=0; jj<ho; jj++) for (int jj=0; jj<ho; jj++)
{ {
SDL_PutPixel(temps,maplgp.x+ii,maplgp.y+jj,graphics->playerColors[hh[i]->getOwner()].r,graphics->playerColors[hh[i]->getOwner()].g,graphics->playerColors[hh[i]->getOwner()].b); SDL_PutPixel(temps,maplgp.x+ii,maplgp.y+jj,graphics->playerColors[hh[i]->getOwner()].r,
graphics->playerColors[hh[i]->getOwner()].g,graphics->playerColors[hh[i]->getOwner()].b);
} }
} }
} }
@ -145,9 +147,11 @@ void CMinimap::draw()
for (int jj=0; jj<ho; jj++) for (int jj=0; jj<ho; jj++)
{ {
if(oo[v]->tempOwner == 255) if(oo[v]->tempOwner == 255)
SDL_PutPixel(temps,maplgp.x+ii,maplgp.y+jj,graphics->neutralColor->r,graphics->neutralColor->g,graphics->neutralColor->b); SDL_PutPixel(temps,maplgp.x+ii,maplgp.y+jj,graphics->neutralColor->r,
graphics->neutralColor->g,graphics->neutralColor->b);
else else
SDL_PutPixel(temps,maplgp.x+ii,maplgp.y+jj,graphics->playerColors[oo[v]->getOwner()].r,graphics->playerColors[oo[v]->getOwner()].g,graphics->playerColors[oo[v]->getOwner()].b); SDL_PutPixel(temps,maplgp.x+ii,maplgp.y+jj,graphics->playerColors[oo[v]->getOwner()].r,
graphics->playerColors[oo[v]->getOwner()].g,graphics->playerColors[oo[v]->getOwner()].b);
} }
} }
} }
@ -765,10 +769,10 @@ void CResDataBar::deactivate()
} }
CResDataBar::CResDataBar() CResDataBar::CResDataBar()
{ {
bg = BitmapHandler::loadBitmap("ZRESBAR.bmp"); bg = BitmapHandler::loadBitmap(ADVOPT.resdatabarG);
SDL_SetColorKey(bg,SDL_SRCCOLORKEY,SDL_MapRGB(bg->format,0,255,255)); SDL_SetColorKey(bg,SDL_SRCCOLORKEY,SDL_MapRGB(bg->format,0,255,255));
graphics->blueToPlayersAdv(bg,LOCPLINT->playerID); graphics->blueToPlayersAdv(bg,LOCPLINT->playerID);
pos = genRect(bg->h,bg->w,3,575); pos = genRect(bg->h,bg->w,ADVOPT.resdatabarX,ADVOPT.resdatabarY);
txtpos += (std::pair<int,int>(35,577)),(std::pair<int,int>(120,577)),(std::pair<int,int>(205,577)), txtpos += (std::pair<int,int>(35,577)),(std::pair<int,int>(120,577)),(std::pair<int,int>(205,577)),
(std::pair<int,int>(290,577)),(std::pair<int,int>(375,577)),(std::pair<int,int>(460,577)), (std::pair<int,int>(290,577)),(std::pair<int,int>(375,577)),(std::pair<int,int>(460,577)),
@ -974,43 +978,44 @@ void CInfoBar::tick()
CAdvMapInt::CAdvMapInt(int Player) CAdvMapInt::CAdvMapInt(int Player)
:player(Player), :player(Player),
statusbar(7,556), statusbar(ADVOPT.statusbarX,ADVOPT.statusbarY,ADVOPT.statusbarG),
kingOverview(CGI->preth->zelp[293].first,CGI->preth->zelp[293].second, kingOverview(CGI->preth->zelp[293].first,CGI->preth->zelp[293].second,
boost::bind(&CAdvMapInt::fshowOverview,this), 679, 196, "IAM002.DEF", SDLK_k, NULL,true), boost::bind(&CAdvMapInt::fshowOverview,this),&ADVOPT.kingOverview, SDLK_k),
underground(CGI->preth->zelp[294].first,CGI->preth->zelp[294].second, underground(CGI->preth->zelp[294].first,CGI->preth->zelp[294].second,
boost::bind(&CAdvMapInt::fswitchLevel,this), 711, 196, "IAM010.DEF", SDLK_u, new std::vector<std::string>(1,std::string("IAM003.DEF")),true), boost::bind(&CAdvMapInt::fswitchLevel,this),&ADVOPT.underground, SDLK_u),
questlog(CGI->preth->zelp[295].first,CGI->preth->zelp[295].second, questlog(CGI->preth->zelp[295].first,CGI->preth->zelp[295].second,
boost::bind(&CAdvMapInt::fshowQuestlog,this), 679, 228, "IAM004.DEF", SDLK_q, NULL,true), boost::bind(&CAdvMapInt::fshowQuestlog,this),&ADVOPT.questlog, SDLK_q),
sleepWake(CGI->preth->zelp[296].first,CGI->preth->zelp[296].second, sleepWake(CGI->preth->zelp[296].first,CGI->preth->zelp[296].second,
boost::bind(&CAdvMapInt::fsleepWake,this), 711, 228, "IAM005.DEF", SDLK_w, NULL,true), boost::bind(&CAdvMapInt::fsleepWake,this), &ADVOPT.sleepWake, SDLK_w),
moveHero(CGI->preth->zelp[297].first,CGI->preth->zelp[297].second, moveHero(CGI->preth->zelp[297].first,CGI->preth->zelp[297].second,
boost::bind(&CAdvMapInt::fmoveHero,this), 679, 260, "IAM006.DEF", SDLK_m, NULL,true), boost::bind(&CAdvMapInt::fmoveHero,this), &ADVOPT.moveHero, SDLK_m),
spellbook(CGI->preth->zelp[298].first,CGI->preth->zelp[298].second, spellbook(CGI->preth->zelp[298].first,CGI->preth->zelp[298].second,
boost::bind(&CAdvMapInt::fshowSpellbok,this), 711, 260, "IAM007.DEF", SDLK_c, NULL,true), boost::bind(&CAdvMapInt::fshowSpellbok,this), &ADVOPT.spellbook, SDLK_c),
advOptions(CGI->preth->zelp[299].first,CGI->preth->zelp[299].second, advOptions(CGI->preth->zelp[299].first,CGI->preth->zelp[299].second,
boost::bind(&CAdvMapInt::fadventureOPtions,this), 679, 292, "IAM008.DEF", SDLK_a, NULL,true), boost::bind(&CAdvMapInt::fadventureOPtions,this), &ADVOPT.advOptions, SDLK_a),
sysOptions(CGI->preth->zelp[300].first,CGI->preth->zelp[300].second, sysOptions(CGI->preth->zelp[300].first,CGI->preth->zelp[300].second,
boost::bind(&CAdvMapInt::fsystemOptions,this), 711, 292, "IAM009.DEF", SDLK_o, NULL,true), boost::bind(&CAdvMapInt::fsystemOptions,this), &ADVOPT.sysOptions, SDLK_o),
nextHero(CGI->preth->zelp[301].first,CGI->preth->zelp[301].second, nextHero(CGI->preth->zelp[301].first,CGI->preth->zelp[301].second,
boost::bind(&CAdvMapInt::fnextHero,this), 679, 324, "IAM000.DEF", SDLK_h, NULL,true), boost::bind(&CAdvMapInt::fnextHero,this), &ADVOPT.nextHero, SDLK_h),
endTurn(CGI->preth->zelp[302].first,CGI->preth->zelp[302].second, endTurn(CGI->preth->zelp[302].first,CGI->preth->zelp[302].second,
boost::bind(&CAdvMapInt::fendTurn,this), 679, 356, "IAM001.DEF", SDLK_e, NULL,true), boost::bind(&CAdvMapInt::fendTurn,this), &ADVOPT.endTurn, SDLK_e),
townList(5,&genRect(192,48,747,196),747,196,747,372) townList(5,ADVOPT.tlistX,ADVOPT.tlistY,ADVOPT.tlistAU,ADVOPT.tlistAD),//(5,&genRect(192,48,747,196),747,196,747,372),
heroList(ADVOPT.hlistSize)
{ {
selection = NULL; selection = NULL;
townList.fun = boost::bind(&CAdvMapInt::selectionChanged,this); townList.fun = boost::bind(&CAdvMapInt::selectionChanged,this);
LOCPLINT->adventureInt=this; LOCPLINT->adventureInt=this;
bg = BitmapHandler::loadBitmap("ADVMAP.bmp"); bg = BitmapHandler::loadBitmap(ADVOPT.mainGraphic);
graphics->blueToPlayersAdv(bg,player); graphics->blueToPlayersAdv(bg,player);
scrollingLeft = false; scrollingLeft = false;
scrollingRight = false; scrollingRight = false;
@ -1029,10 +1034,10 @@ townList(5,&genRect(192,48,747,196),747,196,747,372)
heroWindow = new CHeroWindow(this->player); heroWindow = new CHeroWindow(this->player);
gems.push_back(CDefHandler::giveDef("agemLL.def")); gems.push_back(CDefHandler::giveDef(ADVOPT.gemG[0]));
gems.push_back(CDefHandler::giveDef("agemLR.def")); gems.push_back(CDefHandler::giveDef(ADVOPT.gemG[1]));
gems.push_back(CDefHandler::giveDef("agemUL.def")); gems.push_back(CDefHandler::giveDef(ADVOPT.gemG[2]));
gems.push_back(CDefHandler::giveDef("agemUR.def")); gems.push_back(CDefHandler::giveDef(ADVOPT.gemG[3]));
} }
void CAdvMapInt::fshowOverview() void CAdvMapInt::fshowOverview()
@ -1243,10 +1248,8 @@ void CAdvMapInt::update()
if(updateScreen) if(updateScreen)
{ {
terrain.show(); terrain.show();
blitAt(gems[2]->ourImages[LOCPLINT->playerID].bitmap,6,6); for(int i=0;i<4;i++)
blitAt(gems[0]->ourImages[LOCPLINT->playerID].bitmap,6,508); blitAt(gems[i]->ourImages[LOCPLINT->playerID].bitmap,ADVOPT.gemX[i],ADVOPT.gemY[i]);
blitAt(gems[1]->ourImages[LOCPLINT->playerID].bitmap,556,508);
blitAt(gems[3]->ourImages[LOCPLINT->playerID].bitmap,556,6);
updateScreen=false; updateScreen=false;
} }
if (updateMinimap) if (updateMinimap)

View File

@ -355,7 +355,7 @@ CCastleInterface::CCastleInterface(const CGTownInstance * Town, bool Activate)
//garrison //garrison
garr = new CGarrisonInt(305,387,4,32,townInt,243,13,town,town->visitingHero); garr = new CGarrisonInt(305,387,4,32,townInt,243,13,town,town->visitingHero);
townlist = new CTownList(3,&genRect(128,48,744,414),744,414,744,526); townlist = new CTownList(3,744,414,"IAM014.DEF","IAM015.DEF");//744,526);
exit = new AdventureMapButton exit = new AdventureMapButton
(CGI->townh->tcommands[8],"",boost::bind(&CCastleInterface::close,this),744,544,"TSBTNS.DEF",SDLK_RETURN); (CGI->townh->tcommands[8],"",boost::bind(&CCastleInterface::close,this),744,544,"TSBTNS.DEF",SDLK_RETURN);
split = new AdventureMapButton split = new AdventureMapButton

View File

@ -13,6 +13,7 @@
#include "SDL_Extensions.h" #include "SDL_Extensions.h"
#include "SDL_framerate.h" #include "SDL_framerate.h"
#include "SDL_framerate.h" #include "SDL_framerate.h"
#include "client/CConfigHandler.h"
#include "client/CCreatureAnimation.h" #include "client/CCreatureAnimation.h"
#include "client/Graphics.h" #include "client/Graphics.h"
#include "hch/CAbilityHandler.h" #include "hch/CAbilityHandler.h"
@ -2353,33 +2354,35 @@ CList::CList(int Size)
CHeroList::CHeroList(int Size) CHeroList::CHeroList(int Size)
:CList(Size) :CList(Size)
{ {
pos = genRect(192,64,609,196); arrup = CDefHandler::giveDef(conf.go()->ac.hlistAU);
arrdo = CDefHandler::giveDef(conf.go()->ac.hlistAD);
arrupp = genRect(16,64,609,196); mobile = CDefHandler::giveDef(conf.go()->ac.hlistMB);
arrdop = genRect(16,64,609,372); mana = CDefHandler::giveDef(conf.go()->ac.hlistMN);
//32px per hero
posmobx = 610;
posmoby = 213;
posporx = 617;
pospory = 212;
posmanx = 666;
posmany = 213;
arrup = CDefHandler::giveDef("IAM012.DEF");
arrdo = CDefHandler::giveDef("IAM013.DEF");
mobile = CDefHandler::giveDef("IMOBIL.DEF");
mana = CDefHandler::giveDef("IMANA.DEF");
empty = BitmapHandler::loadBitmap("HPSXXX.bmp"); empty = BitmapHandler::loadBitmap("HPSXXX.bmp");
selection = BitmapHandler::loadBitmap("HPSYYY.bmp"); selection = BitmapHandler::loadBitmap("HPSYYY.bmp");
SDL_SetColorKey(selection,SDL_SRCCOLORKEY,SDL_MapRGB(selection->format,0,255,255)); SDL_SetColorKey(selection,SDL_SRCCOLORKEY,SDL_MapRGB(selection->format,0,255,255));
pos = genRect(32*SIZE+arrup->h+arrdo->h,std::max(arrup->w,arrdo->w),conf.go()->ac.hlistX,conf.go()->ac.hlistY);
arrupp = genRect(arrup->h,arrup->w,pos.x,pos.y);
arrdop = genRect(arrdo->h,arrdo->w,pos.x,pos.y+32*SIZE+arrup->h);
//32px per hero
posmobx = pos.x+1;
posmoby = pos.y+arrup->h+1;
posporx = pos.x+mobile->w+2;
pospory = pos.y+arrup->h;
posmanx = pos.x+1+50+mobile->w;
posmany = pos.y+arrup->h+1;
from = 0; from = 0;
pressed = indeterminate; pressed = indeterminate;
} }
void CHeroList::init() void CHeroList::init()
{ {
bg = CSDL_Ext::newSurface(68,193,screen); int w = pos.w+1, h = pos.h+4;
SDL_BlitSurface(LOCPLINT->adventureInt->bg,&genRect(193,68,607,196),bg,&genRect(193,68,0,0)); bg = CSDL_Ext::newSurface(w,h,screen);
SDL_BlitSurface(LOCPLINT->adventureInt->bg,&genRect(w,h,pos.x,pos.y),bg,&genRect(w,h,0,0));
} }
void CHeroList::genList() void CHeroList::genList()
{ {
@ -2423,7 +2426,7 @@ void CHeroList::clickLeft(tribool down)
pressed = true; pressed = true;
return; return;
} }
else if(isItIn(&arrdop,LOCPLINT->current->motion.x,LOCPLINT->current->motion.y) && (items.size()-from>5)) else if(isItIn(&arrdop,LOCPLINT->current->motion.x,LOCPLINT->current->motion.y) && (items.size()-from>SIZE))
{ {
blitAt(arrdo->ourImages[1].bitmap,arrdop.x,arrdop.y); blitAt(arrdo->ourImages[1].bitmap,arrdop.x,arrdop.y);
pressed = false; pressed = false;
@ -2434,7 +2437,7 @@ void CHeroList::clickLeft(tribool down)
hx-=pos.x; hx-=pos.x;
hy-=pos.y; hy-=arrup->ourImages[0].bitmap->h; hy-=pos.y; hy-=arrup->ourImages[0].bitmap->h;
int ny = hy/32; int ny = hy/32;
if (ny>=5 || ny<0) if (ny>=SIZE || ny<0)
return; return;
if ( (ny+from)==selected && (LOCPLINT->adventureInt->selection->ID == HEROI_TYPE)) if ( (ny+from)==selected && (LOCPLINT->adventureInt->selection->ID == HEROI_TYPE))
LOCPLINT->openHeroWindow(items[selected].first);//print hero screen LOCPLINT->openHeroWindow(items[selected].first);//print hero screen
@ -2485,7 +2488,7 @@ void CHeroList::mouseMoved (const SDL_MouseMotionEvent & sEvent)
} }
else if(isItIn(&arrdop,LOCPLINT->current->motion.x,LOCPLINT->current->motion.y)) else if(isItIn(&arrdop,LOCPLINT->current->motion.x,LOCPLINT->current->motion.y))
{ {
if ((items.size()-from) > 5) if ((items.size()-from) > SIZE)
LOCPLINT->adventureInt->statusbar.print(CGI->preth->zelp[304].first); LOCPLINT->adventureInt->statusbar.print(CGI->preth->zelp[304].first);
else else
LOCPLINT->adventureInt->statusbar.clear(); LOCPLINT->adventureInt->statusbar.clear();
@ -2496,7 +2499,7 @@ void CHeroList::mouseMoved (const SDL_MouseMotionEvent & sEvent)
hx-=pos.x; hx-=pos.x;
hy-=pos.y; hy-=arrup->ourImages[0].bitmap->h; hy-=pos.y; hy-=arrup->ourImages[0].bitmap->h;
int ny = hy/32; int ny = hy/32;
if ((ny>5 || ny<0) || (from+ny>=items.size())) if ((ny>SIZE || ny<0) || (from+ny>=items.size()))
{ {
LOCPLINT->adventureInt->statusbar.clear(); LOCPLINT->adventureInt->statusbar.clear();
return; return;
@ -2525,7 +2528,7 @@ void CHeroList::clickRight(tribool down)
hx-=pos.x; hx-=pos.x;
hy-=pos.y; hy-=arrup->ourImages[0].bitmap->h; hy-=pos.y; hy-=arrup->ourImages[0].bitmap->h;
int ny = hy/32; int ny = hy/32;
if ((ny>5 || ny<0) || (from+ny>=items.size())) if ((ny>SIZE || ny<0) || (from+ny>=items.size()))
{ {
return; return;
} }
@ -2573,7 +2576,7 @@ void CHeroList::updateMove(const CGHeroInstance* which) //draws move points bar
} }
void CHeroList::draw() void CHeroList::draw()
{ {
for (int iT=0+from;iT<5+from;iT++) for (int iT=0+from;iT<SIZE+from;iT++)
{ {
int i = iT-from; int i = iT-from;
if (iT>=items.size()) if (iT>=items.size())
@ -2588,7 +2591,7 @@ void CHeroList::draw()
if (pom>25) pom=25; if (pom>25) pom=25;
if (pom<0) pom=0; if (pom<0) pom=0;
blitAt(mobile->ourImages[pom].bitmap,posmobx,posmoby+i*32); //move point blitAt(mobile->ourImages[pom].bitmap,posmobx,posmoby+i*32); //move point
pom = cur->mana / 5; //bylo: .../10; pom = cur->mana / 5;
if (pom>25) pom=25; if (pom>25) pom=25;
if (pom<0) pom=0; if (pom<0) pom=0;
blitAt(mana->ourImages[pom].bitmap,posmanx,posmany+i*32); //mana blitAt(mana->ourImages[pom].bitmap,posmanx,posmany+i*32); //mana
@ -2605,7 +2608,7 @@ void CHeroList::draw()
else else
blitAt(arrup->ourImages[2].bitmap,arrupp.x,arrupp.y); blitAt(arrup->ourImages[2].bitmap,arrupp.x,arrupp.y);
if (items.size()-from>5) if (items.size()-from > SIZE)
blitAt(arrdo->ourImages[0].bitmap,arrdop.x,arrdop.y); blitAt(arrdo->ourImages[0].bitmap,arrdop.x,arrdop.y);
else else
blitAt(arrdo->ourImages[2].bitmap,arrdop.x,arrdop.y); blitAt(arrdo->ourImages[2].bitmap,arrdop.x,arrdop.y);
@ -2623,21 +2626,23 @@ CTownList::~CTownList()
delete arrdo; delete arrdo;
} }
CTownList::CTownList(int Size, SDL_Rect * Pos, int arupx, int arupy, int ardox, int ardoy) CTownList::CTownList(int Size, int x, int y, std::string arrupg, std::string arrdog)
:CList(Size) :CList(Size)
{ {
pos = *Pos; arrup = CDefHandler::giveDef(arrupg);
arrup = CDefHandler::giveDef("IAM014.DEF"); arrdo = CDefHandler::giveDef(arrdog);
arrdo = CDefHandler::giveDef("IAM015.DEF"); pos.x = x;
pos.y = y;
pos.w = std::max(arrdo->w,arrup->h);
arrupp.x=arupx; arrupp.x=x;
arrupp.y=arupy; arrupp.y=y;
arrupp.w=arrup->ourImages[0].bitmap->w; arrupp.w=arrup->w;
arrupp.h=arrup->ourImages[0].bitmap->h; arrupp.h=arrup->h;
arrdop.x=ardox; arrdop.x=x;
arrdop.y=ardoy; arrdop.y=y+arrup->h+32*SIZE;
arrdop.w=arrdo->ourImages[0].bitmap->w; arrdop.w=arrdo->w;
arrdop.h=arrdo->ourImages[0].bitmap->h; arrdop.h=arrdo->h;
posporx = arrdop.x; posporx = arrdop.x;
pospory = arrupp.y + arrupp.h; pospory = arrupp.y + arrupp.h;

View File

@ -455,7 +455,7 @@ public:
std::vector<std::pair<const CGHeroInstance*, CPath *> > items; std::vector<std::pair<const CGHeroInstance*, CPath *> > items;
int posmobx, posporx, posmanx, posmoby, pospory, posmany; int posmobx, posporx, posmanx, posmoby, pospory, posmany;
CHeroList(int Size = 5); CHeroList(int Size);
int getPosOfHero(const CArmedInstance* h); int getPosOfHero(const CArmedInstance* h);
void genList(); void genList();
void select(int which); void select(int which);
@ -479,7 +479,7 @@ public:
std::vector<const CGTownInstance*> items; std::vector<const CGTownInstance*> items;
int posporx,pospory; int posporx,pospory;
CTownList(int Size, SDL_Rect * Pos, int arupx, int arupy, int ardox, int ardoy); CTownList(int Size, int x, int y, std::string arrupg, std::string arrdog);
~CTownList(); ~CTownList();
void genList(); void genList();
void select(int which); void select(int which);

View File

@ -1,13 +1,18 @@
//#define BOOST_SPIRIT_DEBUG //#define BOOST_SPIRIT_DEBUG
#include "CConfigHandler.h" #include "CConfigHandler.h"
#include <boost/bind.hpp> #include <boost/bind.hpp>
#include <boost/function.hpp>
#include <boost/spirit.hpp> #include <boost/spirit.hpp>
#include <fstream> #include <fstream>
using namespace config; using namespace config;
using namespace boost::spirit; using namespace boost::spirit;
using namespace phoenix;
CConfigHandler conf; CConfigHandler conf;
GUIOptions *current = NULL;
std::pair<int,int> curRes;
ButtonInfo *currentButton;
int gnb=-1;
struct lerror struct lerror
{ {
@ -23,6 +28,34 @@ struct lerror
tlog1 << txt << std::endl; tlog1 << txt << std::endl;
} }
}; };
struct SetCurButton
{
template<typename IteratorT>
void operator()(IteratorT t1, IteratorT t2) const
{
std::string str(t1,t2);
if(str=="KingdomOv")
currentButton = &current->ac.kingOverview;
else if(str=="Underground")
currentButton = &current->ac.underground;
else if(str=="QuestLog")
currentButton = &current->ac.questlog;
else if(str=="SleepWake")
currentButton = &current->ac.sleepWake;
else if(str=="MoveHero")
currentButton = &current->ac.moveHero;
else if(str=="Spellbook")
currentButton = &current->ac.spellbook;
else if(str=="AdvOptions")
currentButton = &current->ac.advOptions;
else if(str=="SysOptions")
currentButton = &current->ac.sysOptions;
else if(str=="NextHero")
currentButton = &current->ac.nextHero;
else if(str=="EndTurn")
currentButton = &current->ac.endTurn;
}
};
struct lerror2 struct lerror2
{ {
std::string txt; std::string txt;
@ -34,29 +67,114 @@ struct lerror2
tlog1 << txt << txt2 << std::endl; tlog1 << txt << txt2 << std::endl;
} }
}; };
//template <typename T, typename U>
//struct AssignInAll struct dummy
//{ {
// std::vector<T> &items; boost::function<void()> func;
// U T::*pointer; dummy(const boost::function<void()> & F)
// AssignInAll(std::vector<T> &Items, U T::*Pointer) :func(F){}
// :items(Items),pointer(Pointer) template<typename IteratorT>
// {} void operator()(IteratorT t1, IteratorT t2) const
// void operator()(const U &as) {
// { func();
// for(int i=0; i<items.size(); i++) }
// items[i].*pointer = U; };
// }
//}; template<typename T>struct SetButtonProp
{
T point;
SetButtonProp(T p)
:point(p){}
template <typename Z>
void operator()(const Z & val) const
{
currentButton->*point = val;
}
};
template<typename T> SetButtonProp<T> SetButtonProp_a(T p)
{
return SetButtonProp<T>(p);
}
struct SetButtonStr
{
std::string ButtonInfo::*point;
SetButtonStr(std::string ButtonInfo::* p)
:point(p){}
template <typename Z>
void operator()(const Z first, const Z last) const
{
std::string str(first,last);
currentButton->*point = str;
}
};
template<typename T>struct SetAdventureProp
{
T point;
SetAdventureProp(T p)
:point(p){}
template <typename Z>
void operator()(const Z & val) const
{
current->ac.*point = val;
}
};
template<typename T> SetAdventureProp<T> SetAdventureProp_a(T p)
{
return SetAdventureProp<T>(p);
}
struct SetAdventureStr
{
std::string AdventureMapConfig::*point;
SetAdventureStr(std::string AdventureMapConfig::* p)
:point(p){}
template <typename Z>
void operator()(const Z first, const Z last) const
{
std::string str(first,last);
current->ac.*point = str;
}
};
struct AddDefForButton
{
template <typename Z>
void operator()(const Z first, const Z last) const
{
std::string str(first,last);
currentButton->additionalDefs.push_back(str);
}
};
void addGRes()
{
if(current)
conf.guiOptions[curRes] = *current; //we'll use by default settings from previous resolution
current = &conf.guiOptions[curRes];
}
void setGem(int x, int val)
{
if(x)
current->ac.gemX[gnb] = val;
else
current->ac.gemY[gnb] = val;
}
struct AddGemName
{
template <typename Z>
void operator()(const Z first, const Z last) const
{
current->ac.gemG.push_back(std::string(first,last));
}
};
struct SettingsGrammar : public grammar<SettingsGrammar> struct SettingsGrammar : public grammar<SettingsGrammar>
{ {
template <typename ScannerT> template <typename ScannerT>
struct definition struct definition
{ {
rule<ScannerT> r, clientOption, clientOptionsSequence; rule<ScannerT> r, clientOption, clientOptionsSequence, ClientSettings;
rule<ScannerT> GUIOption, GUIOptionsSequence, AdvMapOptionsSequence, AdvMapOption; rule<ScannerT> GUISettings, GUIOption, GUIOptionsSequence, AdvMapOptionsSequence, AdvMapOption;
rule<ScannerT> GUIResolution, fname;
definition(SettingsGrammar const& self) definition(SettingsGrammar const& self)
{ {
fname = lexeme_d[+(alnum_p | '.')];
clientOption clientOption
= str_p("resolution=") >> (uint_p[assign_a(conf.cc.resx)] >> 'x' >> uint_p[assign_a(conf.cc.resy)] | eps_p[lerror("Wrong resolution!")]) = str_p("resolution=") >> (uint_p[assign_a(conf.cc.resx)] >> 'x' >> uint_p[assign_a(conf.cc.resy)] | eps_p[lerror("Wrong resolution!")])
| str_p("port=") >> (uint_p[assign_a(conf.cc.port)] | eps_p[lerror("Wrong port!")]) | str_p("port=") >> (uint_p[assign_a(conf.cc.port)] | eps_p[lerror("Wrong port!")])
@ -67,34 +185,94 @@ struct SettingsGrammar : public grammar<SettingsGrammar>
| str_p("defaultAI=") >> ((+(anychar_p - ';'))[assign_a(conf.cc.defaultAI)] | eps_p[lerror("Wrong defaultAI!")]) | str_p("defaultAI=") >> ((+(anychar_p - ';'))[assign_a(conf.cc.defaultAI)] | eps_p[lerror("Wrong defaultAI!")])
| (+(anychar_p - '}'))[lerror2("Unrecognized client option: ")] | (+(anychar_p - '}'))[lerror2("Unrecognized client option: ")]
; ;
clientOptionsSequence = *(clientOption >> (';' | eps_p[lerror("Semicolon lacking!")])); clientOptionsSequence = *(clientOption >> (';' | eps_p[lerror("Semicolon lacking after client option!")]));
ClientSettings = '{' >> clientOptionsSequence >> '}';
AdvMapOption AdvMapOption
= str_p("Buttons") >> ((ch_p('{') >> '}') | eps_p[lerror("Wrong Buttons!")]) = str_p("Buttons") >> ((ch_p('{') >> '}') | eps_p[lerror("Wrong Buttons!")])
| str_p("Minimap : ") >> | str_p("Minimap: ") >>
*( *(
( "width=" >> uint_p[assign_a(conf.gc.ac.minimap.w)] "width=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::minimapW)]//[assign_a(current->ac.minimapW)]
| "height=" >> uint_p[assign_a(conf.gc.ac.minimap.h)] | "height=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::minimapH)]
| "x=" >> uint_p[assign_a(conf.gc.ac.minimap.x)] | "x=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::minimapX)]
| "y=" >> uint_p[assign_a(conf.gc.ac.minimap.y)] | "y=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::minimapY)]
)
| str_p("Statusbar:") >>
*(
( "x=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::statusbarX)]
| "y=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::statusbarY)]
| "graphic=" >> fname[SetAdventureStr(&AdventureMapConfig::statusbarG)]
) )
>> *ch_p(',') )
); | str_p("ResDataBar:") >>
AdvMapOptionsSequence = *(AdvMapOption >> (';' | eps_p[lerror("Semicolon lacking!")])); *(
( "x=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::resdatabarX)]
GUIOption = str_p("AdventureMap") >> (('{' >> AdvMapOptionsSequence >> '}') | eps_p[lerror("Wrong AdventureMap!")]); | "y=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::resdatabarY)]
| "graphic=" >> fname[SetAdventureStr(&AdventureMapConfig::resdatabarG)]
)
)
| str_p("background=") >> fname[SetAdventureStr(&AdventureMapConfig::mainGraphic)]
| str_p("Button") >> (+(anychar_p-':'))[SetCurButton()] >> ':' >>
*(
( "x=" >> uint_p[SetButtonProp_a(&ButtonInfo::x)]
| "y=" >> uint_p[SetButtonProp_a(&ButtonInfo::y)]
| "playerColoured=" >> uint_p[SetButtonProp_a(&ButtonInfo::playerColoured)]
| "graphic=" >> fname[SetButtonStr(&ButtonInfo::defName)]
| "additionalDefs=" >> ch_p('(') >> fname[AddDefForButton()]
>> *(',' >> fname[AddDefForButton()]) >> ')'
)
)
| str_p("HeroList:") >>
*(
( "x=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::hlistX)]
| "y=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::hlistY)]
| "size=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::hlistSize)]
| "movePoints=" >> fname[SetAdventureStr(&AdventureMapConfig::hlistMB)]
| "manaPoints=" >> fname[SetAdventureStr(&AdventureMapConfig::hlistMN)]
| "arrowUp=" >> fname[SetAdventureStr(&AdventureMapConfig::hlistAU)]
| "arrowDown=" >> fname[SetAdventureStr(&AdventureMapConfig::hlistAD)]
)
)
| str_p("TownList:") >>
*(
( "x=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::tlistX)]
| "y=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::tlistY)]
| "size=" >> uint_p[SetAdventureProp_a(&AdventureMapConfig::tlistSize)]
| "arrowUp=" >> fname[SetAdventureStr(&AdventureMapConfig::tlistAU)]
| "arrowDown=" >> fname[SetAdventureStr(&AdventureMapConfig::tlistAD)]
)
)
| str_p("gem") >> uint_p[var(gnb) = arg1] >> ':' >>
*(
( "x=" >> uint_p[bind(&setGem,1,_1)]
| "y=" >> uint_p[bind(&setGem,0,_1)]
| "graphic=" >> fname[AddGemName()]
)
)
;
AdvMapOptionsSequence = *(AdvMapOption >> (';' | eps_p[lerror("Semicolon lacking in advmapopt!")]));
GUIResolution = (uint_p[assign_a(curRes.first)] >> 'x' >> uint_p[assign_a(curRes.second)])
[dummy(&addGRes)];
GUIOption = str_p("AdventureMap") >> ('{' >> AdvMapOptionsSequence >> '}' | eps_p[lerror("Wrong AdventureMap!")]);
GUIOptionsSequence = *(GUIOption >> (';' | eps_p[lerror("Semicolon after GUIOption lacking!")])); GUIOptionsSequence = *(GUIOption >> (';' | eps_p[lerror("Semicolon after GUIOption lacking!")]));
r = str_p("clientSettings") >> (('{' >> clientOptionsSequence >> '}') | eps_p[lerror("Wrong clientSettings!")]) GUISettings = +(GUIResolution >> '{' >> GUIOptionsSequence >> '}');
>> str_p("GUISettings") >> (('{' >> GUIOptionsSequence >> '}') | eps_p[lerror("Wrong GUISettings!")]);
#ifdef BOOST_SPIRIT_DEBUG
BOOST_SPIRIT_DEBUG_RULE(clientOption); r
BOOST_SPIRIT_DEBUG_RULE(clientOptionsSequence); = str_p("clientSettings") >> (ClientSettings | eps_p[lerror("Wrong clientSettings!")])
BOOST_SPIRIT_DEBUG_RULE(AdvMapOption); >> str_p("GUISettings") >> ('{' >> GUISettings >> '}' | eps_p[lerror("Wrong GUISettings!")]);
BOOST_SPIRIT_DEBUG_RULE(AdvMapOptionsSequence); #ifdef BOOST_SPIRIT_DEBUG
BOOST_SPIRIT_DEBUG_RULE(GUIOption); BOOST_SPIRIT_DEBUG_RULE(clientOption);
BOOST_SPIRIT_DEBUG_RULE(GUIOptionsSequence); BOOST_SPIRIT_DEBUG_RULE(clientOptionsSequence);
BOOST_SPIRIT_DEBUG_RULE(r); BOOST_SPIRIT_DEBUG_RULE(ClientSettings);
#endif BOOST_SPIRIT_DEBUG_RULE(AdvMapOption);
BOOST_SPIRIT_DEBUG_RULE(AdvMapOptionsSequence);
BOOST_SPIRIT_DEBUG_RULE(GUIOption);
BOOST_SPIRIT_DEBUG_RULE(GUIOptionsSequence);
BOOST_SPIRIT_DEBUG_RULE(GUISettings);
BOOST_SPIRIT_DEBUG_RULE(GUIResolution);
BOOST_SPIRIT_DEBUG_RULE(r);
#endif
} }
rule<ScannerT> const& start() const { return r; } rule<ScannerT> const& start() const { return r; }
@ -148,3 +326,8 @@ void config::CConfigHandler::init()
else if(!info.full) else if(!info.full)
tlog2 << "Not entire config/settings.txt parsed!\n"; tlog2 << "Not entire config/settings.txt parsed!\n";
} }
GUIOptions * config::CConfigHandler::go()
{
return &guiOptions[std::pair<int,int>(cc.resx,cc.resy)];
}

View File

@ -10,23 +10,37 @@ namespace config
std::string server, //server address (e.g. 127.0.0.1) std::string server, //server address (e.g. 127.0.0.1)
defaultAI; //dll name defaultAI; //dll name
}; };
struct ButtonInfo
{
std::string defName;
std::vector<std::string> additionalDefs;
int x, y; //position on the screen
bool playerColoured; //if true button will be colored to main player's color (works properly only for appropriate 8bpp graphics)
};
struct AdventureMapConfig struct AdventureMapConfig
{ {
struct ButtonInfo //minimap properties
{ int minimapX, minimapY, minimapW, minimapH;
std::string hoverName, //shows in statusbar when hovered //statusbar
helpBox, //shows in pop-up when r-clicked int statusbarX, statusbarY; //pos
defName; std::string statusbarG; //graphic name
std::vector<std::string> additionalDefs; //resdatabar
void (CAdvMapInt::*func)(); //function in advmapint bound to that button int resdatabarX, resdatabarY; //pos
int x, y; //position on the screen std::string resdatabarG; //graphic name
bool playerColoured; //if true button will be colored to main player's color (works properly only for appropriate 8bpp graphics) //general properties
}; std::string mainGraphic;
struct Minimap //buttons
{ ButtonInfo kingOverview, underground, questlog, sleepWake, moveHero, spellbook, advOptions,
int x, y, w, h; sysOptions, nextHero, endTurn;
} minimap; //hero list
std::vector<ButtonInfo> buttons; int hlistX, hlistY, hlistSize;
std::string hlistMB, hlistMN, hlistAU, hlistAD;
//town list
int tlistX, tlistY, tlistSize;
std::string tlistAU, tlistAD;
//gems
int gemX[4], gemY[4];
std::vector<std::string> gemG;
}; };
struct GUIOptions struct GUIOptions
{ {
@ -36,7 +50,8 @@ namespace config
{ {
public: public:
ClientConfig cc; ClientConfig cc;
GUIOptions gc; std::map<std::pair<int,int>, GUIOptions > guiOptions;
GUIOptions *go(); //return pointer to gui options appropriate for used screen resolution
void init(); void init();
CConfigHandler(void); CConfigHandler(void);
~CConfigHandler(void); ~CConfigHandler(void);

View File

@ -12,13 +12,42 @@ clientSettings
} }
GUISettings GUISettings
{ {
//800x600 //settings specific for 800x600 resolution 800x600 //settings for 800x600 resolution
//{ {
AdventureMap AdventureMap
{ {
Buttons gem0: x=6 y=508 graphic=agemLL.def;
{ gem1: x=556 y=508 graphic=agemLR.def;
}; gem2: x=6 y=6 graphic=agemUL.def;
gem3: x=556 y=6 graphic=agemUR.def;
background=ADVMAP.bmp;
HeroList: size=5 x=609 y=196 movePoints=IMOBIL.DEF manaPoints=IMANA.DEF arrowUp=IAM012.DEF arrowDown=IAM013.DEF;
TownList: size=5 x=747 y=196 arrowUp=IAM014.DEF arrowDown=IAM015.DEF;
Minimap: width=144 height=144 x=630 y=26;
Statusbar: x=7 y=556 graphic=ADROLLVR.bmp;
ResDataBar: x=3 y=575 graphic=ZRESBAR.bmp;
ButtonKingdomOv: x=679 y=196 graphic=IAM002.DEF playerColoured=1;
ButtonUnderground: x=711 y=196 graphic=IAM010.DEF playerColoured=1 additionalDefs=(IAM003.DEF);
ButtonQuestLog: x=679 y=228 graphic=IAM004.DEF playerColoured=1;
ButtonSleepWake: x=711 y=228 graphic=IAM005.DEF playerColoured=1;
ButtonMoveHero: x=679 y=260 graphic=IAM006.DEF playerColoured=1;
ButtonSpellbook: x=711 y=260 graphic=IAM007.DEF playerColoured=1;
ButtonAdvOptions: x=679 y=292 graphic=IAM008.DEF playerColoured=1;
ButtonSysOptions: x=711 y=292 graphic=IAM009.DEF playerColoured=1;
ButtonNextHero: x=679 y=324 graphic=IAM000.DEF playerColoured=1;
ButtonEndTurn: x=679 y=356 graphic=IAM001.DEF playerColoured=1;
}; };
//}; }
1024x600 //setting specific for this resolution
{
AdventureMap
{
};
}
1024x768 //setting specific for this resolution
{
AdventureMap
{
};
}
} }

View File

@ -18,7 +18,7 @@ typedef boost::int8_t si8; //signed int 8 bits (1 byte)
#define THC #define THC
#endif #endif
#define NAME_VER ("VCMI 0.64") #define NAME_VER ("VCMI 0.65")
#define CONSOLE_LOGGING_LEVEL 5 #define CONSOLE_LOGGING_LEVEL 5
#define FILE_LOGGING_LEVEL 6 #define FILE_LOGGING_LEVEL 6

View File

@ -59,8 +59,8 @@ void CDefHandler::openDef(std::string name)
delete is; delete is;
i = 0; i = 0;
DEFType = readNormalNr(i,4,FDef); i+=4; DEFType = readNormalNr(i,4,FDef); i+=4;
fullWidth = readNormalNr(i,4,FDef); i+=4; w = readNormalNr(i,4,FDef); i+=4;
fullHeight = readNormalNr(i,4,FDef); i+=4; h = readNormalNr(i,4,FDef); i+=4;
i=0xc; i=0xc;
totalBlocks = readNormalNr(i,4,FDef); i+=4; totalBlocks = readNormalNr(i,4,FDef); i+=4;
@ -123,8 +123,8 @@ void CDefHandler::openFromMemory(unsigned char *table, std::string name)
defName=name; defName=name;
i = 0; i = 0;
DEFType = readNormalNr(i,4,table); i+=4; DEFType = readNormalNr(i,4,table); i+=4;
fullWidth = readNormalNr(i,4,table); i+=4; w = readNormalNr(i,4,table); i+=4;
fullHeight = readNormalNr(i,4,table); i+=4; h = readNormalNr(i,4,table); i+=4;
i=0xc; i=0xc;
totalBlocks = readNormalNr(i,4,table); i+=4; totalBlocks = readNormalNr(i,4,table); i+=4;
@ -168,7 +168,7 @@ void CDefHandler::openFromMemory(unsigned char *table, std::string name)
{ {
SEntries[j].name = SEntries[j].name.substr(0, SEntries[j].name.find('.')+4); SEntries[j].name = SEntries[j].name.substr(0, SEntries[j].name.find('.')+4);
} }
RWEntries = new unsigned int[fullHeight]; RWEntries = new unsigned int[h];
for(int i=0; i<SEntries.size(); ++i) for(int i=0; i<SEntries.size(); ++i)
{ {
Cimage nimg; Cimage nimg;

View File

@ -15,7 +15,7 @@ struct Cimage
class CDefHandler class CDefHandler
{ {
private: private:
int totalEntries, DEFType, totalBlocks, fullWidth, fullHeight; int totalEntries, DEFType, totalBlocks;
bool allowRepaint; bool allowRepaint;
int length; int length;
unsigned int * RWEntries; unsigned int * RWEntries;
@ -28,6 +28,7 @@ private:
std::vector<SEntry> SEntries ; std::vector<SEntry> SEntries ;
public: public:
int w, h; //width and height
static CLodHandler * Spriteh; static CLodHandler * Spriteh;
std::string defName, curDir; std::string defName, curDir;
std::vector<Cimage> ourImages; std::vector<Cimage> ourImages;

View File

@ -384,11 +384,19 @@ void CLodHandler::init(std::string lodFile, std::string dirName)
std::transform(name.begin(), name.end(), name.begin(), (int(*)(int))toupper); std::transform(name.begin(), name.end(), name.begin(), (int(*)(int))toupper);
boost::algorithm::replace_all(name,".BMP",".PCX"); boost::algorithm::replace_all(name,".BMP",".PCX");
Entry * e = entries.znajdz(name); Entry * e = entries.znajdz(name);
if(e) if(e) //file present in .lod - overwrite its entry
{ {
e->offset = -1; e->offset = -1;
e->realSize = e->size = boost::filesystem::file_size(dir->path()); e->realSize = e->size = boost::filesystem::file_size(dir->path());
} }
else //file not present in lod - add entry for it
{
Entry e;
e.offset = -1;
e.nameStr = name;
e.realSize = e.size = boost::filesystem::file_size(dir->path());
entries.push_back(e);
}
} }
} }
} }