2014-07-15 10:14:49 +03:00
|
|
|
/*
|
|
|
|
* TextControls.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
|
|
|
|
*
|
|
|
|
*/
|
2017-07-13 11:26:03 +03:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "../gui/CIntObject.h"
|
2023-01-18 15:50:52 +02:00
|
|
|
#include "../gui/TextAlignment.h"
|
2023-02-02 21:15:13 +02:00
|
|
|
#include "../render/Colors.h"
|
2023-07-31 19:50:55 +03:00
|
|
|
#include "../render/EFont.h"
|
2023-08-23 15:07:50 +03:00
|
|
|
#include "../../lib/filesystem/ResourcePath.h"
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2023-01-30 17:18:59 +02:00
|
|
|
class IImage;
|
2014-07-15 10:14:49 +03:00
|
|
|
class CSlider;
|
|
|
|
|
|
|
|
/// Base class for all text-related widgets.
|
|
|
|
/// Controls text blitting-related options
|
|
|
|
class CTextContainer : public virtual CIntObject
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
/// returns size of border, for left- or right-aligned text
|
|
|
|
virtual Point getBorderSize() = 0;
|
|
|
|
/// do actual blitting of line. Text "what" will be placed at "where" and aligned according to alignment
|
2023-06-02 16:42:18 +03:00
|
|
|
void blitLine(Canvas & to, Rect where, std::string what);
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2023-07-31 19:50:55 +03:00
|
|
|
CTextContainer(ETextAlignment alignment, EFonts font, ColorRGBA color);
|
2014-07-15 10:14:49 +03:00
|
|
|
|
|
|
|
public:
|
2022-11-26 23:12:20 +02:00
|
|
|
ETextAlignment alignment;
|
2014-07-15 10:14:49 +03:00
|
|
|
EFonts font;
|
2023-07-31 19:50:55 +03:00
|
|
|
ColorRGBA color; // default font color. Can be overridden by placing "{}" into the string
|
2014-07-15 10:14:49 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
/// Label which shows text
|
|
|
|
class CLabel : public CTextContainer
|
|
|
|
{
|
|
|
|
protected:
|
|
|
|
Point getBorderSize() override;
|
|
|
|
virtual std::string visibleText();
|
2024-01-07 23:42:48 +01:00
|
|
|
virtual void trimText();
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2023-04-26 15:44:10 +03:00
|
|
|
std::shared_ptr<CIntObject> background;
|
2014-07-15 10:14:49 +03:00
|
|
|
std::string text;
|
2024-01-07 23:42:48 +01:00
|
|
|
int maxWidth;
|
2014-07-15 10:14:49 +03:00
|
|
|
bool autoRedraw; //whether control will redraw itself on setTxt
|
|
|
|
|
2022-12-19 22:04:50 +02:00
|
|
|
public:
|
|
|
|
|
2014-07-15 10:14:49 +03:00
|
|
|
std::string getText();
|
2018-03-20 15:19:33 +07:00
|
|
|
virtual void setAutoRedraw(bool option);
|
2022-05-07 12:56:34 +03:00
|
|
|
virtual void setText(const std::string & Txt);
|
2024-01-08 00:08:05 +01:00
|
|
|
virtual void setMaxWidth(int width);
|
2023-07-31 19:50:55 +03:00
|
|
|
virtual void setColor(const ColorRGBA & Color);
|
2024-02-27 13:39:50 +02:00
|
|
|
void clear();
|
2018-03-20 15:19:33 +07:00
|
|
|
size_t getWidth();
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2022-11-26 23:12:20 +02:00
|
|
|
CLabel(int x = 0, int y = 0, EFonts Font = FONT_SMALL, ETextAlignment Align = ETextAlignment::TOPLEFT,
|
2024-01-07 23:42:48 +01:00
|
|
|
const ColorRGBA & Color = Colors::WHITE, const std::string & Text = "", int maxWidth = 0);
|
2023-06-02 16:42:18 +03:00
|
|
|
void showAll(Canvas & to) override; //shows statusbar (with current text)
|
2014-07-15 10:14:49 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
/// Small helper class to manage group of similar labels
|
|
|
|
class CLabelGroup : public CIntObject
|
|
|
|
{
|
2018-04-07 14:34:11 +03:00
|
|
|
std::vector<std::shared_ptr<CLabel>> labels;
|
2014-07-15 10:14:49 +03:00
|
|
|
EFonts font;
|
2022-11-26 23:12:20 +02:00
|
|
|
ETextAlignment align;
|
2023-07-31 19:50:55 +03:00
|
|
|
ColorRGBA color;
|
2014-07-15 10:14:49 +03:00
|
|
|
public:
|
2023-07-31 19:50:55 +03:00
|
|
|
CLabelGroup(EFonts Font = FONT_SMALL, ETextAlignment Align = ETextAlignment::TOPLEFT, const ColorRGBA & Color = Colors::WHITE);
|
2022-05-07 12:56:34 +03:00
|
|
|
void add(int x = 0, int y = 0, const std::string & text = "");
|
2018-03-23 01:23:18 +07:00
|
|
|
size_t currentSize() const;
|
2014-07-15 10:14:49 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
/// Multi-line label that can display multiple lines of text
|
|
|
|
/// If text is too big to fit into requested area remaining part will not be visible
|
|
|
|
class CMultiLineLabel : public CLabel
|
|
|
|
{
|
|
|
|
// text to blit, split into lines that are no longer than widget width
|
|
|
|
std::vector<std::string> lines;
|
|
|
|
|
|
|
|
// area of text that actually will be printed, default is widget size
|
|
|
|
Rect visibleSize;
|
|
|
|
|
2022-05-07 12:56:34 +03:00
|
|
|
void splitText(const std::string & Txt, bool redrawAfter);
|
2014-07-15 10:14:49 +03:00
|
|
|
Rect getTextLocation();
|
|
|
|
public:
|
|
|
|
// total size of text, x = longest line of text, y = total height of lines
|
|
|
|
Point textSize;
|
|
|
|
|
2023-07-31 19:50:55 +03:00
|
|
|
CMultiLineLabel(Rect position, EFonts Font = FONT_SMALL, ETextAlignment Align = ETextAlignment::TOPLEFT, const ColorRGBA & Color = Colors::WHITE, const std::string & Text = "");
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2022-05-07 12:56:34 +03:00
|
|
|
void setText(const std::string & Txt) override;
|
2024-10-14 23:26:24 +02:00
|
|
|
std::vector<std::string> getLines();
|
2023-06-02 16:42:18 +03:00
|
|
|
void showAll(Canvas & to) override;
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2019-04-20 18:26:54 +02:00
|
|
|
void setVisibleSize(Rect visibleSize, bool redrawElement = true);
|
2014-07-15 10:14:49 +03:00
|
|
|
// scrolls text visible in widget. Positive value will move text up
|
2019-04-20 18:26:54 +02:00
|
|
|
void scrollTextTo(int distance, bool redrawAfterScroll = true);
|
2014-07-15 10:14:49 +03:00
|
|
|
void scrollTextBy(int distance);
|
|
|
|
};
|
|
|
|
|
|
|
|
/// a multi-line label that tries to fit text with given available width and height;
|
|
|
|
/// if not possible, it creates a slider for scrolling text
|
|
|
|
class CTextBox : public CIntObject
|
|
|
|
{
|
|
|
|
int sliderStyle;
|
|
|
|
public:
|
2018-04-07 14:34:11 +03:00
|
|
|
std::shared_ptr<CMultiLineLabel> label;
|
|
|
|
std::shared_ptr<CSlider> slider;
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2023-07-31 19:50:55 +03:00
|
|
|
CTextBox(std::string Text, const Rect & rect, int SliderStyle, EFonts Font = FONT_SMALL, ETextAlignment Align = ETextAlignment::TOPLEFT, const ColorRGBA & Color = Colors::WHITE);
|
2014-07-15 10:14:49 +03:00
|
|
|
|
|
|
|
void resize(Point newSize);
|
2024-02-26 18:32:15 +02:00
|
|
|
/// Resizes text box to minimal size needed to fit current text
|
|
|
|
/// No effect if text is too large to fit and requires slider
|
|
|
|
void trimToFit();
|
2018-04-07 14:34:11 +03:00
|
|
|
void setText(const std::string & Txt);
|
2014-07-15 10:14:49 +03:00
|
|
|
void sliderMoved(int to);
|
|
|
|
};
|
|
|
|
|
|
|
|
/// Status bar which is shown at the bottom of the in-game screens
|
2022-11-18 17:54:10 +02:00
|
|
|
class CGStatusBar : public CLabel, public std::enable_shared_from_this<CGStatusBar>, public IStatusBar
|
2014-07-15 10:14:49 +03:00
|
|
|
{
|
2022-12-12 18:23:41 +02:00
|
|
|
std::string hoverText;
|
|
|
|
std::string consoleText;
|
|
|
|
bool enteringText;
|
|
|
|
|
2023-07-31 19:50:55 +03:00
|
|
|
CGStatusBar(std::shared_ptr<CIntObject> background_, EFonts Font = FONT_SMALL, ETextAlignment Align = ETextAlignment::CENTER, const ColorRGBA & Color = Colors::WHITE);
|
2023-09-26 15:53:44 +02:00
|
|
|
CGStatusBar(int x, int y, const ImagePath & name, int maxw = -1);
|
|
|
|
CGStatusBar(int x, int y);
|
2022-12-19 22:04:50 +02:00
|
|
|
|
|
|
|
//make CLabel API private
|
|
|
|
using CLabel::getText;
|
|
|
|
using CLabel::setAutoRedraw;
|
|
|
|
using CLabel::setText;
|
|
|
|
using CLabel::setColor;
|
|
|
|
using CLabel::getWidth;
|
|
|
|
|
2014-07-15 10:14:49 +03:00
|
|
|
protected:
|
|
|
|
Point getBorderSize() override;
|
|
|
|
|
2023-07-09 17:48:25 +03:00
|
|
|
void clickPressed(const Point & cursorPosition) override;
|
2022-11-20 11:53:46 +02:00
|
|
|
|
2014-07-15 10:14:49 +03:00
|
|
|
public:
|
2023-05-05 23:36:33 +03:00
|
|
|
~CGStatusBar();
|
|
|
|
|
2018-08-26 19:09:56 +03:00
|
|
|
template<typename ...Args>
|
|
|
|
static std::shared_ptr<CGStatusBar> create(Args... args)
|
|
|
|
{
|
|
|
|
std::shared_ptr<CGStatusBar> ret{new CGStatusBar{args...}};
|
|
|
|
return ret;
|
|
|
|
}
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2023-06-02 16:42:18 +03:00
|
|
|
void show(Canvas & to) override;
|
2023-05-05 23:36:33 +03:00
|
|
|
void activate() override;
|
2022-12-19 22:06:01 +02:00
|
|
|
void deactivate() override;
|
2014-07-15 10:14:49 +03:00
|
|
|
|
2022-12-12 18:23:41 +02:00
|
|
|
// IStatusBar interface
|
|
|
|
void write(const std::string & Text) override;
|
|
|
|
void clearIfMatching(const std::string & Text) override;
|
|
|
|
void clear() override;
|
|
|
|
void setEnteringMode(bool on) override;
|
|
|
|
void setEnteredText(const std::string & text) override;
|
2022-05-07 12:56:34 +03:00
|
|
|
};
|