Change: Rename text colour NWidgetPart to SetTextStyle and add font size.
This allows to set both text colour and size for any widget with default drawing.
This commit is contained in:
@@ -89,7 +89,7 @@ enum WidgetType {
|
||||
WPT_DATATIP, ///< Widget part for specifying data and tooltip.
|
||||
WPT_PADDING, ///< Widget part for specifying a padding.
|
||||
WPT_PIPSPACE, ///< Widget part for specifying pre/inter/post space for containers.
|
||||
WPT_TEXTCOLOUR, ///< Widget part for specifying text colour.
|
||||
WPT_TEXTSTYLE, ///< Widget part for specifying text colour.
|
||||
WPT_ALIGNMENT, ///< Widget part for specifying text/image alignment.
|
||||
WPT_ENDCONTAINER, ///< Widget part to denote end of a container.
|
||||
WPT_FUNCTION, ///< Widget part for calling a user function.
|
||||
@@ -320,7 +320,7 @@ public:
|
||||
void SetIndex(int index);
|
||||
void SetDataTip(uint32 widget_data, StringID tool_tip);
|
||||
void SetToolTip(StringID tool_tip);
|
||||
void SetTextColour(TextColour colour);
|
||||
void SetTextStyle(TextColour colour, FontSize size);
|
||||
void SetAlignment(StringAlignment align);
|
||||
|
||||
inline void SetLowered(bool lowered);
|
||||
@@ -342,6 +342,7 @@ public:
|
||||
int scrollbar_index; ///< Index of an attached scrollbar.
|
||||
TextColour highlight_colour; ///< Colour of highlight.
|
||||
TextColour text_colour; ///< Colour of text within widget.
|
||||
FontSize text_size; ///< Size of text within widget.
|
||||
StringAlignment align; ///< Alignment of text/image within widget.
|
||||
};
|
||||
|
||||
@@ -948,8 +949,9 @@ struct NWidgetPartTextLines {
|
||||
* Widget part for storing text colour.
|
||||
* @ingroup NestedWidgetParts
|
||||
*/
|
||||
struct NWidgetPartTextColour {
|
||||
struct NWidgetPartTextStyle {
|
||||
TextColour colour; ///< TextColour for DrawString.
|
||||
FontSize size; ///< Font size of text.
|
||||
};
|
||||
|
||||
/**
|
||||
@@ -981,7 +983,7 @@ struct NWidgetPart {
|
||||
NWidgetPartPaddings padding; ///< Part with paddings.
|
||||
NWidgetPartPIP pip; ///< Part with pre/inter/post spaces.
|
||||
NWidgetPartTextLines text_lines; ///< Part with text line data.
|
||||
NWidgetPartTextColour colour; ///< Part with text colour data.
|
||||
NWidgetPartTextStyle text_style; ///< Part with text style data.
|
||||
NWidgetPartAlignment align; ///< Part with internal alignment.
|
||||
NWidgetFunctionType *func_ptr; ///< Part with a function call.
|
||||
NWidContainerFlags cont_flags; ///< Part with container flags.
|
||||
@@ -1042,16 +1044,18 @@ static inline NWidgetPart SetMinimalTextLines(uint8 lines, uint8 spacing, FontSi
|
||||
}
|
||||
|
||||
/**
|
||||
* Widget part function for setting the text colour.
|
||||
* Widget part function for setting the text style.
|
||||
* @param colour Colour to draw string within widget.
|
||||
* @param size Font size to draw string within widget.
|
||||
* @ingroup NestedWidgetParts
|
||||
*/
|
||||
static inline NWidgetPart SetTextColour(TextColour colour)
|
||||
static inline NWidgetPart SetTextStyle(TextColour colour, FontSize size = FS_NORMAL)
|
||||
{
|
||||
NWidgetPart part;
|
||||
|
||||
part.type = WPT_TEXTCOLOUR;
|
||||
part.u.colour.colour = colour;
|
||||
part.type = WPT_TEXTSTYLE;
|
||||
part.u.text_style.colour = colour;
|
||||
part.u.text_style.size = size;
|
||||
|
||||
return part;
|
||||
}
|
||||
|
Reference in New Issue
Block a user