2011-12-17 18:59:59 +00:00
|
|
|
/*
|
|
|
|
* CIntObject.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
|
|
|
|
*
|
|
|
|
*/
|
2014-05-23 20:46:54 +04:00
|
|
|
#pragma once
|
|
|
|
|
2023-05-18 13:31:26 +03:00
|
|
|
#include "EventsReceiver.h"
|
2014-05-23 20:46:54 +04:00
|
|
|
|
2023-07-31 19:50:55 +03:00
|
|
|
#include "../../lib/Rect.h"
|
|
|
|
#include "../../lib/Color.h"
|
|
|
|
#include "../../lib/GameConstants.h"
|
|
|
|
|
2014-05-23 20:46:54 +04:00
|
|
|
class CGuiHandler;
|
2016-10-16 04:23:38 +03:00
|
|
|
class CPicture;
|
2023-06-02 16:42:18 +03:00
|
|
|
class Canvas;
|
2011-12-17 18:59:59 +00:00
|
|
|
|
2011-12-22 13:05:19 +00:00
|
|
|
class IUpdateable
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual void update()=0;
|
2023-05-17 23:22:45 +03:00
|
|
|
virtual ~IUpdateable() = default;
|
2011-12-22 13:05:19 +00:00
|
|
|
};
|
|
|
|
|
2023-05-18 02:09:42 +03:00
|
|
|
class IShowActivatable
|
2011-12-22 13:05:19 +00:00
|
|
|
{
|
|
|
|
public:
|
2023-05-18 02:09:42 +03:00
|
|
|
virtual void activate()=0;
|
|
|
|
virtual void deactivate()=0;
|
|
|
|
|
2011-12-22 13:05:19 +00:00
|
|
|
virtual void redraw()=0;
|
2023-06-02 16:42:18 +03:00
|
|
|
virtual void show(Canvas & to) = 0;
|
|
|
|
virtual void showAll(Canvas & to) = 0;
|
2011-12-22 13:05:19 +00:00
|
|
|
|
2023-06-11 20:38:42 +03:00
|
|
|
virtual bool isPopupWindow() const = 0;
|
2023-05-17 23:22:45 +03:00
|
|
|
virtual void onScreenResize() = 0;
|
|
|
|
virtual ~IShowActivatable() = default;
|
2011-12-22 13:05:19 +00:00
|
|
|
};
|
|
|
|
|
2023-05-17 23:22:45 +03:00
|
|
|
// Base UI element
|
|
|
|
class CIntObject : public IShowActivatable, public AEventsReceiver //interface object
|
|
|
|
{
|
2023-05-18 02:09:42 +03:00
|
|
|
ui16 used;
|
2023-05-17 23:22:45 +03:00
|
|
|
|
|
|
|
//non-const versions of fields to allow changing them in CIntObject
|
|
|
|
CIntObject *parent_m; //parent object
|
|
|
|
|
2023-07-03 19:24:12 +03:00
|
|
|
bool inputEnabled;
|
|
|
|
bool redrawParent;
|
2012-06-02 15:16:54 +00:00
|
|
|
|
2023-07-03 19:24:12 +03:00
|
|
|
public:
|
2023-05-18 02:09:42 +03:00
|
|
|
std::vector<CIntObject *> children;
|
2012-06-02 15:16:54 +00:00
|
|
|
|
|
|
|
/// read-only parent access. May not be a "clean" solution but allows some compatibility
|
|
|
|
CIntObject * const & parent;
|
|
|
|
|
|
|
|
/// position of object on the screen. Please do not modify this anywhere but in constructor - use moveBy\moveTo instead
|
|
|
|
/*const*/ Rect pos;
|
|
|
|
|
|
|
|
CIntObject(int used=0, Point offset=Point());
|
2017-07-18 00:04:00 +03:00
|
|
|
virtual ~CIntObject();
|
2012-06-02 15:16:54 +00:00
|
|
|
|
2023-07-04 18:42:52 +03:00
|
|
|
bool captureThisKey(EShortcut key) override;
|
2011-12-17 18:59:59 +00:00
|
|
|
|
2012-06-02 15:16:54 +00:00
|
|
|
void addUsedEvents(ui16 newActions);
|
|
|
|
void removeUsedEvents(ui16 newActions);
|
2011-12-17 18:59:59 +00:00
|
|
|
|
|
|
|
enum {ACTIVATE=1, DEACTIVATE=2, UPDATE=4, SHOWALL=8, DISPOSE=16, SHARE_POS=32};
|
|
|
|
ui8 defActions; //which calls will be tried to be redirected to children
|
2012-06-02 15:16:54 +00:00
|
|
|
ui8 recActions; //which calls we allow to receive from parent
|
2011-12-17 18:59:59 +00:00
|
|
|
|
2023-05-04 19:04:36 +03:00
|
|
|
/// deactivates if needed, blocks all automatic activity, allows only disposal
|
|
|
|
void disable();
|
|
|
|
/// activates if needed, all activity enabled (Warning: may not be symetric with disable if recActions was limited!)
|
|
|
|
void enable();
|
|
|
|
/// deactivates or activates UI element based on flag
|
|
|
|
void setEnabled(bool on);
|
|
|
|
|
2023-07-03 19:24:12 +03:00
|
|
|
/// Block (or allow) all user input, e.g. mouse/keyboard/touch without hiding element
|
|
|
|
void setInputEnabled(bool on);
|
|
|
|
|
|
|
|
/// Mark this input as one that requires parent redraw on update,
|
|
|
|
/// for example if current control might have semi-transparent elements and requires redrawing of background
|
|
|
|
void setRedrawParent(bool on);
|
|
|
|
|
2012-01-19 14:33:22 +00:00
|
|
|
// activate or deactivate object. Inactive object won't receive any input events (keyboard\mouse)
|
|
|
|
// usually used automatically by parent
|
2015-10-12 16:47:10 +03:00
|
|
|
void activate() override;
|
|
|
|
void deactivate() override;
|
2012-01-19 14:33:22 +00:00
|
|
|
|
|
|
|
//called each frame to update screen
|
2023-06-02 16:42:18 +03:00
|
|
|
void show(Canvas & to) override;
|
2012-01-19 14:33:22 +00:00
|
|
|
//called on complete redraw only
|
2023-06-02 16:42:18 +03:00
|
|
|
void showAll(Canvas & to) override;
|
2012-06-02 15:16:54 +00:00
|
|
|
//request complete redraw of this object
|
2015-10-12 16:47:10 +03:00
|
|
|
void redraw() override;
|
2011-12-17 18:59:59 +00:00
|
|
|
|
2023-06-11 20:38:42 +03:00
|
|
|
/// returns true if this element is a popup window
|
|
|
|
/// called only for windows
|
|
|
|
bool isPopupWindow() const override;
|
|
|
|
|
2023-05-04 22:33:25 +03:00
|
|
|
/// called only for windows whenever screen size changes
|
|
|
|
/// default behavior is to re-center, can be overriden
|
2023-05-17 23:22:45 +03:00
|
|
|
void onScreenResize() override;
|
|
|
|
|
2023-06-13 19:33:35 +03:00
|
|
|
/// returns true if UI elements wants to handle event of specific type (LCLICK, SHOW_POPUP ...)
|
2023-06-11 20:38:42 +03:00
|
|
|
/// by default, usedEvents inside UI elements are always handled
|
2023-05-29 13:08:08 +03:00
|
|
|
bool receiveEvent(const Point & position, int eventType) const override;
|
2023-05-04 22:33:25 +03:00
|
|
|
|
2011-12-22 13:05:19 +00:00
|
|
|
const Rect & center(const Rect &r, bool propagate = true); //sets pos so that r will be in the center of screen, assigns sizes of r to pos, returns new position
|
|
|
|
const Rect & center(const Point &p, bool propagate = true); //moves object so that point p will be in its center
|
|
|
|
const Rect & center(bool propagate = true); //centers when pos.w and pos.h are set, returns new position
|
2011-12-17 18:59:59 +00:00
|
|
|
void fitToScreen(int borderWidth, bool propagate = true); //moves window to fit into screen
|
2011-12-22 13:05:19 +00:00
|
|
|
void moveBy(const Point &p, bool propagate = true);
|
2012-01-19 14:33:22 +00:00
|
|
|
void moveTo(const Point &p, bool propagate = true);//move this to new position, coordinates are absolute (0,0 is topleft screen corner)
|
2011-12-17 18:59:59 +00:00
|
|
|
|
|
|
|
void addChild(CIntObject *child, bool adjustPosition = false);
|
|
|
|
void removeChild(CIntObject *child, bool adjustPosition = false);
|
2018-07-25 01:36:48 +03:00
|
|
|
|
2011-12-22 13:05:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/// Class for binding keys to left mouse button clicks
|
|
|
|
/// Classes wanting use it should have it as one of their base classes
|
|
|
|
class CKeyShortcut : public virtual CIntObject
|
|
|
|
{
|
2023-05-18 02:09:42 +03:00
|
|
|
bool shortcutPressed;
|
2011-12-22 13:05:19 +00:00
|
|
|
public:
|
2023-04-27 20:21:06 +03:00
|
|
|
EShortcut assignedKey;
|
2014-08-03 14:16:19 +03:00
|
|
|
CKeyShortcut();
|
2023-04-27 20:21:06 +03:00
|
|
|
CKeyShortcut(EShortcut key);
|
|
|
|
void keyPressed(EShortcut key) override;
|
|
|
|
void keyReleased(EShortcut key) override;
|
2023-02-02 18:02:25 +02:00
|
|
|
|
2012-06-02 15:16:54 +00:00
|
|
|
};
|
2018-07-25 01:36:48 +03:00
|
|
|
|
|
|
|
class WindowBase : public CIntObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
WindowBase(int used_ = 0, Point pos_ = Point());
|
|
|
|
protected:
|
2020-10-05 16:27:04 -07:00
|
|
|
void close();
|
2018-07-25 01:36:48 +03:00
|
|
|
};
|
2022-11-18 17:54:10 +02:00
|
|
|
|
2023-07-07 01:08:29 +03:00
|
|
|
class IGarrisonHolder
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual void updateGarrisons() = 0;
|
|
|
|
};
|
|
|
|
|
2022-11-18 17:54:10 +02:00
|
|
|
class IStatusBar
|
|
|
|
{
|
|
|
|
public:
|
2023-05-18 13:59:09 +03:00
|
|
|
virtual ~IStatusBar() = default;
|
2022-12-12 18:23:41 +02:00
|
|
|
|
|
|
|
/// set current text for the status bar
|
|
|
|
virtual void write(const std::string & text) = 0;
|
|
|
|
|
|
|
|
/// remove any current text from the status bar
|
2022-11-18 17:54:10 +02:00
|
|
|
virtual void clear() = 0;
|
2022-12-12 18:23:41 +02:00
|
|
|
|
|
|
|
/// remove text from status bar if current text matches tested text
|
|
|
|
virtual void clearIfMatching(const std::string & testedText) = 0;
|
|
|
|
|
|
|
|
/// enables mode for entering text instead of showing hover text
|
|
|
|
virtual void setEnteringMode(bool on) = 0;
|
|
|
|
|
|
|
|
/// overrides hover text from controls with text entered into in-game console (for chat/cheats)
|
|
|
|
virtual void setEnteredText(const std::string & text) = 0;
|
|
|
|
|
2022-11-18 17:54:10 +02:00
|
|
|
};
|
2023-05-16 18:34:23 +03:00
|
|
|
|
|
|
|
class EmptyStatusBar : public IStatusBar
|
|
|
|
{
|
|
|
|
virtual void write(const std::string & text){};
|
|
|
|
virtual void clear(){};
|
|
|
|
virtual void clearIfMatching(const std::string & testedText){};
|
|
|
|
virtual void setEnteringMode(bool on){};
|
|
|
|
virtual void setEnteredText(const std::string & text){};
|
|
|
|
};
|