mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-26 03:52:01 +02:00
Rename InterfaceBuilder
This commit is contained in:
parent
34bf741936
commit
cd58e8a860
@ -15,7 +15,7 @@ set(client_SRCS
|
|||||||
gui/Geometries.cpp
|
gui/Geometries.cpp
|
||||||
gui/SDL_Extensions.cpp
|
gui/SDL_Extensions.cpp
|
||||||
gui/NotificationHandler.cpp
|
gui/NotificationHandler.cpp
|
||||||
gui/InterfaceBuilder.cpp
|
gui/InterfaceObjectConfigurable.cpp
|
||||||
|
|
||||||
widgets/AdventureMapClasses.cpp
|
widgets/AdventureMapClasses.cpp
|
||||||
widgets/Buttons.cpp
|
widgets/Buttons.cpp
|
||||||
@ -91,7 +91,7 @@ set(client_HEADERS
|
|||||||
gui/SDL_Extensions.h
|
gui/SDL_Extensions.h
|
||||||
gui/SDL_Pixels.h
|
gui/SDL_Pixels.h
|
||||||
gui/NotificationHandler.h
|
gui/NotificationHandler.h
|
||||||
gui/InterfaceBuilder.h
|
gui/InterfaceObjectConfigurable.h
|
||||||
|
|
||||||
widgets/AdventureMapClasses.h
|
widgets/AdventureMapClasses.h
|
||||||
widgets/Buttons.h
|
widgets/Buttons.h
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
|
|
||||||
#include "StdInc.h"
|
#include "StdInc.h"
|
||||||
|
|
||||||
#include "InterfaceBuilder.h"
|
#include "InterfaceObjectConfigurable.h"
|
||||||
|
|
||||||
#include "../CGameInfo.h"
|
#include "../CGameInfo.h"
|
||||||
#include "../gui/CAnimation.h"
|
#include "../gui/CAnimation.h"
|
||||||
@ -26,23 +26,23 @@
|
|||||||
#include "../../lib/CGeneralTextHandler.h"
|
#include "../../lib/CGeneralTextHandler.h"
|
||||||
|
|
||||||
|
|
||||||
InterfaceBuilder::InterfaceBuilder(const JsonNode & config):
|
InterfaceObjectConfigurable::InterfaceObjectConfigurable(const JsonNode & config):
|
||||||
CIntObject()
|
CIntObject()
|
||||||
{
|
{
|
||||||
init(config);
|
init(config);
|
||||||
}
|
}
|
||||||
|
|
||||||
InterfaceBuilder::InterfaceBuilder():
|
InterfaceObjectConfigurable::InterfaceObjectConfigurable():
|
||||||
CIntObject()
|
CIntObject()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
void InterfaceBuilder::addCallback(const std::string & callbackName, std::function<void(int)> callback)
|
void InterfaceObjectConfigurable::addCallback(const std::string & callbackName, std::function<void(int)> callback)
|
||||||
{
|
{
|
||||||
callbacks[callbackName] = callback;
|
callbacks[callbackName] = callback;
|
||||||
}
|
}
|
||||||
|
|
||||||
void InterfaceBuilder::init(const JsonNode &config)
|
void InterfaceObjectConfigurable::init(const JsonNode &config)
|
||||||
{
|
{
|
||||||
OBJ_CONSTRUCTION;
|
OBJ_CONSTRUCTION;
|
||||||
int unnamedObjectId = 0;
|
int unnamedObjectId = 0;
|
||||||
@ -57,7 +57,7 @@ void InterfaceBuilder::init(const JsonNode &config)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string InterfaceBuilder::buildText(const JsonNode & config) const
|
std::string InterfaceObjectConfigurable::buildText(const JsonNode & config) const
|
||||||
{
|
{
|
||||||
if(config.isNull())
|
if(config.isNull())
|
||||||
return "";
|
return "";
|
||||||
@ -69,7 +69,7 @@ std::string InterfaceBuilder::buildText(const JsonNode & config) const
|
|||||||
return config.String();
|
return config.String();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::shared_ptr<CIntObject> InterfaceBuilder::buildWidget(const JsonNode & config)
|
std::shared_ptr<CIntObject> InterfaceObjectConfigurable::buildWidget(const JsonNode & config)
|
||||||
{
|
{
|
||||||
assert(!config.isNull());
|
assert(!config.isNull());
|
||||||
auto type = config["type"].String();
|
auto type = config["type"].String();
|
||||||
|
@ -14,11 +14,11 @@
|
|||||||
|
|
||||||
#include "../../lib/JsonNode.h"
|
#include "../../lib/JsonNode.h"
|
||||||
|
|
||||||
class InterfaceBuilder: public CIntObject
|
class InterfaceObjectConfigurable: public CIntObject
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
InterfaceBuilder();
|
InterfaceObjectConfigurable();
|
||||||
InterfaceBuilder(const JsonNode & config);
|
InterfaceObjectConfigurable(const JsonNode & config);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
//must be called after adding callbacks
|
//must be called after adding callbacks
|
||||||
|
204
client/gui/InterfaceObjectConfigurable.cpp
Normal file
204
client/gui/InterfaceObjectConfigurable.cpp
Normal file
@ -0,0 +1,204 @@
|
|||||||
|
/*
|
||||||
|
* InterfaceBuilder.cpp, part of VCMI engine
|
||||||
|
*
|
||||||
|
* Authors: listed in file AUTHORS in main folder
|
||||||
|
*
|
||||||
|
* License: GNU General Public License v2.0 or later
|
||||||
|
* Full text of license available in license.txt file, in main folder
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "StdInc.h"
|
||||||
|
|
||||||
|
#include "InterfaceObjectConfigurable.h"
|
||||||
|
|
||||||
|
#include "../CGameInfo.h"
|
||||||
|
#include "../gui/CAnimation.h"
|
||||||
|
#include "../gui/CGuiHandler.h"
|
||||||
|
#include "../widgets/CComponent.h"
|
||||||
|
#include "../widgets/Buttons.h"
|
||||||
|
#include "../widgets/MiscWidgets.h"
|
||||||
|
#include "../widgets/ObjectLists.h"
|
||||||
|
#include "../widgets/TextControls.h"
|
||||||
|
#include "../windows/GUIClasses.h"
|
||||||
|
#include "../windows/InfoWindows.h"
|
||||||
|
|
||||||
|
#include "../../lib/CGeneralTextHandler.h"
|
||||||
|
|
||||||
|
|
||||||
|
InterfaceObjectConfigurable::InterfaceObjectConfigurable(const JsonNode & config):
|
||||||
|
CIntObject()
|
||||||
|
{
|
||||||
|
init(config);
|
||||||
|
}
|
||||||
|
|
||||||
|
InterfaceObjectConfigurable::InterfaceObjectConfigurable():
|
||||||
|
CIntObject()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
void InterfaceObjectConfigurable::addCallback(const std::string & callbackName, std::function<void(int)> callback)
|
||||||
|
{
|
||||||
|
callbacks[callbackName] = callback;
|
||||||
|
}
|
||||||
|
|
||||||
|
void InterfaceObjectConfigurable::init(const JsonNode &config)
|
||||||
|
{
|
||||||
|
OBJ_CONSTRUCTION;
|
||||||
|
int unnamedObjectId = 0;
|
||||||
|
const std::string unnamedObjectPrefix = "__widget_";
|
||||||
|
|
||||||
|
for(const auto & item : config["items"].Vector())
|
||||||
|
{
|
||||||
|
std::string name = item["name"].isNull()
|
||||||
|
? unnamedObjectPrefix + std::to_string(unnamedObjectId++)
|
||||||
|
: item["name"].String();
|
||||||
|
widgets[name] = buildWidget(item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string InterfaceObjectConfigurable::buildText(const JsonNode & config) const
|
||||||
|
{
|
||||||
|
if(config.isNull())
|
||||||
|
return "";
|
||||||
|
|
||||||
|
if(config.isNumber())
|
||||||
|
{
|
||||||
|
return CGI->generaltexth->allTexts[config.Integer()];
|
||||||
|
}
|
||||||
|
return config.String();
|
||||||
|
}
|
||||||
|
|
||||||
|
std::shared_ptr<CIntObject> InterfaceObjectConfigurable::buildWidget(const JsonNode & config)
|
||||||
|
{
|
||||||
|
assert(!config.isNull());
|
||||||
|
auto type = config["type"].String();
|
||||||
|
|
||||||
|
int x = 0, y = 0;
|
||||||
|
if(!config["position"].isNull())
|
||||||
|
{
|
||||||
|
x = config["position"]["x"].Integer();
|
||||||
|
y = config["position"]["y"].Integer();
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string image;
|
||||||
|
std::string text = buildText(config["text"]);
|
||||||
|
auto alignment = EAlignment::CENTER;
|
||||||
|
auto color = Colors::DEFAULT_KEY_COLOR;
|
||||||
|
auto font = EFonts::FONT_TIMES;
|
||||||
|
|
||||||
|
if(!config["image"].isNull())
|
||||||
|
image = config["image"].String();
|
||||||
|
if(!config["alignment"].isNull())
|
||||||
|
{
|
||||||
|
if(config["alignment"].String() == "left")
|
||||||
|
alignment = EAlignment::TOPLEFT;
|
||||||
|
if(config["alignment"].String() == "center")
|
||||||
|
alignment = EAlignment::CENTER;
|
||||||
|
if(config["alignment"].String() == "right")
|
||||||
|
alignment = EAlignment::BOTTOMRIGHT;
|
||||||
|
}
|
||||||
|
if(!config["color"].isNull())
|
||||||
|
{
|
||||||
|
if(config["color"].String() == "yellow")
|
||||||
|
color = Colors::YELLOW;
|
||||||
|
if(config["color"].String() == "white")
|
||||||
|
color = Colors::WHITE;
|
||||||
|
if(config["color"].String() == "gold")
|
||||||
|
color = Colors::METALLIC_GOLD;
|
||||||
|
if(config["color"].String() == "green")
|
||||||
|
color = Colors::GREEN;
|
||||||
|
if(config["color"].String() == "orange")
|
||||||
|
color = Colors::ORANGE;
|
||||||
|
if(config["color"].String() == "bright-yellow")
|
||||||
|
color = Colors::BRIGHT_YELLOW;
|
||||||
|
}
|
||||||
|
if(!config["font"].isNull())
|
||||||
|
{
|
||||||
|
if(config["font"].String() == "big")
|
||||||
|
font = EFonts::FONT_BIG;
|
||||||
|
if(config["font"].String() == "medium")
|
||||||
|
font = EFonts::FONT_MEDIUM;
|
||||||
|
if(config["font"].String() == "small")
|
||||||
|
font = EFonts::FONT_SMALL;
|
||||||
|
if(config["font"].String() == "tiny")
|
||||||
|
font = EFonts::FONT_TINY;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if(type == "picture")
|
||||||
|
{
|
||||||
|
return std::make_shared<CPicture>(image, x, y);
|
||||||
|
}
|
||||||
|
if(type == "label")
|
||||||
|
{
|
||||||
|
return std::make_shared<CLabel>(x, y, font, alignment, color, text);
|
||||||
|
}
|
||||||
|
if(type == "toggleGroup")
|
||||||
|
{
|
||||||
|
auto group = std::make_shared<CToggleGroup>(0);
|
||||||
|
group->pos.x += x;
|
||||||
|
group->pos.y += y;
|
||||||
|
if(!config["items"].isNull())
|
||||||
|
{
|
||||||
|
SObjectConstruction obj__i(group.get());
|
||||||
|
int itemIdx = -1;
|
||||||
|
for(const auto & item : config["items"].Vector())
|
||||||
|
{
|
||||||
|
itemIdx = item["index"].isNull() ? itemIdx + 1 : item["index"].Integer();
|
||||||
|
group->addToggle(itemIdx, std::dynamic_pointer_cast<CToggleBase>(buildWidget(item)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(!config["selected"].isNull())
|
||||||
|
group->setSelected(config["selected"].Integer());
|
||||||
|
if(!config["callback"].isNull())
|
||||||
|
group->addCallback(callbacks[config["callback"].String()]);
|
||||||
|
return group;
|
||||||
|
}
|
||||||
|
if(type == "toggleButton")
|
||||||
|
{
|
||||||
|
std::pair<std::string, std::string> zelp;
|
||||||
|
if(!config["zelp"].isNull())
|
||||||
|
zelp = CGI->generaltexth->zelp[config["zelp"].Integer()];
|
||||||
|
auto button = std::make_shared<CToggleButton>(Point(x, y), image, zelp);
|
||||||
|
if(!config["selected"].isNull())
|
||||||
|
button->setSelected(config["selected"].Bool());
|
||||||
|
if(!config["imageOrder"].isNull())
|
||||||
|
{
|
||||||
|
auto imgOrder = config["imageOrder"].Vector();
|
||||||
|
assert(imgOrder.size() >= 4);
|
||||||
|
button->setImageOrder(imgOrder[0].Integer(), imgOrder[1].Integer(), imgOrder[2].Integer(), imgOrder[3].Integer());
|
||||||
|
}
|
||||||
|
if(!config["callback"].isNull())
|
||||||
|
button->addCallback(callbacks[config["callback"].String()]);
|
||||||
|
return button;
|
||||||
|
}
|
||||||
|
if(type == "button")
|
||||||
|
{
|
||||||
|
std::pair<std::string, std::string> zelp;
|
||||||
|
if(!config["zelp"].isNull())
|
||||||
|
zelp = CGI->generaltexth->zelp[config["zelp"].Integer()];
|
||||||
|
auto button = std::make_shared<CButton>(Point(x, y), image, zelp);
|
||||||
|
return button;
|
||||||
|
}
|
||||||
|
if(type == "labelGroup")
|
||||||
|
{
|
||||||
|
auto group = std::make_shared<CLabelGroup>(font, alignment, color);
|
||||||
|
if(!config["items"].isNull())
|
||||||
|
{
|
||||||
|
for(const auto & item : config["items"].Vector())
|
||||||
|
{
|
||||||
|
if(!item["position"].isNull())
|
||||||
|
{
|
||||||
|
x = item["position"]["x"].Integer();
|
||||||
|
y = item["position"]["y"].Integer();
|
||||||
|
}
|
||||||
|
if(!item["text"].isNull())
|
||||||
|
text = buildText(item["text"]);
|
||||||
|
group->add(x, y, text);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return group;
|
||||||
|
}
|
||||||
|
return std::shared_ptr<CIntObject>(nullptr);
|
||||||
|
}
|
46
client/gui/InterfaceObjectConfigurable.h
Normal file
46
client/gui/InterfaceObjectConfigurable.h
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
* InterfaceBuilder.h, part of VCMI engine
|
||||||
|
*
|
||||||
|
* Authors: listed in file AUTHORS in main folder
|
||||||
|
*
|
||||||
|
* License: GNU General Public License v2.0 or later
|
||||||
|
* Full text of license available in license.txt file, in main folder
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "CIntObject.h"
|
||||||
|
|
||||||
|
#include "../../lib/JsonNode.h"
|
||||||
|
|
||||||
|
class InterfaceObjectConfigurable: public CIntObject
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
InterfaceObjectConfigurable();
|
||||||
|
InterfaceObjectConfigurable(const JsonNode & config);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
//must be called after adding callbacks
|
||||||
|
void init(const JsonNode & config);
|
||||||
|
|
||||||
|
void addCallback(const std::string & callbackName, std::function<void(int)> callback);
|
||||||
|
|
||||||
|
template<class T>
|
||||||
|
const std::shared_ptr<T> widget(const std::string & name) const
|
||||||
|
{
|
||||||
|
auto iter = widgets.find(name);
|
||||||
|
if(iter == widgets.end())
|
||||||
|
return nullptr;
|
||||||
|
return std::dynamic_pointer_cast<T>(iter->second);
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
std::map<std::string, std::shared_ptr<CIntObject>> widgets;
|
||||||
|
std::map<std::string, std::function<void(int)>> callbacks;
|
||||||
|
|
||||||
|
std::shared_ptr<CIntObject> buildWidget(const JsonNode & config);
|
||||||
|
|
||||||
|
std::string buildText(const JsonNode & param) const;
|
||||||
|
};
|
@ -30,7 +30,7 @@
|
|||||||
#include "../../lib/CModHandler.h"
|
#include "../../lib/CModHandler.h"
|
||||||
|
|
||||||
RandomMapTab::RandomMapTab():
|
RandomMapTab::RandomMapTab():
|
||||||
InterfaceBuilder()
|
InterfaceObjectConfigurable()
|
||||||
{
|
{
|
||||||
recActions = 0;
|
recActions = 0;
|
||||||
mapGenOptions = std::make_shared<CMapGenOptions>();
|
mapGenOptions = std::make_shared<CMapGenOptions>();
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#include "../../lib/FunctionList.h"
|
#include "../../lib/FunctionList.h"
|
||||||
#include "../../lib/GameConstants.h"
|
#include "../../lib/GameConstants.h"
|
||||||
#include "../gui/InterfaceBuilder.h"
|
#include "../gui/InterfaceObjectConfigurable.h"
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
@ -25,7 +25,7 @@ class CToggleButton;
|
|||||||
class CLabel;
|
class CLabel;
|
||||||
class CLabelGroup;
|
class CLabelGroup;
|
||||||
|
|
||||||
class RandomMapTab : public InterfaceBuilder
|
class RandomMapTab : public InterfaceObjectConfigurable
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
RandomMapTab();
|
RandomMapTab();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user