|
roo_display
API Documentation for roo_display
|
Single-line, single-color text label. More...
#include <text_label.h>
Public Member Functions | |
| template<typename String > | |
| TextLabel (const String &label, const Font &font, Color color, FillMode fill_mode=FillMode::kVisible) | |
| Construct from a string-like value (moves into internal storage). | |
| TextLabel (std::string label, const Font &font, Color color, FillMode fill_mode=FillMode::kVisible) | |
| Construct from an owned string. | |
| void | drawTo (const Surface &s) const override |
| Draw this object's content, respecting the fill mode. | |
| Box | extents () const override |
| Return the bounding box encompassing all pixels that need to be drawn. | |
| Box | anchorExtents () const override |
| Return the bounds used for alignment. | |
| const Font & | font () const |
| Return the font used by the label. | |
| const GlyphMetrics & | metrics () const |
| Return cached string metrics. | |
| const std::string & | label () const |
| Return the label text. | |
| const Color | color () const |
| Return the label color. | |
| const FillMode | fill_mode () const |
| Return the fill mode. | |
| void | setColor (Color color) |
| Set the label color. | |
| void | setFillMode (FillMode fill_mode) |
| Set the fill mode. | |
Public Member Functions inherited from roo_display::Drawable | |
| virtual | ~Drawable () |
Additional Inherited Members | |
Static Public Member Functions inherited from roo_display::Drawable | |
| static const Drawable * | Empty () |
| A singleton representing a no-op drawable with no bounding box. | |
Single-line, single-color text label.
Extents have height based on the font size, not the specific text. The origin is at the text baseline, and horizontally affected by the text bearing.
When using smooth fonts, you should generally specify bgcolor when drawing text labels, even over pre-filled solid backgrounds. This is because many device drivers don't support alpha blending, which is required for smooth font edges. Exceptions: offscreen/double-buffered devices, or drivers that do support alpha blending, when you want to preserve the existing non-solid background.
For changing text fields, wrap TextLabel in a Tile to reduce flicker.
See also StringViewLabel.
Definition at line 32 of file text_label.h.
|
inline |
Construct from a string-like value (moves into internal storage).
Definition at line 36 of file text_label.h.
|
inline |
Construct from an owned string.
Definition at line 41 of file text_label.h.
|
inlineoverridevirtual |
Return the bounds used for alignment.
Defaults to extents(). Some drawables (notably text labels) may want different alignment bounds.
This method is called during a transaction and must not block or perform I/O.
Reimplemented from roo_display::Drawable.
Definition at line 59 of file text_label.h.
References roo_display::GlyphMetrics::advance(), roo_display::ascent, roo_display::descent, font(), roo_display::linegap, and metrics().
Return the label color.
Definition at line 71 of file text_label.h.
Referenced by drawTo(), roo_display::ClippedTextLabel::drawTo(), and setColor().
Draw this object's content, respecting the fill mode.
If s.fill_mode() == FillMode::kExtents, the method must fill the entire (clipped) extents() rectangle (using s.bgcolor() for transparent parts).
The default implementation fills the clipped extents() rectangle with bgcolor and then calls drawInteriorTo(). That can cause flicker, so override this method if a better implementation is possible.
The implementation must respect surface parameters, particularly clip_box(), and must not draw outside it. The surface clip box is pre-clipped to fit within this drawable's extents().
Reimplemented from roo_display::Drawable.
Definition at line 49 of file text_label.h.
References color(), roo_display::Font::drawHorizontalString(), fill_mode(), font(), roo_display::kExtents, and label().
|
inlineoverridevirtual |
Return the bounding box encompassing all pixels that need to be drawn.
This method is called during a transaction and must not block or perform I/O.
Implements roo_display::Drawable.
Definition at line 57 of file text_label.h.
References roo_display::GlyphMetrics::screen_extents().
Return the fill mode.
Definition at line 73 of file text_label.h.
Referenced by drawTo(), roo_display::ClippedTextLabel::drawTo(), and setFillMode().
Return the font used by the label.
Definition at line 65 of file text_label.h.
Referenced by anchorExtents(), drawTo(), and roo_display::ClippedTextLabel::drawTo().
|
inline |
Return the label text.
Definition at line 69 of file text_label.h.
Referenced by drawTo(), and roo_display::ClippedTextLabel::drawTo().
|
inline |
Return cached string metrics.
Definition at line 67 of file text_label.h.
Referenced by anchorExtents(), and roo_display::ClippedTextLabel::anchorExtents().