CommonLibSSE (powerof3)
Loading...
Searching...
No Matches
GFxTranslator.h
Go to the documentation of this file.
1#pragma once
2
3#include "RE/G/GFxState.h"
4#include "RE/G/GFxWWHelper.h"
5
6namespace RE
7{
8 class GFxWStringBuffer;
9
10 class GFxTranslator : public GFxState
11 {
12 public:
13 inline static constexpr auto RTTI = RTTI_GFxTranslator;
14 inline static constexpr auto VTABLE = VTABLE_GFxTranslator;
15
17
18 // TranslateCaps is an enumeration type defining the translation capabilities of the Translator object. In general, capability flags are used to determine two things:
19 // * The type of strings can be passed to the Translate virtual function as a key.
20 // * The type of result strings that will be generated by Translate into the result buffer.
21 enum class TranslateCap
22 {
23 kNone = 0,
24 kReceiveHTML = 1 << 0, // Specifies that Translate key can include Flash-HTML tags. If not specified, translate will only receive stripped text content (default)
25 kStripTrailingNewLines = 1 << 1 // Forces all trailing new-line symbols to be stripped before the text is passed to Translate. This is important if the original text was in HTML format, since it can have a trailing paragraph tag that is turned into a new line
26 };
27
29 {
30 public:
31 enum Flag
32 {
33 kNone = 0,
34 kTranslated = 1 << 0,
35 kResultHTML = 1 << 1,
36 kResultSourceHTML = 1 << 2
37 };
38
40
41 [[nodiscard]] const char* GetInstanceName() const; // An input method which returns the instance name of the textfield being translated.
42 [[nodiscard]] const wchar_t* GetKey() const; // An input method which returns the 'key' string - original text value of the textfield being translated.
43 [[nodiscard]] bool IsKeyHTML() const; // Determines if the key string (returned by GetKey) is HTML or not.
44 void SetResult(const wchar_t* a_resultText, UPInt a_resultLen = UPINT_MAX); // An output method which sets the translated string as a plain text.
45 void SetResultHTML(const wchar_t* a_resultHTML, UPInt a_resultLen = UPINT_MAX); // An output method which sets translated string as a HTML text.
46
47 // members
48 const wchar_t* key; // 00
50 const char* instanceName; // 10
52 std::uint8_t pad19; // 19
53 std::uint16_t pad1A; // 1A
54 std::uint32_t pad1C; // 1C
55 };
56 static_assert(sizeof(TranslateInfo) == 0x20);
57
58 // LineFormatDesc provides information of the line text to be formatted like the length of the text, text position etc. This structure is mainly used by OnWordWrapping to control word wrapping of the text.
59 // Note that all members of LineFormatDesc marked as "[in]" are used as input values only and shouldn't be modified. Members marked as "[out]" or "[in, out]" might be modified.
61 {
62 enum class Alignment
63 {
64 kLeft = 0,
65 kRight = 1,
66 kCenter = 2,
67 kJustify = 3
68 };
69
70 // members
71 const wchar_t* paraText; // 00 - [in] Text of the current paragraph, wide-characters are used
72 UPInt paraTextLen; // 08 - [in] Length of the paragraph text, in characters
73 const float* widths; // 10 - [in] An array of line widths, in pixels, before the character at the corresponding index. The size of the array is NumCharsInLine + 1. Note, this is not the array of character widths. For example, there is a line that contains three characters: ABC. The NumCharInLine will be equal 3, the size of the pWidths will be 4; the pWidth[0] will be always 0 (since there are no characters before the A), the pWidth[1] will contain width of A symbol, pWidths[2] will contain width of A PLUS width of B, and, finally, pWidths[3] will contain total width of the line (width of A PLUS width of B PLUS width of C)
74 UPInt lineStartPos; // 18 - [in] The text position of the first character in line. ParaTextLen[LineStartPos] might be used to get the value of this character
75 UPInt numCharsInLine; // 20 - [in] Number of characters currently in the line
76 float visibleRectWidth; // 28 - [in] Width, in pixels, of client rectangle. This width might be used in calculation of word wrapping position: the total width of line should not exceed this width
77 float currentLineWidth; // 2C - [in] Current line width, in pixels
78 float lineWidthBeforeWordWrap; // 30 - [in] Line width before the proposedWordWrapPoint, in pixels. For example, if line is ABC DEF and proposedWordWrapPoint = 3 (space) then lineWidthBeforeWordWrap will contain the width of ABC (w/o space) part of the line
79 float dashSymbolWidth; // 34 - [in] Supplementary member, width of the hyphen symbol, in pixels. It might be used to calculate hyphenation
80 REX::EnumSet<Alignment, std::uint8_t> alignment; // 38 - [in] Alignment of the line
81 std::uint8_t pad39; // 39
82 std::uint16_t pad3A; // 3A
83 std::uint32_t pad3C; // 3C
84 UPInt proposedWordWrapPoint; // 40 - [in,out] An index in the line of the proposed word wrap position. For example, if the line text is "ABC DEF" and only "ABC DE" fits in visibleRectWidth then the proposedWordWrapPoint will be equal to 3. Note, this is the index in line, not in text (paraText), not in line. Use lineStartPos to calculate the proposed word wrapping position in the text. The user's OnWordWrapping method should change this member if it is necessary to change the word wrapping position according to custom rules
85 bool useHyphenation; // 48 - [out] The OnWordWrapping method may set this to true to indicate to put hyphen symbol at the word-wrapping position. This might be useful for implementing hyphenation
86 std::uint8_t pad49; // 49
87 std::uint16_t pad4A; // 4A
88 std::uint32_t pad4C; // 4C
89 };
90 static_assert(sizeof(LineFormatDesc) == 0x50);
91
93 explicit GFxTranslator(WordWrappingType a_wwMode);
94 ~GFxTranslator() override = default; // 00
95
96 // add
97 [[nodiscard]] virtual TranslateCap GetCaps() const; // 01 - { return TranslateCap::kNone; } - Specifies capabilities of the Translate implementation
98 virtual void Translate(TranslateInfo* a_translateInfo); // 02 - { return; } - Translate method implements a UTF-8/UCS-2 translation interface and performs lookup of 'a_translateInfo->GetKey()' string for language translation, filling in the destination buffer by calling TranslateInfo::SetResult or TranslateInfo::SetResultHTML method. 'a_translateInfo' is guaranteed to be not null. If neither TranslateInfo::SetResult nor TranslateInfo::SetResultHTML is called then original text will not be changed
99 virtual bool OnWordWrapping(LineFormatDesc* a_desc); // 03 - OnWordWrapping is a virtual method, a callback, which is invoked once a necessity of word-wrapping for any text field is determined. This method is invoked only if custom word-wrapping is turned on by using the Translator(a_wwMode) constructor
100
101 [[nodiscard]] bool CanReceiveHTML() const;
102 [[nodiscard]] bool NeedStripNewLines() const;
103 [[nodiscard]] bool HandlesCustomWordWrapping() const;
104
105 // members
107 std::uint32_t pad1C; // 1C
108 };
109 static_assert(sizeof(GFxTranslator) == 0x20);
110}
Definition EnumSet.h:9
Definition GFxState.h:9
Definition GFxTranslator.h:29
GFxWStringBuffer * result
Definition GFxTranslator.h:49
std::uint16_t pad1A
Definition GFxTranslator.h:53
std::uint8_t pad19
Definition GFxTranslator.h:52
std::uint32_t pad1C
Definition GFxTranslator.h:54
void SetResultHTML(const wchar_t *a_resultHTML, UPInt a_resultLen=UPINT_MAX)
REX::EnumSet< Flag, std::uint8_t > flags
Definition GFxTranslator.h:51
const char * GetInstanceName() const
Flag
Definition GFxTranslator.h:32
@ kTranslated
Definition GFxTranslator.h:34
@ kNone
Definition GFxTranslator.h:33
@ kResultHTML
Definition GFxTranslator.h:35
@ kResultSourceHTML
Definition GFxTranslator.h:36
const wchar_t * GetKey() const
const char * instanceName
Definition GFxTranslator.h:50
const wchar_t * key
Definition GFxTranslator.h:48
void SetResult(const wchar_t *a_resultText, UPInt a_resultLen=UPINT_MAX)
Definition GFxTranslator.h:11
REX::EnumSet< WordWrappingType, std::uint32_t > wwMode
Definition GFxTranslator.h:106
std::uint32_t pad1C
Definition GFxTranslator.h:107
static constexpr auto RTTI
Definition GFxTranslator.h:13
bool NeedStripNewLines() const
bool CanReceiveHTML() const
static constexpr auto VTABLE
Definition GFxTranslator.h:14
virtual TranslateCap GetCaps() const
~GFxTranslator() override=default
GFxTranslator(WordWrappingType a_wwMode)
virtual void Translate(TranslateInfo *a_translateInfo)
bool HandlesCustomWordWrapping() const
TranslateCap
Definition GFxTranslator.h:22
virtual bool OnWordWrapping(LineFormatDesc *a_desc)
Definition GFxWStringBuffer.h:6
WordWrappingType
Definition GFxWWHelper.h:18
Definition AbsorbEffect.h:6
constexpr REL::ID RTTI_GFxTranslator(static_cast< std::uint64_t >(691055))
constexpr std::array< REL::ID, 1 > VTABLE_GFxTranslator
Definition Offsets_VTABLE.h:11700
std::size_t UPInt
Definition SFTypes.h:5
constexpr UPInt UPINT_MAX
Definition SFTypes.h:6
Definition GFxTranslator.h:61
UPInt proposedWordWrapPoint
Definition GFxTranslator.h:84
std::uint8_t pad39
Definition GFxTranslator.h:81
std::uint16_t pad3A
Definition GFxTranslator.h:82
float currentLineWidth
Definition GFxTranslator.h:77
std::uint32_t pad3C
Definition GFxTranslator.h:83
Alignment
Definition GFxTranslator.h:63
UPInt numCharsInLine
Definition GFxTranslator.h:75
std::uint8_t pad49
Definition GFxTranslator.h:86
float dashSymbolWidth
Definition GFxTranslator.h:79
std::uint16_t pad4A
Definition GFxTranslator.h:87
float visibleRectWidth
Definition GFxTranslator.h:76
UPInt paraTextLen
Definition GFxTranslator.h:72
const float * widths
Definition GFxTranslator.h:73
UPInt lineStartPos
Definition GFxTranslator.h:74
REX::EnumSet< Alignment, std::uint8_t > alignment
Definition GFxTranslator.h:80
const wchar_t * paraText
Definition GFxTranslator.h:71
float lineWidthBeforeWordWrap
Definition GFxTranslator.h:78
bool useHyphenation
Definition GFxTranslator.h:85
std::uint32_t pad4C
Definition GFxTranslator.h:88