draw-character

wayland/sensecap-indicator-gfx/draw-character

Draw a character.
draw-character
@/draw-character
Draw a character.
DEV@/display
A SenseCAP Indicator display.
Xnumber
X coordinate.
Ynumber
Y coordinate.
Charstring
Character to draw.
Colorxod/color/color
Color of character.
BGxod/color/color
Background color.
Sizebyte
Size of character.
UPDpulse
Update.
draw-character
Done
DEV
X
Y
Char
Color
BG
Size
UPD
Donepulse
Pulse on completion.
To use the node in your project you should have the wayland/sensecap-indicator-gfx library installed. Use the “File → Add Library” menu item in XOD IDE if you don’t have it yet. See Using libraries for more info.

C++ implementation

#pragma XOD evaluate_on_pin disable
#pragma XOD evaluate_on_pin enable input_UPD

node {
    void evaluate(Context ctx) {
        // The node responds only if there is an input pulse
        if (!isInputDirty<input_UPD>(ctx))
            return;

        // Get a pointer to the `TFT_eSPI tft` class instance
        auto tft = getValue<input_DEV>(ctx);

        auto xString = getValue<input_Char>(ctx);
        auto it = xString.iterate();

        XColor color24 = getValue<input_Color>(ctx);
        uint16_t color16 = ((color24.r & 0xF8) << 8) | ((color24.g & 0xFC) << 3) | (color24.b >> 3);

        XColor bg24 = getValue<input_BG>(ctx);
        uint16_t bg16 = ((bg24.r & 0xF8) << 8) | ((bg24.g & 0xFC) << 3) | (bg24.b >> 3);

        tft -> setFont(nullptr);

        tft -> setTextSize(getValue<input_Size>(ctx));

        tft -> drawChar(getValue<input_X>(ctx),
                        getValue<input_Y>(ctx),
                        *it,
                        color16,
                        bg16);

        emitValue<output_Done>(ctx, 1);
    }
}