|
@@ -29,6 +29,9 @@
|
|
#include <boost/function.hpp>
|
|
#include <boost/function.hpp>
|
|
#include <boost/ref.hpp>
|
|
#include <boost/ref.hpp>
|
|
#include <boost/foreach.hpp>
|
|
#include <boost/foreach.hpp>
|
|
|
|
+#include <boost/assign/std/vector.hpp>
|
|
|
|
+#include <boost/assign/list_of.hpp>
|
|
|
|
+
|
|
#include <cstdlib>
|
|
#include <cstdlib>
|
|
#include "../lib/Connection.h"
|
|
#include "../lib/Connection.h"
|
|
#include "../lib/VCMIDirs.h"
|
|
#include "../lib/VCMIDirs.h"
|
|
@@ -86,7 +89,7 @@ struct EvilHlpStruct
|
|
CConnection *serv;
|
|
CConnection *serv;
|
|
StartInfo *sInfo;
|
|
StartInfo *sInfo;
|
|
|
|
|
|
- void reset(bool strong = true)
|
|
|
|
|
|
+ void reset(bool strong = true)
|
|
{
|
|
{
|
|
if(strong)
|
|
if(strong)
|
|
{
|
|
{
|
|
@@ -148,7 +151,7 @@ void setPlayer(PlayerSettings &pset, unsigned player, const std::map<ui32, std::
|
|
void updateStartInfo(std::string filename, StartInfo & sInfo, const CMapHeader * mapHeader, const std::map<ui32, std::string> &playerNames)
|
|
void updateStartInfo(std::string filename, StartInfo & sInfo, const CMapHeader * mapHeader, const std::map<ui32, std::string> &playerNames)
|
|
{
|
|
{
|
|
sInfo.playerInfos.clear();
|
|
sInfo.playerInfos.clear();
|
|
- if(!filename.size())
|
|
|
|
|
|
+ if(!filename.size())
|
|
return;
|
|
return;
|
|
|
|
|
|
/*sInfo.playerInfos.resize(to->playerAmnt);*/
|
|
/*sInfo.playerInfos.resize(to->playerAmnt);*/
|
|
@@ -191,7 +194,7 @@ template <typename T> class CApplyOnPG;
|
|
class CBaseForPGApply
|
|
class CBaseForPGApply
|
|
{
|
|
{
|
|
public:
|
|
public:
|
|
- virtual void applyOnPG(CSelectionScreen *selScr, void *pack) const =0;
|
|
|
|
|
|
+ virtual void applyOnPG(CSelectionScreen *selScr, void *pack) const =0;
|
|
virtual ~CBaseForPGApply(){};
|
|
virtual ~CBaseForPGApply(){};
|
|
template<typename U> static CBaseForPGApply *getApplier(const U * t=NULL)
|
|
template<typename U> static CBaseForPGApply *getApplier(const U * t=NULL)
|
|
{
|
|
{
|
|
@@ -211,100 +214,212 @@ public:
|
|
|
|
|
|
static CApplier<CBaseForPGApply> *applier = NULL;
|
|
static CApplier<CBaseForPGApply> *applier = NULL;
|
|
|
|
|
|
-CMenuScreen::CMenuScreen( EState which )
|
|
|
|
|
|
+static CPicture* createPicture(const JsonNode& config)
|
|
{
|
|
{
|
|
- OBJ_CONSTRUCTION;
|
|
|
|
- bgAd = NULL;
|
|
|
|
|
|
+ return new CPicture(config["name"].String(), config["x"].Float(), config["y"].Float());
|
|
|
|
+}
|
|
|
|
|
|
- switch(which)
|
|
|
|
|
|
+CMenuScreen::CMenuScreen(const JsonNode& configNode):
|
|
|
|
+ config(configNode)
|
|
|
|
+{
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
|
|
+
|
|
|
|
+ BOOST_FOREACH(const JsonNode& node, config["items"].Vector())
|
|
|
|
+ menuNameToEntry.push_back(node["name"].String());
|
|
|
|
+
|
|
|
|
+ BOOST_FOREACH(const JsonNode& node, config["images"].Vector())
|
|
|
|
+ images.push_back(createPicture(node));
|
|
|
|
+
|
|
|
|
+ //Hardcoded entry
|
|
|
|
+ menuNameToEntry.push_back("credits");
|
|
|
|
+
|
|
|
|
+ tabs = new CTabbedInt(boost::bind(&CMenuScreen::createTab, this, _1), CTabbedInt::DestroyFunc());
|
|
|
|
+ tabs->type |= REDRAW_PARENT;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+CIntObject * CMenuScreen::createTab(size_t index)
|
|
|
|
+{
|
|
|
|
+ if (config["items"].Vector().size() == index)
|
|
|
|
+ return new CreditsScreen();
|
|
|
|
+
|
|
|
|
+ return new CMenuEntry(this, config["items"].Vector()[index]);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void CMenuScreen::show(SDL_Surface * to)
|
|
|
|
+{
|
|
|
|
+ if (!config["video"].isNull())
|
|
|
|
+ CCS->videoh->update(config["video"]["x"].Float(), config["video"]["y"].Float(), to, true, false);
|
|
|
|
+ CIntObject::show(to);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void CMenuScreen::activate()
|
|
|
|
+{
|
|
|
|
+ CCS->musich->playMusic(musicBase::mainMenu, -1);
|
|
|
|
+ if (!config["video"].isNull())
|
|
|
|
+ CCS->videoh->open(config["video"]["name"].String());
|
|
|
|
+ CIntObject::activate();
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void CMenuScreen::deactivate()
|
|
|
|
+{
|
|
|
|
+ if (!config["video"].isNull())
|
|
|
|
+ CCS->videoh->close();
|
|
|
|
+
|
|
|
|
+ CIntObject::deactivate();
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void CMenuScreen::switchToTab(size_t index)
|
|
|
|
+{
|
|
|
|
+ tabs->setActive(index);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+//funciton for std::string -> boost::function conversion for main menu
|
|
|
|
+static boost::function<void()> genCommand(CMenuScreen* menu, std::vector<std::string> menuType, const std::string &string)
|
|
|
|
+{
|
|
|
|
+ static const std::vector<std::string> commandType = boost::assign::list_of
|
|
|
|
+ ("to")("campaigns")("start")("load")("exit")("highscores");
|
|
|
|
+
|
|
|
|
+ static const std::vector<std::string> gameType = boost::assign::list_of
|
|
|
|
+ ("single")("multi")("campaign")("tutorial");
|
|
|
|
+
|
|
|
|
+ std::list<std::string> commands;
|
|
|
|
+ boost::split(commands, string, boost::is_any_of("\t "));
|
|
|
|
+
|
|
|
|
+ if (!commands.empty())
|
|
{
|
|
{
|
|
- case mainMenu:
|
|
|
|
- {
|
|
|
|
- buttons[0] = new AdventureMapButton("", CGI->generaltexth->zelp[3].second, // New game
|
|
|
|
- bind(&CMenuScreen::moveTo, this, ref(CGP->scrs[newGame])), 540, 10, "ZMENUNG.DEF", SDLK_n);
|
|
|
|
- buttons[1] = new AdventureMapButton("", CGI->generaltexth->zelp[4].second, // Load game
|
|
|
|
- bind(&CMenuScreen::moveTo, this, ref(CGP->scrs[loadGame])), 532, 132, "ZMENULG.DEF", SDLK_l);
|
|
|
|
- buttons[2] = new AdventureMapButton("", CGI->generaltexth->zelp[5].second, 0, 524, 251, "ZMENUHS.DEF", SDLK_h); // Highscore
|
|
|
|
- buttons[3] = new AdventureMapButton("", CGI->generaltexth->zelp[6].second, 0 /*cb*/, 557, 359, "ZMENUCR.DEF", SDLK_c); // Credits
|
|
|
|
- boost::function<void()> confWindow = bind(CInfoWindow::showYesNoDialog, ref(CGI->generaltexth->allTexts[69]), (const std::vector<SComponent*>*)0, do_quit, 0, false, 1);
|
|
|
|
- buttons[4] = new AdventureMapButton("", CGI->generaltexth->zelp[7].second, confWindow, 586, 468, "ZMENUQT.DEF", SDLK_ESCAPE); // Exit
|
|
|
|
- }
|
|
|
|
- break;
|
|
|
|
- case newGame:
|
|
|
|
|
|
+ size_t index = std::find(commandType.begin(), commandType.end(), commands.front()) - commandType.begin();
|
|
|
|
+ commands.pop_front();
|
|
|
|
+ if (index > 3 || !commands.empty())
|
|
{
|
|
{
|
|
- bgAd = new CPicture(BitmapHandler::loadBitmap("ZNEWGAM.bmp"), 114, 312, true);
|
|
|
|
- buttons[0] = new AdventureMapButton("", CGI->generaltexth->zelp[10].second, // Single player
|
|
|
|
- bind(&CGPreGame::openSel, CGP, newGame, SINGLE_PLAYER), 545, 4, "ZTSINGL.DEF", SDLK_s);
|
|
|
|
- buttons[1] = new AdventureMapButton("", CGI->generaltexth->zelp[12].second, &pushIntT<CMultiMode>, 568, 120, "ZTMULTI.DEF", SDLK_m);
|
|
|
|
- buttons[2] = new AdventureMapButton("", CGI->generaltexth->zelp[11].second, bind(&CMenuScreen::moveTo, this, ref(CGP->scrs[campaignMain])), 541, 233, "ZTCAMPN.DEF", SDLK_c);
|
|
|
|
- buttons[3] = new AdventureMapButton("", CGI->generaltexth->zelp[13].second, 0 /*cb*/, 545, 358, "ZTTUTOR.DEF", SDLK_t);
|
|
|
|
- buttons[4] = new AdventureMapButton("", CGI->generaltexth->zelp[14].second, bind(&CMenuScreen::moveTo, this, CGP->scrs[mainMenu]), 582, 464, "ZTBACK.DEF", SDLK_ESCAPE);
|
|
|
|
- }
|
|
|
|
- break;
|
|
|
|
- case loadGame:
|
|
|
|
- {
|
|
|
|
- bgAd = new CPicture(BitmapHandler::loadBitmap("ZLOADGAM.bmp"), 114, 312, true);
|
|
|
|
- buttons[0] = new AdventureMapButton("", CGI->generaltexth->zelp[10].second, bind(&CGPreGame::openSel, CGP, loadGame, SINGLE_PLAYER), 545, 4, "ZTSINGL.DEF", SDLK_s);
|
|
|
|
- buttons[1] = new AdventureMapButton("", CGI->generaltexth->zelp[12].second, bind(&CGPreGame::openSel, CGP, loadGame, MULTI_HOT_SEAT), 568, 120, "ZTMULTI.DEF", SDLK_m);
|
|
|
|
- buttons[2] = new AdventureMapButton("", CGI->generaltexth->zelp[11].second, 0 /*cb*/, 541, 233, "ZTCAMPN.DEF", SDLK_c);
|
|
|
|
- buttons[3] = new AdventureMapButton("", CGI->generaltexth->zelp[13].second, 0 /*cb*/, 545, 358, "ZTTUTOR.DEF", SDLK_t);
|
|
|
|
- buttons[4] = new AdventureMapButton("", CGI->generaltexth->zelp[14].second, bind(&CMenuScreen::moveTo, this, CGP->scrs[mainMenu]), 582, 464, "ZTBACK.DEF", SDLK_ESCAPE);
|
|
|
|
- }
|
|
|
|
- break;
|
|
|
|
- case campaignMain:
|
|
|
|
- {
|
|
|
|
- buttons[0] = new AdventureMapButton("", "", bind(&CGPreGame::openCampaignScreen, CGP, CCampaignScreen::WOG), 535, 8, "ZSSSOD.DEF", SDLK_s); // WOG
|
|
|
|
- buttons[1] = new AdventureMapButton("", "", bind(&CGPreGame::openCampaignScreen, CGP, CCampaignScreen::ROE) , 494, 117, "ZSSROE.DEF", SDLK_m); // ROE
|
|
|
|
- buttons[2] = new AdventureMapButton("", "", bind(&CGPreGame::openCampaignScreen, CGP, CCampaignScreen::AB), 486, 241, "ZSSARM.DEF", SDLK_c); // AB
|
|
|
|
- buttons[3] = new AdventureMapButton("", "", bind(&CGPreGame::openSel, CGP, campaignList, SINGLE_PLAYER), 550, 358, "ZSSCUS.DEF", SDLK_t); // Custom
|
|
|
|
- buttons[4] = new AdventureMapButton("", "", bind(&CMenuScreen::moveTo, this, CGP->scrs[newGame]), 582, 464, "ZTBACK.DEF", SDLK_ESCAPE); // Back
|
|
|
|
-
|
|
|
|
|
|
+ switch (index)
|
|
|
|
+ {
|
|
|
|
+ break; case 0://to - switch to another tab, if such tab exists
|
|
|
|
+ {
|
|
|
|
+ size_t index2 = std::find(menuType.begin(), menuType.end(), commands.front()) - menuType.begin();
|
|
|
|
+ if ( index2 != menuType.size())
|
|
|
|
+ return boost::bind(&CMenuScreen::switchToTab, menu, index2);
|
|
|
|
+ }
|
|
|
|
+ break; case 1://open campaign selection window
|
|
|
|
+ {
|
|
|
|
+ return boost::bind(&CGPreGame::openCampaignScreen, CGP, commands.front());
|
|
|
|
+ }
|
|
|
|
+ break; case 2://start
|
|
|
|
+ {
|
|
|
|
+ switch (std::find(gameType.begin(), gameType.end(), commands.front()) - gameType.begin())
|
|
|
|
+ {
|
|
|
|
+ case 0: return bind(&CGPreGame::openSel, CGP, CMenuScreen::newGame, CMenuScreen::SINGLE_PLAYER);
|
|
|
|
+ case 1: return &pushIntT<CMultiMode>;
|
|
|
|
+ case 2: return boost::bind(&CGPreGame::openSel, CGP, CMenuScreen::campaignList, CMenuScreen::SINGLE_PLAYER);
|
|
|
|
+ case 3: return boost::function<void()>();//TODO: start tutorial
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ break; case 3://load
|
|
|
|
+ {
|
|
|
|
+ switch (std::find(gameType.begin(), gameType.end(), commands.front()) - gameType.begin())
|
|
|
|
+ {
|
|
|
|
+ case 0: return boost::bind(&CGPreGame::openSel, CGP, CMenuScreen::loadGame, CMenuScreen::SINGLE_PLAYER);
|
|
|
|
+ case 1: return boost::bind(&CGPreGame::openSel, CGP, CMenuScreen::loadGame, CMenuScreen::MULTI_HOT_SEAT);
|
|
|
|
+ case 2: return boost::function<void()>();//TODO: load campaign
|
|
|
|
+ case 3: return boost::function<void()>();//TODO: load tutorial
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ break; case 4://exit
|
|
|
|
+ {
|
|
|
|
+ return boost::bind(CInfoWindow::showYesNoDialog, boost::ref(CGI->generaltexth->allTexts[69]), (const std::vector<SComponent*>*)0, do_quit, 0, false, 1);
|
|
|
|
+ }
|
|
|
|
+ break; case 5://highscores
|
|
|
|
+ {
|
|
|
|
+ return boost::function<void()>(); //TODO: high scores &pushIntT<CHighScores>;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
}
|
|
}
|
|
- break;
|
|
|
|
}
|
|
}
|
|
|
|
+ tlog0<<"Failed to parse command: "<<string<<"\n";
|
|
|
|
+ return boost::function<void()>();
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+AdventureMapButton* CMenuEntry::createButton(CMenuScreen* parent, const JsonNode& button)
|
|
|
|
+{
|
|
|
|
+ boost::function<void()> command = genCommand(parent, parent->menuNameToEntry, button["command"].String());
|
|
|
|
|
|
- for(int i = 0; i < ARRAY_COUNT(buttons); i++)
|
|
|
|
- buttons[i]->hoverable = true;
|
|
|
|
|
|
+ std::pair<std::string, std::string> help;
|
|
|
|
+ if (!button["help"].isNull() && button["help"].Float() > 0)
|
|
|
|
+ help = CGI->generaltexth->zelp[button["help"].Float()];
|
|
|
|
+
|
|
|
|
+ return new AdventureMapButton(help, command, button["x"].Float(), button["y"].Float(), button["name"].String(), button["hotkey"].Float());
|
|
}
|
|
}
|
|
|
|
|
|
-CMenuScreen::~CMenuScreen()
|
|
|
|
|
|
+CMenuEntry::CMenuEntry(CMenuScreen* parent, const JsonNode &config)
|
|
{
|
|
{
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
|
|
+ type |= REDRAW_PARENT;
|
|
|
|
+
|
|
|
|
+ BOOST_FOREACH(const JsonNode& node, config["images"].Vector())
|
|
|
|
+ images.push_back(createPicture(node));
|
|
|
|
+
|
|
|
|
+ BOOST_FOREACH(const JsonNode& node, config["buttons"].Vector())
|
|
|
|
+ {
|
|
|
|
+ buttons.push_back(createButton(parent, node));
|
|
|
|
+ buttons.back()->hoverable = true;
|
|
|
|
+ buttons.back()->type |= REDRAW_PARENT;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
-void CMenuScreen::showAll( SDL_Surface * to )
|
|
|
|
|
|
+CreditsScreen::CreditsScreen()
|
|
{
|
|
{
|
|
- blitAt(CGP->mainbg, 0, 0, to);
|
|
|
|
- CIntObject::showAll(to);
|
|
|
|
|
|
+ used |= LCLICK | RCLICK;
|
|
|
|
+ type |= REDRAW_PARENT;
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
|
|
+ pos.w = 800;
|
|
|
|
+ pos.h = 600;
|
|
|
|
+ std::string text = bitmaph->getTextFile("CREDITS");
|
|
|
|
+ size_t firstQuote = text.find('\"')+1;
|
|
|
|
+ text = text.substr(firstQuote, text.find('\"', firstQuote) - firstQuote );
|
|
|
|
+ credits = new CTextBox(text, Rect(450, 600, 350, 32000), 0, FONT_CREDITS, CENTER, zwykly);
|
|
|
|
+ credits->pos.h = credits->maxH;
|
|
}
|
|
}
|
|
|
|
|
|
-void CMenuScreen::show( SDL_Surface * to )
|
|
|
|
|
|
+void CreditsScreen::show(SDL_Surface *to)
|
|
{
|
|
{
|
|
- CCS->videoh->update(pos.x + 8, pos.y + 105, to, true, false);
|
|
|
|
- CIntObject::show(to);
|
|
|
|
|
|
+ static int count = 0;
|
|
|
|
+ count++;
|
|
|
|
+ if (count == 2)
|
|
|
|
+ {
|
|
|
|
+ credits->pos.y--;
|
|
|
|
+ count = 0;
|
|
|
|
+ }
|
|
|
|
+ SDL_SetClipRect(screen, &credits->pos);
|
|
|
|
+ redraw();
|
|
|
|
+ SDL_SetClipRect(screen, NULL);
|
|
|
|
+
|
|
|
|
+ //end of credits, close this screen
|
|
|
|
+ if (credits->pos.y + credits->pos.h < 0)
|
|
|
|
+ clickRight(false, false);
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void CreditsScreen::clickLeft(tribool down, bool previousState)
|
|
|
|
+{
|
|
|
|
+ clickRight(down, previousState);
|
|
}
|
|
}
|
|
|
|
|
|
-void CMenuScreen::moveTo( CMenuScreen *next )
|
|
|
|
|
|
+void CreditsScreen::clickRight(tribool down, bool previousState)
|
|
{
|
|
{
|
|
- GH.popInt(this);
|
|
|
|
- GH.pushInt(next);
|
|
|
|
|
|
+ CTabbedInt* menu = dynamic_cast<CTabbedInt*>(parent);
|
|
|
|
+ assert(menu);
|
|
|
|
+ menu->setActive(0);
|
|
}
|
|
}
|
|
|
|
|
|
-CGPreGame::CGPreGame()
|
|
|
|
|
|
+CGPreGame::CGPreGame():
|
|
|
|
+ pregameConfig(new JsonNode(DATA_DIR "/config/mainmenu.json"))
|
|
{
|
|
{
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
GH.defActionsDef = 63;
|
|
GH.defActionsDef = 63;
|
|
CGP = this;
|
|
CGP = this;
|
|
- mainbg = BitmapHandler::loadBitmap("ZPIC1005.bmp");
|
|
|
|
-
|
|
|
|
- for(int i = 0; i < ARRAY_COUNT(scrs); i++)
|
|
|
|
- scrs[i] = new CMenuScreen((CMenuScreen::EState)i);
|
|
|
|
|
|
+ menu = new CMenuScreen((*pregameConfig)["window"]);
|
|
}
|
|
}
|
|
|
|
|
|
CGPreGame::~CGPreGame()
|
|
CGPreGame::~CGPreGame()
|
|
{
|
|
{
|
|
- SDL_FreeSurface(mainbg);
|
|
|
|
-
|
|
|
|
- for(int i = 0; i < ARRAY_COUNT(scrs); i++)
|
|
|
|
- delete scrs[i];
|
|
|
|
}
|
|
}
|
|
|
|
|
|
void CGPreGame::openSel(CMenuScreen::EState screenType, CMenuScreen::EMultiMode multi /*= CMenuScreen::SINGLE_PLAYER*/)
|
|
void CGPreGame::openSel(CMenuScreen::EState screenType, CMenuScreen::EMultiMode multi /*= CMenuScreen::SINGLE_PLAYER*/)
|
|
@@ -312,12 +427,6 @@ void CGPreGame::openSel(CMenuScreen::EState screenType, CMenuScreen::EMultiMode
|
|
GH.pushInt(new CSelectionScreen(screenType, multi));
|
|
GH.pushInt(new CSelectionScreen(screenType, multi));
|
|
}
|
|
}
|
|
|
|
|
|
-void CGPreGame::openCampaignScreen(CCampaignScreen::CampaignSet campaigns)
|
|
|
|
-{
|
|
|
|
- std::map<std::string, CCampaignScreen::CampaignStatus> defaultCamp;
|
|
|
|
- GH.pushInt(new CCampaignScreen(campaigns, defaultCamp));
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
void CGPreGame::loadGraphics()
|
|
void CGPreGame::loadGraphics()
|
|
{
|
|
{
|
|
victory = CDefHandler::giveDef("SCNRVICT.DEF");
|
|
victory = CDefHandler::giveDef("SCNRVICT.DEF");
|
|
@@ -341,11 +450,10 @@ void CGPreGame::disposeGraphics()
|
|
|
|
|
|
void CGPreGame::update()
|
|
void CGPreGame::update()
|
|
{
|
|
{
|
|
- if (GH.listInt.size() == 0)
|
|
|
|
|
|
+ if (GH.listInt.empty())
|
|
{
|
|
{
|
|
- CCS->musich->playMusic(musicBase::mainMenu, -1);
|
|
|
|
- CCS->videoh->open("ACREDIT.SMK");
|
|
|
|
- GH.pushInt(scrs[CMenuScreen::mainMenu]);
|
|
|
|
|
|
+ GH.pushInt(menu);
|
|
|
|
+ menu->switchToTab(0);
|
|
}
|
|
}
|
|
|
|
|
|
if(SEL)
|
|
if(SEL)
|
|
@@ -355,7 +463,7 @@ void CGPreGame::update()
|
|
GH.updateTime();
|
|
GH.updateTime();
|
|
GH.handleEvents();
|
|
GH.handleEvents();
|
|
|
|
|
|
- if (GH.curInt == 0) // no redraw, when a new game was created
|
|
|
|
|
|
+ if (GH.curInt == NULL) // no redraw, when a new game was created
|
|
return;
|
|
return;
|
|
|
|
|
|
GH.topInt()->show(screen);
|
|
GH.topInt()->show(screen);
|
|
@@ -369,6 +477,19 @@ void CGPreGame::update()
|
|
CCS->curh->draw2();
|
|
CCS->curh->draw2();
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+void CGPreGame::openCampaignScreen(std::string name)
|
|
|
|
+{
|
|
|
|
+ BOOST_FOREACH(const JsonNode& node, (*pregameConfig)["campaignsset"].Vector())
|
|
|
|
+ {
|
|
|
|
+ if (node["name"].String() == name)
|
|
|
|
+ {
|
|
|
|
+ GH.pushInt(new CCampaignScreen(node));
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ tlog1<<"Unknown campaign set: "<<name<<"\n";
|
|
|
|
+}
|
|
|
|
+
|
|
CSelectionScreen::CSelectionScreen(CMenuScreen::EState Type, CMenuScreen::EMultiMode MultiPlayer /*= CMenuScreen::SINGLE_PLAYER*/, const std::map<ui32, std::string> *Names /*= NULL*/)
|
|
CSelectionScreen::CSelectionScreen(CMenuScreen::EState Type, CMenuScreen::EMultiMode MultiPlayer /*= CMenuScreen::SINGLE_PLAYER*/, const std::map<ui32, std::string> *Names /*= NULL*/)
|
|
: ISelectionScreenInfo(Names), serverHandlingThread(NULL), mx(new boost::recursive_mutex),
|
|
: ISelectionScreenInfo(Names), serverHandlingThread(NULL), mx(new boost::recursive_mutex),
|
|
serv(NULL), ongoingClosing(false), myNameID(255)
|
|
serv(NULL), ongoingClosing(false), myNameID(255)
|
|
@@ -420,7 +541,7 @@ CSelectionScreen::CSelectionScreen(CMenuScreen::EState Type, CMenuScreen::EMulti
|
|
if (screenType == CMenuScreen::campaignList)
|
|
if (screenType == CMenuScreen::campaignList)
|
|
{
|
|
{
|
|
opt = NULL;
|
|
opt = NULL;
|
|
- }
|
|
|
|
|
|
+ }
|
|
else
|
|
else
|
|
{
|
|
{
|
|
opt = new OptionsTab(); //scenario options tab
|
|
opt = new OptionsTab(); //scenario options tab
|
|
@@ -476,7 +597,7 @@ CSelectionScreen::CSelectionScreen(CMenuScreen::EState Type, CMenuScreen::EMulti
|
|
start = new AdventureMapButton(std::pair<std::string, std::string>(), bind(&CSelectionScreen::startCampaign, this), 411, 529, "SCNRLOD.DEF", SDLK_b);
|
|
start = new AdventureMapButton(std::pair<std::string, std::string>(), bind(&CSelectionScreen::startCampaign, this), 411, 529, "SCNRLOD.DEF", SDLK_b);
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
|
|
|
|
start->assignedKeys.insert(SDLK_RETURN);
|
|
start->assignedKeys.insert(SDLK_RETURN);
|
|
|
|
|
|
@@ -697,7 +818,7 @@ void CSelectionScreen::difficultyChange( int to )
|
|
assert(screenType == CMenuScreen::newGame);
|
|
assert(screenType == CMenuScreen::newGame);
|
|
sInfo.difficulty = to;
|
|
sInfo.difficulty = to;
|
|
propagateOptions();
|
|
propagateOptions();
|
|
- GH.totalRedraw();
|
|
|
|
|
|
+ redraw();
|
|
}
|
|
}
|
|
|
|
|
|
void CSelectionScreen::handleConnection()
|
|
void CSelectionScreen::handleConnection()
|
|
@@ -818,12 +939,12 @@ void SelectionTab::filter( int size, bool selectFirst )
|
|
|
|
|
|
if(tabType == CMenuScreen::campaignList)
|
|
if(tabType == CMenuScreen::campaignList)
|
|
{
|
|
{
|
|
- for (size_t i=0; i<allItems.size(); i++)
|
|
|
|
|
|
+ for (size_t i=0; i<allItems.size(); i++)
|
|
curItems.push_back(&allItems[i]);
|
|
curItems.push_back(&allItems[i]);
|
|
}
|
|
}
|
|
else
|
|
else
|
|
{
|
|
{
|
|
- for (size_t i=0; i<allItems.size(); i++)
|
|
|
|
|
|
+ for (size_t i=0; i<allItems.size(); i++)
|
|
if( allItems[i].mapHeader && allItems[i].mapHeader->version && (!size || allItems[i].mapHeader->width == size))
|
|
if( allItems[i].mapHeader && allItems[i].mapHeader->version && (!size || allItems[i].mapHeader->width == size))
|
|
curItems.push_back(&allItems[i]);
|
|
curItems.push_back(&allItems[i]);
|
|
}
|
|
}
|
|
@@ -866,7 +987,7 @@ void SelectionTab::parseMaps(std::vector<FileInfo> &files, int start, int thread
|
|
gzclose(tempf);
|
|
gzclose(tempf);
|
|
if(read < 50 || !mapBuffer[4])
|
|
if(read < 50 || !mapBuffer[4])
|
|
{
|
|
{
|
|
- tlog3 << "\t\tWarning: corrupted map file: " << files[start].name << std::endl;
|
|
|
|
|
|
+ tlog3 << "\t\tWarning: corrupted map file: " << files[start].name << std::endl;
|
|
}
|
|
}
|
|
else //valid map
|
|
else //valid map
|
|
{
|
|
{
|
|
@@ -885,7 +1006,7 @@ void SelectionTab::parseGames(std::vector<FileInfo> &files, bool multi)
|
|
if(!lf.sfile)
|
|
if(!lf.sfile)
|
|
continue;
|
|
continue;
|
|
|
|
|
|
- ui8 sign[8];
|
|
|
|
|
|
+ ui8 sign[8];
|
|
lf >> sign;
|
|
lf >> sign;
|
|
if(std::memcmp(sign,"VCMISVG",7))
|
|
if(std::memcmp(sign,"VCMISVG",7))
|
|
{
|
|
{
|
|
@@ -977,7 +1098,7 @@ SelectionTab::SelectionTab(CMenuScreen::EState Type, const boost::function<void(
|
|
else
|
|
else
|
|
{
|
|
{
|
|
positions = 16;
|
|
positions = 16;
|
|
- }
|
|
|
|
|
|
+ }
|
|
if(tabType == CMenuScreen::saveGame)
|
|
if(tabType == CMenuScreen::saveGame)
|
|
txt = new CTextInput(Rect(32, 539, 350, 20), Point(-32, -25), "GSSTRIP.bmp", 0);
|
|
txt = new CTextInput(Rect(32, 539, 350, 20), Point(-32, -25), "GSSTRIP.bmp", 0);
|
|
break;
|
|
break;
|
|
@@ -1011,7 +1132,7 @@ SelectionTab::SelectionTab(CMenuScreen::EState Type, const boost::function<void(
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
-
|
|
|
|
|
|
+
|
|
if (tabType != CMenuScreen::campaignList)
|
|
if (tabType != CMenuScreen::campaignList)
|
|
{
|
|
{
|
|
//size filter buttons
|
|
//size filter buttons
|
|
@@ -1161,7 +1282,7 @@ void SelectionTab::printMaps(SDL_Surface *to)
|
|
|
|
|
|
if (elemIdx == selectionPos)
|
|
if (elemIdx == selectionPos)
|
|
itemColor=tytulowy;
|
|
itemColor=tytulowy;
|
|
- else
|
|
|
|
|
|
+ else
|
|
itemColor=zwykly;
|
|
itemColor=zwykly;
|
|
|
|
|
|
if(tabType != CMenuScreen::campaignList)
|
|
if(tabType != CMenuScreen::campaignList)
|
|
@@ -1215,14 +1336,14 @@ void SelectionTab::printMaps(SDL_Surface *to)
|
|
//victory conditions
|
|
//victory conditions
|
|
if (currentItem->mapHeader->victoryCondition.condition == winStandard)
|
|
if (currentItem->mapHeader->victoryCondition.condition == winStandard)
|
|
temp = 11;
|
|
temp = 11;
|
|
- else
|
|
|
|
|
|
+ else
|
|
temp = currentItem->mapHeader->victoryCondition.condition;
|
|
temp = currentItem->mapHeader->victoryCondition.condition;
|
|
blitAt(CGP->victory->ourImages[temp].bitmap, POS(306, 117), to);
|
|
blitAt(CGP->victory->ourImages[temp].bitmap, POS(306, 117), to);
|
|
|
|
|
|
//loss conditions
|
|
//loss conditions
|
|
if (currentItem->mapHeader->lossCondition.typeOfLossCon == lossStandard)
|
|
if (currentItem->mapHeader->lossCondition.typeOfLossCon == lossStandard)
|
|
temp=3;
|
|
temp=3;
|
|
- else
|
|
|
|
|
|
+ else
|
|
temp=currentItem->mapHeader->lossCondition.typeOfLossCon;
|
|
temp=currentItem->mapHeader->lossCondition.typeOfLossCon;
|
|
blitAt(CGP->loss->ourImages[temp].bitmap, POS(339, 117), to);
|
|
blitAt(CGP->loss->ourImages[temp].bitmap, POS(339, 117), to);
|
|
}
|
|
}
|
|
@@ -1252,7 +1373,7 @@ void SelectionTab::printMaps(SDL_Surface *to)
|
|
|
|
|
|
//print name
|
|
//print name
|
|
CSDL_Ext::printAtMiddle(name, POS(213, 128), FONT_SMALL, itemColor, to);
|
|
CSDL_Ext::printAtMiddle(name, POS(213, 128), FONT_SMALL, itemColor, to);
|
|
-
|
|
|
|
|
|
+
|
|
}
|
|
}
|
|
#undef POS
|
|
#undef POS
|
|
}
|
|
}
|
|
@@ -1311,7 +1432,7 @@ void SelectionTab::keyPressed( const SDL_KeyboardEvent & key )
|
|
moveBy = -positions+1;
|
|
moveBy = -positions+1;
|
|
break;
|
|
break;
|
|
case SDLK_PAGEDOWN:
|
|
case SDLK_PAGEDOWN:
|
|
- moveBy = +positions-1;
|
|
|
|
|
|
+ moveBy = +positions-1;
|
|
break;
|
|
break;
|
|
case SDLK_HOME:
|
|
case SDLK_HOME:
|
|
select(-slider->value);
|
|
select(-slider->value);
|
|
@@ -1322,7 +1443,7 @@ void SelectionTab::keyPressed( const SDL_KeyboardEvent & key )
|
|
default:
|
|
default:
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
- select(selectionPos - slider->value + moveBy);
|
|
|
|
|
|
+ select(selectionPos - slider->value + moveBy);
|
|
}
|
|
}
|
|
|
|
|
|
void SelectionTab::onDoubleClick()
|
|
void SelectionTab::onDoubleClick()
|
|
@@ -1403,7 +1524,7 @@ InfoCard::InfoCard( bool Network )
|
|
: bg(NULL), network(Network), chatOn(false), chat(NULL), playerListBg(NULL),
|
|
: bg(NULL), network(Network), chatOn(false), chat(NULL), playerListBg(NULL),
|
|
difficulty(NULL), sizes(NULL), sFlags(NULL)
|
|
difficulty(NULL), sizes(NULL), sFlags(NULL)
|
|
{
|
|
{
|
|
- OBJ_CONSTRUCTION;
|
|
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
pos.x += 393;
|
|
pos.x += 393;
|
|
used = RCLICK;
|
|
used = RCLICK;
|
|
mapDescription = NULL;
|
|
mapDescription = NULL;
|
|
@@ -1419,7 +1540,9 @@ InfoCard::InfoCard( bool Network )
|
|
else
|
|
else
|
|
{
|
|
{
|
|
bg = new CPicture(BitmapHandler::loadBitmap("GSELPOP1.bmp"), 0, 0, true);
|
|
bg = new CPicture(BitmapHandler::loadBitmap("GSELPOP1.bmp"), 0, 0, true);
|
|
- std::swap(children.front(), children.back());
|
|
|
|
|
|
+ moveChild(bg, this, parent);
|
|
|
|
+ parent->children.insert(parent->children.begin()+1, bg);
|
|
|
|
+ parent->children.pop_back();
|
|
pos.w = bg->pos.w;
|
|
pos.w = bg->pos.w;
|
|
pos.h = bg->pos.h;
|
|
pos.h = bg->pos.h;
|
|
sizes = CDefHandler::giveDef("SCNRMPSZ.DEF");
|
|
sizes = CDefHandler::giveDef("SCNRMPSZ.DEF");
|
|
@@ -1504,19 +1627,6 @@ void InfoCard::showAll( SDL_Surface * to )
|
|
{
|
|
{
|
|
if(SEL->screenType != CMenuScreen::campaignList)
|
|
if(SEL->screenType != CMenuScreen::campaignList)
|
|
{
|
|
{
|
|
- if(SEL->screenType != CMenuScreen::newGame)
|
|
|
|
- {
|
|
|
|
- for (int i = 0; i < difficulty->buttons.size(); i++)
|
|
|
|
- {
|
|
|
|
- //if(i == SEL->current->difficulty)
|
|
|
|
- // difficulty->buttons[i]->state = 3;
|
|
|
|
- //else
|
|
|
|
- // difficulty->buttons[i]->state = 2;
|
|
|
|
-
|
|
|
|
- difficulty->buttons[i]->showAll(to);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
int temp = -1;
|
|
int temp = -1;
|
|
|
|
|
|
if(!chatOn)
|
|
if(!chatOn)
|
|
@@ -1540,7 +1650,7 @@ void InfoCard::showAll( SDL_Surface * to )
|
|
|
|
|
|
temp=SEL->current->mapHeader->lossCondition.typeOfLossCon;
|
|
temp=SEL->current->mapHeader->lossCondition.typeOfLossCon;
|
|
if (temp>12) temp=3;
|
|
if (temp>12) temp=3;
|
|
- blitAtLoc(CGP->loss->ourImages[temp].bitmap, 24, 359, to); //loss cond
|
|
|
|
|
|
+ blitAtLoc(CGP->loss->ourImages[temp].bitmap, 24, 359, to); //loss cond
|
|
}
|
|
}
|
|
|
|
|
|
//difficulty
|
|
//difficulty
|
|
@@ -1576,12 +1686,12 @@ void InfoCard::showAll( SDL_Surface * to )
|
|
//print flags
|
|
//print flags
|
|
int fx = 34 + graphics->fonts[FONT_SMALL]->getWidth(CGI->generaltexth->allTexts[390].c_str());
|
|
int fx = 34 + graphics->fonts[FONT_SMALL]->getWidth(CGI->generaltexth->allTexts[390].c_str());
|
|
int ex = 200 + graphics->fonts[FONT_SMALL]->getWidth(CGI->generaltexth->allTexts[391].c_str());
|
|
int ex = 200 + graphics->fonts[FONT_SMALL]->getWidth(CGI->generaltexth->allTexts[391].c_str());
|
|
-
|
|
|
|
|
|
+
|
|
int myT;
|
|
int myT;
|
|
|
|
|
|
if(playerColor >= 0)
|
|
if(playerColor >= 0)
|
|
myT = SEL->current->mapHeader->players[playerColor].team;
|
|
myT = SEL->current->mapHeader->players[playerColor].team;
|
|
- else
|
|
|
|
|
|
+ else
|
|
myT = -1;
|
|
myT = -1;
|
|
|
|
|
|
for (std::map<int, PlayerSettings>::const_iterator i = SEL->sInfo.playerInfos.begin(); i != SEL->sInfo.playerInfos.end(); i++)
|
|
for (std::map<int, PlayerSettings>::const_iterator i = SEL->sInfo.playerInfos.begin(); i != SEL->sInfo.playerInfos.end(); i++)
|
|
@@ -1619,7 +1729,7 @@ void InfoCard::showAll( SDL_Surface * to )
|
|
if (SEL->screenType == CMenuScreen::campaignList)
|
|
if (SEL->screenType == CMenuScreen::campaignList)
|
|
{
|
|
{
|
|
name = SEL->current->campaignHeader->name;
|
|
name = SEL->current->campaignHeader->name;
|
|
- }
|
|
|
|
|
|
+ }
|
|
else
|
|
else
|
|
{
|
|
{
|
|
name = SEL->current->mapHeader->name;
|
|
name = SEL->current->mapHeader->name;
|
|
@@ -1628,10 +1738,10 @@ void InfoCard::showAll( SDL_Surface * to )
|
|
//name
|
|
//name
|
|
if (name.length())
|
|
if (name.length())
|
|
printAtLoc(name, 26, 39, FONT_BIG, tytulowy, to);
|
|
printAtLoc(name, 26, 39, FONT_BIG, tytulowy, to);
|
|
- else
|
|
|
|
|
|
+ else
|
|
printAtLoc("Unnamed", 26, 39, FONT_BIG, tytulowy, to);
|
|
printAtLoc("Unnamed", 26, 39, FONT_BIG, tytulowy, to);
|
|
|
|
|
|
-
|
|
|
|
|
|
+
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
@@ -1681,7 +1791,7 @@ void InfoCard::showTeamsPopup()
|
|
{
|
|
{
|
|
blitAt(sFlags->ourImages[flags[j]].bitmap, curx, 75 + 50*i, bmp);
|
|
blitAt(sFlags->ourImages[flags[j]].bitmap, curx, 75 + 50*i, bmp);
|
|
curx += 18;
|
|
curx += 18;
|
|
- }
|
|
|
|
|
|
+ }
|
|
}
|
|
}
|
|
|
|
|
|
GH.pushInt(new CInfoPopup(bmp, true));
|
|
GH.pushInt(new CInfoPopup(bmp, true));
|
|
@@ -1917,7 +2027,7 @@ void OptionsTab::recreate()
|
|
usedHeroes.clear();
|
|
usedHeroes.clear();
|
|
|
|
|
|
OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
- for(std::map<int, PlayerSettings>::iterator it = SEL->sInfo.playerInfos.begin();
|
|
|
|
|
|
+ for(std::map<int, PlayerSettings>::iterator it = SEL->sInfo.playerInfos.begin();
|
|
it != SEL->sInfo.playerInfos.end(); ++it)
|
|
it != SEL->sInfo.playerInfos.end(); ++it)
|
|
{
|
|
{
|
|
entries.insert(std::make_pair(it->first, new PlayerOptionsEntry(this, it->second)));
|
|
entries.insert(std::make_pair(it->first, new PlayerOptionsEntry(this, it->second)));
|
|
@@ -2032,9 +2142,9 @@ OptionsTab::PlayerOptionsEntry::PlayerOptionsEntry( OptionsTab *owner, PlayerSet
|
|
|
|
|
|
pos = parent->pos + Point(54, 122 + serial*50);
|
|
pos = parent->pos + Point(54, 122 + serial*50);
|
|
|
|
|
|
- static const char *flags[] = {"AOFLGBR.DEF", "AOFLGBB.DEF", "AOFLGBY.DEF", "AOFLGBG.DEF",
|
|
|
|
|
|
+ static const char *flags[] = {"AOFLGBR.DEF", "AOFLGBB.DEF", "AOFLGBY.DEF", "AOFLGBG.DEF",
|
|
"AOFLGBO.DEF", "AOFLGBP.DEF", "AOFLGBT.DEF", "AOFLGBS.DEF"};
|
|
"AOFLGBO.DEF", "AOFLGBP.DEF", "AOFLGBT.DEF", "AOFLGBS.DEF"};
|
|
- static const char *bgs[] = {"ADOPRPNL.bmp", "ADOPBPNL.bmp", "ADOPYPNL.bmp", "ADOPGPNL.bmp",
|
|
|
|
|
|
+ static const char *bgs[] = {"ADOPRPNL.bmp", "ADOPBPNL.bmp", "ADOPYPNL.bmp", "ADOPGPNL.bmp",
|
|
"ADOPOPNL.bmp", "ADOPPPNL.bmp", "ADOPTPNL.bmp", "ADOPSPNL.bmp"};
|
|
"ADOPOPNL.bmp", "ADOPPPNL.bmp", "ADOPTPNL.bmp", "ADOPSPNL.bmp"};
|
|
|
|
|
|
bg = new CPicture(BitmapHandler::loadBitmap(bgs[s.color]), 0, 0, true);
|
|
bg = new CPicture(BitmapHandler::loadBitmap(bgs[s.color]), 0, 0, true);
|
|
@@ -2063,7 +2173,7 @@ OptionsTab::PlayerOptionsEntry::PlayerOptionsEntry( OptionsTab *owner, PlayerSet
|
|
else
|
|
else
|
|
whoCanPlay = HUMAN;
|
|
whoCanPlay = HUMAN;
|
|
|
|
|
|
- if(SEL->screenType != CMenuScreen::scenarioInfo
|
|
|
|
|
|
+ if(SEL->screenType != CMenuScreen::scenarioInfo
|
|
&& SEL->current->mapHeader->players[s.color].canHumanPlay
|
|
&& SEL->current->mapHeader->players[s.color].canHumanPlay
|
|
&& SEL->multiPlayer != CMenuScreen::MULTI_NETWORK_GUEST)
|
|
&& SEL->multiPlayer != CMenuScreen::MULTI_NETWORK_GUEST)
|
|
{
|
|
{
|
|
@@ -2194,7 +2304,7 @@ SDL_Surface * OptionsTab::SelectedBox::getImg() const
|
|
case 2:
|
|
case 2:
|
|
pom=CGI->townh->towns[s.castle].bonus;
|
|
pom=CGI->townh->towns[s.castle].bonus;
|
|
break;
|
|
break;
|
|
- default:
|
|
|
|
|
|
+ default:
|
|
assert(0);
|
|
assert(0);
|
|
}
|
|
}
|
|
return CGP->bonuses->ourImages[pom].bitmap;
|
|
return CGP->bonuses->ourImages[pom].bitmap;
|
|
@@ -2206,7 +2316,7 @@ SDL_Surface * OptionsTab::SelectedBox::getImg() const
|
|
|
|
|
|
const std::string * OptionsTab::SelectedBox::getText() const
|
|
const std::string * OptionsTab::SelectedBox::getText() const
|
|
{
|
|
{
|
|
- const PlayerSettings &s = SEL->sInfo.playerInfos[player];
|
|
|
|
|
|
+ const PlayerSettings &s = SEL->sInfo.playerInfos[player];
|
|
switch(which)
|
|
switch(which)
|
|
{
|
|
{
|
|
case TOWN:
|
|
case TOWN:
|
|
@@ -2263,11 +2373,11 @@ void OptionsTab::SelectedBox::clickRight( tribool down, bool previousState )
|
|
int val=-1;
|
|
int val=-1;
|
|
switch(which)
|
|
switch(which)
|
|
{
|
|
{
|
|
- case TOWN:
|
|
|
|
- val = s.castle;
|
|
|
|
|
|
+ case TOWN:
|
|
|
|
+ val = s.castle;
|
|
break;
|
|
break;
|
|
- case HERO:
|
|
|
|
- val = s.hero;
|
|
|
|
|
|
+ case HERO:
|
|
|
|
+ val = s.hero;
|
|
if(val == -2) //none => we may have some preset info
|
|
if(val == -2) //none => we may have some preset info
|
|
{
|
|
{
|
|
int p9 = SEL->current->mapHeader->players[s.color].p9;
|
|
int p9 = SEL->current->mapHeader->players[s.color].p9;
|
|
@@ -2275,8 +2385,8 @@ void OptionsTab::SelectedBox::clickRight( tribool down, bool previousState )
|
|
val = p9;
|
|
val = p9;
|
|
}
|
|
}
|
|
break;
|
|
break;
|
|
- case BONUS:
|
|
|
|
- val = s.bonus;
|
|
|
|
|
|
+ case BONUS:
|
|
|
|
+ val = s.bonus;
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
|
|
|
|
@@ -2358,7 +2468,7 @@ void OptionsTab::SelectedBox::clickRight( tribool down, bool previousState )
|
|
title = &CGI->generaltexth->allTexts[80];
|
|
title = &CGI->generaltexth->allTexts[80];
|
|
|
|
|
|
CSDL_Ext::printAtMiddle(CGI->generaltexth->allTexts[79], 135, 137, FONT_MEDIUM, tytulowy, bmp);
|
|
CSDL_Ext::printAtMiddle(CGI->generaltexth->allTexts[79], 135, 137, FONT_MEDIUM, tytulowy, bmp);
|
|
-
|
|
|
|
|
|
+
|
|
const CTown &t = CGI->townh->towns[val];
|
|
const CTown &t = CGI->townh->towns[val];
|
|
//print creatures
|
|
//print creatures
|
|
int x = 60, y = 159;
|
|
int x = 60, y = 159;
|
|
@@ -2414,7 +2524,7 @@ CScenarioInfo::CScenarioInfo(const CMapHeader *mapHeader, const StartInfo *start
|
|
{
|
|
{
|
|
OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
|
|
|
|
- for(std::map<int, PlayerSettings>::const_iterator it = startInfo->playerInfos.begin();
|
|
|
|
|
|
+ for(std::map<int, PlayerSettings>::const_iterator it = startInfo->playerInfos.begin();
|
|
it != startInfo->playerInfos.end(); ++it)
|
|
it != startInfo->playerInfos.end(); ++it)
|
|
{
|
|
{
|
|
if(it->second.human)
|
|
if(it->second.human)
|
|
@@ -2496,7 +2606,7 @@ bool mapSorter::operator()(const CMapInfo *aaa, const CMapInfo *bbb)
|
|
switch(sortBy)
|
|
switch(sortBy)
|
|
{
|
|
{
|
|
case _numOfMaps: //by number of maps in campaign
|
|
case _numOfMaps: //by number of maps in campaign
|
|
- return CGI->generaltexth->campaignRegionNames[ aaa->campaignHeader->mapVersion ].size() <
|
|
|
|
|
|
+ return CGI->generaltexth->campaignRegionNames[ aaa->campaignHeader->mapVersion ].size() <
|
|
CGI->generaltexth->campaignRegionNames[ bbb->campaignHeader->mapVersion ].size();
|
|
CGI->generaltexth->campaignRegionNames[ bbb->campaignHeader->mapVersion ].size();
|
|
break;
|
|
break;
|
|
case _name: //by name
|
|
case _name: //by name
|
|
@@ -2511,7 +2621,7 @@ bool mapSorter::operator()(const CMapInfo *aaa, const CMapInfo *bbb)
|
|
|
|
|
|
CMultiMode::CMultiMode()
|
|
CMultiMode::CMultiMode()
|
|
{
|
|
{
|
|
- OBJ_CONSTRUCTION;
|
|
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
bg = new CPicture("MUPOPUP.bmp");
|
|
bg = new CPicture("MUPOPUP.bmp");
|
|
bg->convertToScreenBPP(); //so we could draw without problems
|
|
bg->convertToScreenBPP(); //so we could draw without problems
|
|
blitAt(CPicture("MUMAP.bmp"), 16, 77, *bg); //blit img
|
|
blitAt(CPicture("MUMAP.bmp"), 16, 77, *bg); //blit img
|
|
@@ -2548,7 +2658,7 @@ void CMultiMode::joinTCP()
|
|
|
|
|
|
CHotSeatPlayers::CHotSeatPlayers(const std::string &firstPlayer)
|
|
CHotSeatPlayers::CHotSeatPlayers(const std::string &firstPlayer)
|
|
{
|
|
{
|
|
- OBJ_CONSTRUCTION;
|
|
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
bg = new CPicture("MUHOTSEA.bmp");
|
|
bg = new CPicture("MUHOTSEA.bmp");
|
|
bg->convertToScreenBPP(); //so we could draw without problems
|
|
bg->convertToScreenBPP(); //so we could draw without problems
|
|
bg->printAtMiddleWBLoc(CGI->generaltexth->allTexts[446], 185, 55, FONT_BIG, 50, zwykly, *bg); //HOTSEAT Please enter names
|
|
bg->printAtMiddleWBLoc(CGI->generaltexth->allTexts[446], 185, 55, FONT_BIG, 50, zwykly, *bg); //HOTSEAT Please enter names
|
|
@@ -2587,7 +2697,7 @@ CBonusSelection::CBonusSelection( CCampaignState * _ourCampaign )
|
|
static const std::string bgNames [] = {"E1_BG.BMP", "G2_BG.BMP", "E2_BG.BMP", "G1_BG.BMP", "G3_BG.BMP", "N1_BG.BMP",
|
|
static const std::string bgNames [] = {"E1_BG.BMP", "G2_BG.BMP", "E2_BG.BMP", "G1_BG.BMP", "G3_BG.BMP", "N1_BG.BMP",
|
|
"S1_BG.BMP", "BR_BG.BMP", "IS_BG.BMP", "KR_BG.BMP", "NI_BG.BMP", "TA_BG.BMP", "AR_BG.BMP", "HS_BG.BMP",
|
|
"S1_BG.BMP", "BR_BG.BMP", "IS_BG.BMP", "KR_BG.BMP", "NI_BG.BMP", "TA_BG.BMP", "AR_BG.BMP", "HS_BG.BMP",
|
|
"BB_BG.BMP", "NB_BG.BMP", "EL_BG.BMP", "RN_BG.BMP", "UA_BG.BMP", "SP_BG.BMP"};
|
|
"BB_BG.BMP", "NB_BG.BMP", "EL_BG.BMP", "RN_BG.BMP", "UA_BG.BMP", "SP_BG.BMP"};
|
|
-
|
|
|
|
|
|
+
|
|
loadPositionsOfGraphics();
|
|
loadPositionsOfGraphics();
|
|
|
|
|
|
background = BitmapHandler::loadBitmap(bgNames[ourCampaign->camp->header.mapVersion]);
|
|
background = BitmapHandler::loadBitmap(bgNames[ourCampaign->camp->header.mapVersion]);
|
|
@@ -2603,7 +2713,7 @@ CBonusSelection::CBonusSelection( CCampaignState * _ourCampaign )
|
|
//campaign name
|
|
//campaign name
|
|
if (ourCampaign->camp->header.name.length())
|
|
if (ourCampaign->camp->header.name.length())
|
|
printAtLoc(ourCampaign->camp->header.name, 481, 28, FONT_BIG, tytulowy, background);
|
|
printAtLoc(ourCampaign->camp->header.name, 481, 28, FONT_BIG, tytulowy, background);
|
|
- else
|
|
|
|
|
|
+ else
|
|
printAtLoc("Unnamed", 481, 28, FONT_BIG, tytulowy, background);
|
|
printAtLoc("Unnamed", 481, 28, FONT_BIG, tytulowy, background);
|
|
|
|
|
|
//map size icon
|
|
//map size icon
|
|
@@ -2612,7 +2722,7 @@ CBonusSelection::CBonusSelection( CCampaignState * _ourCampaign )
|
|
|
|
|
|
//campaign description
|
|
//campaign description
|
|
printAtLoc(CGI->generaltexth->allTexts[38], 481, 63, FONT_SMALL, tytulowy, background);
|
|
printAtLoc(CGI->generaltexth->allTexts[38], 481, 63, FONT_SMALL, tytulowy, background);
|
|
-
|
|
|
|
|
|
+
|
|
cmpgDesc = new CTextBox(ourCampaign->camp->header.description, Rect(480, 86, 286, 117), 1);
|
|
cmpgDesc = new CTextBox(ourCampaign->camp->header.description, Rect(480, 86, 286, 117), 1);
|
|
cmpgDesc->showAll(background);
|
|
cmpgDesc->showAll(background);
|
|
|
|
|
|
@@ -2659,7 +2769,7 @@ CBonusSelection::CBonusSelection( CCampaignState * _ourCampaign )
|
|
std::vector<std::string> difficulty;
|
|
std::vector<std::string> difficulty;
|
|
boost::split(difficulty, CGI->generaltexth->allTexts[492], boost::is_any_of(" "));
|
|
boost::split(difficulty, CGI->generaltexth->allTexts[492], boost::is_any_of(" "));
|
|
printAtLoc(difficulty.back(), 689, 432, FONT_MEDIUM, zwykly, background); //Difficulty
|
|
printAtLoc(difficulty.back(), 689, 432, FONT_MEDIUM, zwykly, background); //Difficulty
|
|
-
|
|
|
|
|
|
+
|
|
//difficulty pics
|
|
//difficulty pics
|
|
for (int b=0; b<ARRAY_COUNT(diffPics); ++b)
|
|
for (int b=0; b<ARRAY_COUNT(diffPics); ++b)
|
|
{
|
|
{
|
|
@@ -2670,7 +2780,7 @@ CBonusSelection::CBonusSelection( CCampaignState * _ourCampaign )
|
|
|
|
|
|
delete cde;
|
|
delete cde;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
//difficulty selection buttons
|
|
//difficulty selection buttons
|
|
if (ourCampaign->camp->header.difficultyChoosenByPlayer)
|
|
if (ourCampaign->camp->header.difficultyChoosenByPlayer)
|
|
{
|
|
{
|
|
@@ -2680,7 +2790,7 @@ CBonusSelection::CBonusSelection( CCampaignState * _ourCampaign )
|
|
|
|
|
|
//load miniflags
|
|
//load miniflags
|
|
sFlags = CDefHandler::giveDef("ITGFLAGS.DEF");
|
|
sFlags = CDefHandler::giveDef("ITGFLAGS.DEF");
|
|
-
|
|
|
|
|
|
+
|
|
}
|
|
}
|
|
|
|
|
|
CBonusSelection::~CBonusSelection()
|
|
CBonusSelection::~CBonusSelection()
|
|
@@ -2749,7 +2859,7 @@ void CBonusSelection::selectMap( int whichOne )
|
|
delete ourHeader;
|
|
delete ourHeader;
|
|
ourHeader = new CMapHeader();
|
|
ourHeader = new CMapHeader();
|
|
ourHeader->initFromMemory((const unsigned char*)ourCampaign->camp->mapPieces.find(whichOne)->second.c_str(), i);
|
|
ourHeader->initFromMemory((const unsigned char*)ourCampaign->camp->mapPieces.find(whichOne)->second.c_str(), i);
|
|
-
|
|
|
|
|
|
+
|
|
std::map<ui32, std::string> names;
|
|
std::map<ui32, std::string> names;
|
|
names[1] = GDefaultOptions.playerName;
|
|
names[1] = GDefaultOptions.playerName;
|
|
updateStartInfo(ourCampaign->camp->header.filename, sInfo, ourHeader, names);
|
|
updateStartInfo(ourCampaign->camp->header.filename, sInfo, ourHeader, names);
|
|
@@ -2773,7 +2883,7 @@ void CBonusSelection::show( SDL_Surface * to )
|
|
|
|
|
|
if (mapName.length())
|
|
if (mapName.length())
|
|
printAtLoc(mapName, 481, 219, FONT_BIG, tytulowy, to);
|
|
printAtLoc(mapName, 481, 219, FONT_BIG, tytulowy, to);
|
|
- else
|
|
|
|
|
|
+ else
|
|
printAtLoc("Unnamed", 481, 219, FONT_BIG, tytulowy, to);
|
|
printAtLoc("Unnamed", 481, 219, FONT_BIG, tytulowy, to);
|
|
|
|
|
|
//map description
|
|
//map description
|
|
@@ -2869,7 +2979,7 @@ void CBonusSelection::updateBonusSelection()
|
|
case 2: //building
|
|
case 2: //building
|
|
{
|
|
{
|
|
int faction = -1;
|
|
int faction = -1;
|
|
- for(std::map<int, PlayerSettings>::iterator it = sInfo.playerInfos.begin();
|
|
|
|
|
|
+ for(std::map<int, PlayerSettings>::iterator it = sInfo.playerInfos.begin();
|
|
it != sInfo.playerInfos.end(); ++it)
|
|
it != sInfo.playerInfos.end(); ++it)
|
|
{
|
|
{
|
|
if (it->second.human)
|
|
if (it->second.human)
|
|
@@ -2877,7 +2987,7 @@ void CBonusSelection::updateBonusSelection()
|
|
faction = it->second.castle;
|
|
faction = it->second.castle;
|
|
break;
|
|
break;
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
}
|
|
}
|
|
assert(faction != -1);
|
|
assert(faction != -1);
|
|
|
|
|
|
@@ -3023,7 +3133,7 @@ void CBonusSelection::startMap()
|
|
// one of the main campaign selection screens + Bonus selection screen and
|
|
// one of the main campaign selection screens + Bonus selection screen and
|
|
// deactivates the main menu
|
|
// deactivates the main menu
|
|
GH.popInts(2);
|
|
GH.popInts(2);
|
|
- GH.popInt(GH.topInt());
|
|
|
|
|
|
+ GH.popInt(GH.topInt());
|
|
}
|
|
}
|
|
::startGame(si);
|
|
::startGame(si);
|
|
}
|
|
}
|
|
@@ -3040,7 +3150,7 @@ void CBonusSelection::selectBonus( int id )
|
|
if (startB->getState() == CButtonBase::BLOCKED)
|
|
if (startB->getState() == CButtonBase::BLOCKED)
|
|
startB->setState(CButtonBase::NORMAL);
|
|
startB->setState(CButtonBase::NORMAL);
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
|
|
|
|
const CCampaignScenario &scenario = ourCampaign->camp->scenarios[sInfo.whichMapInCampaign];
|
|
const CCampaignScenario &scenario = ourCampaign->camp->scenarios[sInfo.whichMapInCampaign];
|
|
const std::vector<CScenarioTravel::STravelBonus> & bonDescs = scenario.travelOptions.bonusesToChoose;
|
|
const std::vector<CScenarioTravel::STravelBonus> & bonDescs = scenario.travelOptions.bonusesToChoose;
|
|
@@ -3227,7 +3337,7 @@ void PlayerJoined::apply(CSelectionScreen *selScreen)
|
|
{
|
|
{
|
|
//assert(SEL->playerNames.size() == connectionID); //temporary, TODO when player exits
|
|
//assert(SEL->playerNames.size() == connectionID); //temporary, TODO when player exits
|
|
SEL->playerNames[connectionID] = playerName;
|
|
SEL->playerNames[connectionID] = playerName;
|
|
-
|
|
|
|
|
|
+
|
|
//put new player in first slot with AI
|
|
//put new player in first slot with AI
|
|
for(std::map<int, PlayerSettings>::iterator i = SEL->sInfo.playerInfos.begin(); i != SEL->sInfo.playerInfos.end(); i++)
|
|
for(std::map<int, PlayerSettings>::iterator i = SEL->sInfo.playerInfos.begin(); i != SEL->sInfo.playerInfos.end(); i++)
|
|
{
|
|
{
|
|
@@ -3314,7 +3424,7 @@ void PlayerLeft::apply(CSelectionScreen *selScreen)
|
|
selScreen->setPlayer(*s, 0);
|
|
selScreen->setPlayer(*s, 0);
|
|
selScreen->opt->entries[s->color]->selectButtons();
|
|
selScreen->opt->entries[s->color]->selectButtons();
|
|
}
|
|
}
|
|
-
|
|
|
|
|
|
+
|
|
selScreen->propagateNames();
|
|
selScreen->propagateNames();
|
|
selScreen->propagateOptions();
|
|
selScreen->propagateOptions();
|
|
GH.totalRedraw();
|
|
GH.totalRedraw();
|
|
@@ -3349,228 +3459,112 @@ void StartWithCurrentSettings::apply(CSelectionScreen *selScreen)
|
|
throw 666; //EVIL, EVIL, EVIL workaround to kill thread (does "goto catch" outside listening loop)
|
|
throw 666; //EVIL, EVIL, EVIL workaround to kill thread (does "goto catch" outside listening loop)
|
|
}
|
|
}
|
|
|
|
|
|
-CCampaignScreen::CCampaignScreen(CampaignSet campaigns, std::map<std::string, CampaignStatus>& camps)
|
|
|
|
|
|
+CCampaignScreen::CCampaignButton::CCampaignButton(const JsonNode &config )
|
|
{
|
|
{
|
|
- OBJ_CONSTRUCTION; // sets this as parent
|
|
|
|
- std::string bgImage;
|
|
|
|
- if (campaigns == ROE || campaigns == AB)
|
|
|
|
- bgImage = "CAMPBACK.BMP";
|
|
|
|
- else if (campaigns == SOD)
|
|
|
|
- bgImage = "CAMPBKX2.BMP";
|
|
|
|
- else if (campaigns == WOG)
|
|
|
|
- bgImage = "CAMPZALL.BMP";
|
|
|
|
-
|
|
|
|
- // Load background image
|
|
|
|
- bg = BitmapHandler::loadBitmap(bgImage);
|
|
|
|
- pos.x = 0;
|
|
|
|
- pos.y = 0;
|
|
|
|
- pos.w = bg->w;
|
|
|
|
- pos.h = bg->h;
|
|
|
|
-
|
|
|
|
- // Create back button
|
|
|
|
- back = new AdventureMapButton("", "", bind(&CGuiHandler::popIntTotally, &GH, this), 658, 482, "CMPSCAN.DEF", SDLK_ESCAPE);
|
|
|
|
- back->hoverable = true;
|
|
|
|
|
|
+ pos.x += config["x"].Float();
|
|
|
|
+ pos.y += config["y"].Float();
|
|
|
|
+ pos.w = 200;
|
|
|
|
+ pos.h = 116;
|
|
|
|
|
|
- // Load all campaign buttons
|
|
|
|
- // 1.index: 0 => ROE, 1 => AB, 2 => WOG
|
|
|
|
- static const int buttonCords[7][2] = { {90, 72} , {539, 72} , {43, 245} , {313, 244}, {586, 246}, {34, 417}, {404, 414}};
|
|
|
|
-
|
|
|
|
- static const std::string campFiles[3][7] = { {"GOOD1", "EVIL1", "GOOD2", "NEUTRAL1", "EVIL2", "GOOD3", "SECRET"},
|
|
|
|
- { "AB", "BLOOD", "SLAYER", "FESTIVAL", "FIRE", "FOOL" },
|
|
|
|
- { "ZC1", "ZC2", "ZC3", "ZC4" } };
|
|
|
|
|
|
+ campFile = config["file"].String();
|
|
|
|
+ video = config["video"].String();
|
|
|
|
|
|
- static const std::string campImages[3][7] = { { "CAMPGD1S.BMP", "CAMPEV1S.BMP", "CAMPGD2S.BMP", "CAMPNEUS.BMP", "CAMPEV2S.BMP", "CAMPGD3S.BMP", "CAMPSCTS.BMP" },
|
|
|
|
- { "CAMP1AB7.BMP", "CAMP1DB2.BMP", "CAMP1DS1.BMP", "CAMP1FL3.BMP", "CAMP1PF2.BMP", "CAMP1FW1.BMP" },
|
|
|
|
- { "CAMPZ01.BMP", "CAMPZ02.BMP", "CAMPZ03.BMP", "CAMPZ04.BMP" } };
|
|
|
|
|
|
+//On linux we can only play *.mjpg videos from LOKI release
|
|
#ifdef _WIN32
|
|
#ifdef _WIN32
|
|
- static const std::string campVideos[3][7] = { { "CGOOD1.BIK", "CEVIL1.BIK", "CGOOD2.BIK", "CNEUTRAL.BIK", "CEVIL2.BIK", "CGOOD3.BIK", "CSECRET.BIK" },
|
|
|
|
- { "C1ab7.BIK", "C1db2.BIK", "C1ds1.BIK", "C1fl3.BIK", "C1pf2.BIK", "C1fw1.BIK" } };
|
|
|
|
|
|
+ std::transform(video.begin(), video.end(), video.begin(), toupper);
|
|
|
|
+ video += ".BIK";
|
|
#else
|
|
#else
|
|
- static const std::string campVideos[3][7] = { { "cgood1.mjpg", "cevil1.mjpg", "cgood2.mjpg", "cneutral.mjpg", "cevil2.mjpg", "cgood3.mjpg", "csecret.mjpg" } };
|
|
|
|
|
|
+ std::transform(video.begin(), video.end(), video.begin(), tolower);
|
|
|
|
+ video += ".mjpg";
|
|
#endif
|
|
#endif
|
|
- static const std::string campTexts[3][7] = { { getMapText(0), getMapText(3), getMapText(1), getMapText(5), getMapText(4), getMapText(2), getMapText(6) },
|
|
|
|
- { "Armageddon's Blade", "Dragon's Blood", "Dragon Slayer", "Festival of Life", "Playing With Fire", "Foolhardy Waywardness" },
|
|
|
|
- { "In the Wake of Gods", "The Samaritan", "A Life of A-d-v-e-n-t-u-r-e", "Evil Way Home" } };
|
|
|
|
|
|
|
|
- static const CampaignStatus campDefaults[3][7] = { { CCampaignScreen::ENABLED, CCampaignScreen::ENABLED, CCampaignScreen::DISABLED, CCampaignScreen::ENABLED, CCampaignScreen::DISABLED,
|
|
|
|
- CCampaignScreen::DISABLED, CCampaignScreen::DISABLED },
|
|
|
|
- { CCampaignScreen::ENABLED, CCampaignScreen::ENABLED, CCampaignScreen::ENABLED, CCampaignScreen::ENABLED, CCampaignScreen::ENABLED, CCampaignScreen::DISABLED},
|
|
|
|
- { CCampaignScreen::ENABLED, CCampaignScreen::ENABLED, CCampaignScreen::ENABLED, CCampaignScreen::ENABLED } };
|
|
|
|
-
|
|
|
|
- if (campaigns == ROE)
|
|
|
|
- {
|
|
|
|
- createButtons(buttonCords, campFiles[0], campImages[0], campVideos[0], campTexts[0], camps, campDefaults[0]);
|
|
|
|
-
|
|
|
|
- if (camps[campFiles[0][6]] == 0)
|
|
|
|
- drawCampaignPlaceholder();
|
|
|
|
- }
|
|
|
|
- if (campaigns == AB)
|
|
|
|
- {
|
|
|
|
- // Foolhardy Waywardness -- draw deactivated image
|
|
|
|
- SDL_Surface *ab5Dis = BitmapHandler::loadBitmap("CAMP1FWX");
|
|
|
|
- Rect ab5DisRect(buttonCords[5][0] - 2, buttonCords[5][1] - 2, ab5Dis->w, ab5Dis->h);
|
|
|
|
- blitAt(ab5Dis, ab5DisRect, bg);
|
|
|
|
-
|
|
|
|
- createButtons(buttonCords, campFiles[1], campImages[1], campVideos[1], campTexts[1], camps, campDefaults[1]);
|
|
|
|
- drawCampaignPlaceholder();
|
|
|
|
- }
|
|
|
|
- if (campaigns == WOG)
|
|
|
|
- {
|
|
|
|
- createButtons(buttonCords, campFiles[2], campImages[2], campVideos[2], campTexts[2], camps, campDefaults[2]);
|
|
|
|
- campButtons[3]->pos.x -= 2; // special rule for the 4.th campaign
|
|
|
|
- campButtons[3]->pos.y -= 2;
|
|
|
|
- drawCampaignPlaceholder();
|
|
|
|
- }
|
|
|
|
-}
|
|
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
|
|
|
|
-CCampaignScreen::~CCampaignScreen()
|
|
|
|
-{
|
|
|
|
- // Free background image and re-start WOG main menu animation
|
|
|
|
- SDL_FreeSurface(bg);
|
|
|
|
- if (noCamp != 0)
|
|
|
|
- SDL_FreeSurface(noCamp);
|
|
|
|
|
|
+ status = config["open"].Bool() ? CCampaignScreen::ENABLED : CCampaignScreen::DISABLED;
|
|
|
|
|
|
- //campButtons.clear();
|
|
|
|
- CCS->videoh->open("ACREDIT.SMK");
|
|
|
|
-}
|
|
|
|
|
|
+ CCampaignHeader header = CCampaignHandler::getHeader(campFile, true);
|
|
|
|
+ hoverText = header.name;
|
|
|
|
|
|
-void CCampaignScreen::createButtons(const int buttonCords[7][2], const std::string campFiles[],
|
|
|
|
- const std::string campImages[], const std::string campVideos[], const std::string campTexts[], std::map<std::string, CampaignStatus>& camps, const CampaignStatus campDefaults[])
|
|
|
|
-{
|
|
|
|
- for (int i = 0; i < 7; i++)
|
|
|
|
|
|
+ if (status != CCampaignScreen::DISABLED)
|
|
{
|
|
{
|
|
- if (campFiles[i] != "") // if it's setted in the array
|
|
|
|
- {
|
|
|
|
- std::string file = campFiles[i];
|
|
|
|
-
|
|
|
|
- CCampaignButton *button = new CCampaignButton(bg, campImages[i], buttonCords[i][0], buttonCords[i][1], camps[file] != 0 ? camps[file] : campDefaults[i]);
|
|
|
|
- button->campFile = file;
|
|
|
|
- button->hoverText = campTexts[i];
|
|
|
|
- button->video = campVideos[i];
|
|
|
|
- campButtons.push_back(button);
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
-}
|
|
|
|
|
|
+ used |= LCLICK | HOVER;
|
|
|
|
+ image = new CPicture(config["image"].String());
|
|
|
|
|
|
-std::string CCampaignScreen::getMapText(int index)
|
|
|
|
-{
|
|
|
|
- return CGI->generaltexth->campaignMapNames[index];
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-void CCampaignScreen::drawCampaignPlaceholder()
|
|
|
|
-{
|
|
|
|
- noCamp = BitmapHandler::loadBitmap("CAMPNOSC.BMP");
|
|
|
|
- noCamp->w -= 2;
|
|
|
|
- Rect noCampRect(385, 401, 238, 143);
|
|
|
|
- blitAt(noCamp, noCampRect, bg);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-void CCampaignScreen::show(SDL_Surface *to)
|
|
|
|
-{
|
|
|
|
- // Draw background image and all interactive objects like buttons
|
|
|
|
- blitAt(bg, pos.x, pos.y, to);
|
|
|
|
-
|
|
|
|
- for (int i = 0; i < this->campButtons.size(); i++)
|
|
|
|
- {
|
|
|
|
- campButtons[i]->show(to);
|
|
|
|
|
|
+ hoverLabel = new CLabel(pos.w / 2, pos.h + 20, FONT_MEDIUM, CENTER, tytulowy, "");
|
|
|
|
+ moveChild(hoverLabel, this, parent);
|
|
}
|
|
}
|
|
|
|
|
|
- back->showAll(to);
|
|
|
|
|
|
+ if (status == CCampaignScreen::COMPLETED)
|
|
|
|
+ checkMark = new CPicture("CAMPCHK");
|
|
}
|
|
}
|
|
|
|
|
|
-CCampaignScreen::CCampaignButton::CCampaignButton(SDL_Surface *bg, const std::string image, const int x, const int y, CampaignStatus status)
|
|
|
|
|
|
+void CCampaignScreen::CCampaignButton::clickLeft(tribool down, bool previousState)
|
|
{
|
|
{
|
|
- OBJ_CONSTRUCTION; // sets this as parent
|
|
|
|
-
|
|
|
|
- // Initialize CCampaignButton members
|
|
|
|
- this->bg = bg;
|
|
|
|
- this->image = image;
|
|
|
|
- this->status = status;
|
|
|
|
-
|
|
|
|
- // Initialize pos and size
|
|
|
|
- pos.x = x;
|
|
|
|
- pos.y = y;
|
|
|
|
- pos.w = 200;
|
|
|
|
- pos.h = 116;
|
|
|
|
-
|
|
|
|
- // Creates the button image
|
|
|
|
- button = BitmapHandler::loadBitmap(image);
|
|
|
|
- if (status != CCampaignScreen::DISABLED && button != 0)
|
|
|
|
|
|
+ if (down)
|
|
{
|
|
{
|
|
- blitAt(button, pos, bg);
|
|
|
|
- used = LCLICK | HOVER; // set these flags to activate left click and hover event functions
|
|
|
|
|
|
+ // Close running video and open the selected campaign
|
|
|
|
+ CCS->videoh->close();
|
|
|
|
+ CCampaign * ourCampaign = CCampaignHandler::getCampaign(campFile, true);
|
|
|
|
+ CCampaignState * campState = new CCampaignState();
|
|
|
|
+ campState->camp = ourCampaign;
|
|
|
|
+ GH.pushInt( new CBonusSelection(campState) );
|
|
}
|
|
}
|
|
-
|
|
|
|
- // Create the checked image
|
|
|
|
- if (status == CCampaignScreen::COMPLETED)
|
|
|
|
- checked = BitmapHandler::loadBitmap("CAMPCHK.BMP");
|
|
|
|
-
|
|
|
|
- // Create the button hover effect
|
|
|
|
- hoverLabel = new CLabel(pos.w / 2., pos.h + 20, FONT_MEDIUM, CENTER, tytulowy, "");
|
|
|
|
- hoverLabel->ignoreLeadingWhitespace = false;
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
-CCampaignScreen::CCampaignButton::~CCampaignButton()
|
|
|
|
-{
|
|
|
|
- if (button != 0)
|
|
|
|
- SDL_FreeSurface(button);
|
|
|
|
-
|
|
|
|
- if (status == CCampaignScreen::COMPLETED)
|
|
|
|
- SDL_FreeSurface(checked);
|
|
|
|
}
|
|
}
|
|
|
|
|
|
void CCampaignScreen::CCampaignButton::hover(bool on)
|
|
void CCampaignScreen::CCampaignButton::hover(bool on)
|
|
-{
|
|
|
|
|
|
+{
|
|
if (on)
|
|
if (on)
|
|
hoverLabel->setTxt(hoverText); // Shows the name of the campaign when you get into the bounds of the button
|
|
hoverLabel->setTxt(hoverText); // Shows the name of the campaign when you get into the bounds of the button
|
|
-
|
|
|
|
else
|
|
else
|
|
- {
|
|
|
|
- // Deletes the text from the screen when you hover out of the bounds of the button
|
|
|
|
- hoverLabel->setTxt(" ");
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
|
|
+ hoverLabel->setTxt(" ");
|
|
}
|
|
}
|
|
|
|
|
|
void CCampaignScreen::CCampaignButton::show(SDL_Surface *to)
|
|
void CCampaignScreen::CCampaignButton::show(SDL_Surface *to)
|
|
{
|
|
{
|
|
- hoverLabel->showAll(to);
|
|
|
|
-
|
|
|
|
- if (status == CCampaignScreen::DISABLED || video == "" || button == 0)
|
|
|
|
|
|
+ if (status == CCampaignScreen::DISABLED)
|
|
return;
|
|
return;
|
|
|
|
|
|
|
|
+ CIntObject::show(to);
|
|
|
|
+
|
|
// Play the campaign button video when the mouse cursor is placed over the button
|
|
// Play the campaign button video when the mouse cursor is placed over the button
|
|
- if (CCS->curh->xpos >= pos.x && CCS->curh->ypos >= pos.y && CCS->curh->xpos < pos.x + pos.w && CCS->curh->ypos < pos.y + pos.h)
|
|
|
|
|
|
+ if (hovered)
|
|
{
|
|
{
|
|
if (CCS->videoh->fname != video)
|
|
if (CCS->videoh->fname != video)
|
|
CCS->videoh->open(video);
|
|
CCS->videoh->open(video);
|
|
-
|
|
|
|
|
|
+
|
|
CCS->videoh->update(pos.x, pos.y, to, true, false); // plays sequentially frame by frame, starts at the beginning when the video is over
|
|
CCS->videoh->update(pos.x, pos.y, to, true, false); // plays sequentially frame by frame, starts at the beginning when the video is over
|
|
}
|
|
}
|
|
else if (CCS->videoh->fname == video) // When you got out of the bounds of the button then close the video
|
|
else if (CCS->videoh->fname == video) // When you got out of the bounds of the button then close the video
|
|
{
|
|
{
|
|
CCS->videoh->close();
|
|
CCS->videoh->close();
|
|
- blitAt(button, pos, to);
|
|
|
|
|
|
+ redraw();
|
|
}
|
|
}
|
|
|
|
+}
|
|
|
|
|
|
|
|
+AdventureMapButton* CCampaignScreen::createExitButton(const JsonNode& button)
|
|
|
|
+{
|
|
|
|
+ std::pair<std::string, std::string> help;
|
|
|
|
+ if (!button["help"].isNull() && button["help"].Float() > 0)
|
|
|
|
+ help = CGI->generaltexth->zelp[button["help"].Float()];
|
|
|
|
|
|
- if (status == CCampaignScreen::COMPLETED) // Draw a checked symbol when you completed the mission
|
|
|
|
- {
|
|
|
|
- Rect chkRect(pos.x + 5, pos.y + 74, 42, 40);
|
|
|
|
- blitAt(checked, chkRect, to); // this is needed because the video gets drawn on top of the screen
|
|
|
|
- blitAt(checked, chkRect, bg); // this is needed because of the totalRedraw at the hover method
|
|
|
|
- }
|
|
|
|
|
|
+ boost::function<void()> close = boost::bind(&CGuiHandler::popIntTotally, &GH, this);
|
|
|
|
+ return new AdventureMapButton(help, close, button["x"].Float(), button["y"].Float(), button["name"].String(), button["hotkey"].Float());
|
|
}
|
|
}
|
|
|
|
|
|
-void CCampaignScreen::CCampaignButton::clickLeft(tribool down, bool previousState)
|
|
|
|
|
|
+
|
|
|
|
+CCampaignScreen::CCampaignScreen(const JsonNode &config)
|
|
{
|
|
{
|
|
- if (down)
|
|
|
|
|
|
+ OBJ_CONSTRUCTION_CAPTURING_ALL;
|
|
|
|
+
|
|
|
|
+ BOOST_FOREACH(const JsonNode& node, config["images"].Vector())
|
|
|
|
+ images.push_back(createPicture(node));
|
|
|
|
+
|
|
|
|
+ if (!config["exitbutton"].isNull())
|
|
{
|
|
{
|
|
- // Close running video and open the selected campaign
|
|
|
|
- CCS->videoh->close();
|
|
|
|
- CCampaign * ourCampaign = CCampaignHandler::getCampaign(campFile, true);
|
|
|
|
- CCampaignState * campState = new CCampaignState();
|
|
|
|
- campState->camp = ourCampaign;
|
|
|
|
- GH.pushInt( new CBonusSelection(campState) );
|
|
|
|
|
|
+ back = createExitButton(config["exitbutton"]);
|
|
|
|
+ back->hoverable = true;
|
|
}
|
|
}
|
|
|
|
+
|
|
|
|
+ BOOST_FOREACH(const JsonNode& node, config["items"].Vector())
|
|
|
|
+ campButtons.push_back(new CCampaignButton(node));
|
|
}
|
|
}
|