2024-02-25 15:46:47 +01:00
|
|
|
#pragma once
|
2023-06-20 14:33:09 +10:00
|
|
|
|
|
|
|
#include "StarFontTextureGroup.hpp"
|
|
|
|
#include "StarAnchorTypes.hpp"
|
2023-06-21 19:46:23 +10:00
|
|
|
#include "StarRoot.hpp"
|
2023-06-28 20:08:11 +10:00
|
|
|
#include "StarStringView.hpp"
|
2023-06-20 14:33:09 +10:00
|
|
|
|
|
|
|
namespace Star {
|
|
|
|
|
|
|
|
STAR_CLASS(TextPainter);
|
|
|
|
|
|
|
|
enum class FontMode {
|
|
|
|
Normal,
|
|
|
|
Shadow
|
|
|
|
};
|
|
|
|
|
|
|
|
float const DefaultLineSpacing = 1.3f;
|
|
|
|
|
|
|
|
struct TextPositioning {
|
|
|
|
TextPositioning();
|
|
|
|
|
|
|
|
TextPositioning(Vec2F pos,
|
|
|
|
HorizontalAnchor hAnchor = HorizontalAnchor::LeftAnchor,
|
|
|
|
VerticalAnchor vAnchor = VerticalAnchor::BottomAnchor,
|
|
|
|
Maybe<unsigned> wrapWidth = {},
|
|
|
|
Maybe<unsigned> charLimit = {});
|
|
|
|
|
|
|
|
TextPositioning(Json const& v);
|
|
|
|
Json toJson() const;
|
|
|
|
|
|
|
|
TextPositioning translated(Vec2F translation) const;
|
|
|
|
|
|
|
|
Vec2F pos;
|
|
|
|
HorizontalAnchor hAnchor;
|
|
|
|
VerticalAnchor vAnchor;
|
|
|
|
Maybe<unsigned> wrapWidth;
|
|
|
|
Maybe<unsigned> charLimit;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Renders text while caching individual glyphs for fast rendering but with *no
|
|
|
|
// kerning*.
|
|
|
|
class TextPainter {
|
|
|
|
public:
|
2023-06-21 19:46:23 +10:00
|
|
|
TextPainter(RendererPtr renderer, TextureGroupPtr textureGroup);
|
2023-06-20 14:33:09 +10:00
|
|
|
|
2023-06-28 20:08:11 +10:00
|
|
|
RectF renderText(StringView s, TextPositioning const& position);
|
|
|
|
RectF renderLine(StringView s, TextPositioning const& position);
|
2023-06-20 14:33:09 +10:00
|
|
|
RectF renderGlyph(String::Char c, TextPositioning const& position);
|
|
|
|
|
2023-06-28 20:08:11 +10:00
|
|
|
RectF determineTextSize(StringView s, TextPositioning const& position);
|
|
|
|
RectF determineLineSize(StringView s, TextPositioning const& position);
|
2023-06-20 14:33:09 +10:00
|
|
|
RectF determineGlyphSize(String::Char c, TextPositioning const& position);
|
|
|
|
|
|
|
|
int glyphWidth(String::Char c);
|
2023-06-28 20:08:11 +10:00
|
|
|
int stringWidth(StringView s);
|
2023-06-20 14:33:09 +10:00
|
|
|
|
2023-06-28 20:08:11 +10:00
|
|
|
|
2023-07-01 14:01:27 +10:00
|
|
|
typedef function<bool(StringView, int)> WrapTextCallback;
|
2023-07-02 00:52:36 +10:00
|
|
|
bool processWrapText(StringView s, unsigned* wrapWidth, WrapTextCallback textFunc);
|
2023-06-28 20:08:11 +10:00
|
|
|
|
|
|
|
List<StringView> wrapTextViews(StringView s, Maybe<unsigned> wrapWidth);
|
|
|
|
StringList wrapText(StringView s, Maybe<unsigned> wrapWidth);
|
2023-06-20 14:33:09 +10:00
|
|
|
|
|
|
|
unsigned fontSize() const;
|
|
|
|
void setFontSize(unsigned size);
|
|
|
|
void setLineSpacing(float lineSpacing);
|
|
|
|
void setMode(FontMode mode);
|
|
|
|
void setFontColor(Vec4B color);
|
2023-07-04 06:01:29 +10:00
|
|
|
void setProcessingDirectives(StringView directives);
|
2023-06-21 19:46:23 +10:00
|
|
|
void setFont(String const& font);
|
|
|
|
void addFont(FontPtr const& font, String const& name);
|
2023-06-21 23:13:37 +10:00
|
|
|
void reloadFonts();
|
2023-06-20 14:33:09 +10:00
|
|
|
|
|
|
|
void cleanup(int64_t textureTimeout);
|
2023-06-28 20:08:11 +10:00
|
|
|
void applyCommands(StringView unsplitCommands);
|
2023-06-20 14:33:09 +10:00
|
|
|
private:
|
|
|
|
struct RenderSettings {
|
|
|
|
FontMode mode;
|
|
|
|
Vec4B color;
|
2023-06-21 19:46:23 +10:00
|
|
|
String font;
|
2023-07-04 06:01:29 +10:00
|
|
|
Directives directives;
|
2023-06-20 14:33:09 +10:00
|
|
|
};
|
|
|
|
|
2023-06-28 20:08:11 +10:00
|
|
|
RectF doRenderText(StringView s, TextPositioning const& position, bool reallyRender, unsigned* charLimit);
|
|
|
|
RectF doRenderLine(StringView s, TextPositioning const& position, bool reallyRender, unsigned* charLimit);
|
2023-06-20 14:33:09 +10:00
|
|
|
RectF doRenderGlyph(String::Char c, TextPositioning const& position, bool reallyRender);
|
|
|
|
|
2023-07-04 06:01:29 +10:00
|
|
|
void renderGlyph(String::Char c, Vec2F const& screenPos, unsigned fontSize, float scale, Vec4B const& color, Directives const* processingDirectives = nullptr);
|
2023-08-04 23:47:52 +10:00
|
|
|
static FontPtr loadFont(String const& fontPath, Maybe<String> fontName = {});
|
2023-06-20 14:33:09 +10:00
|
|
|
|
|
|
|
RendererPtr m_renderer;
|
|
|
|
FontTextureGroup m_fontTextureGroup;
|
|
|
|
|
|
|
|
unsigned m_fontSize;
|
|
|
|
float m_lineSpacing;
|
|
|
|
|
|
|
|
RenderSettings m_renderSettings;
|
|
|
|
RenderSettings m_savedRenderSettings;
|
|
|
|
|
|
|
|
String m_nonRenderedCharacters;
|
2023-06-21 23:13:37 +10:00
|
|
|
|
|
|
|
TrackerListenerPtr m_reloadTracker;
|
2023-06-20 14:33:09 +10:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|