2025-04-15 21:49:22 +03:00

3.3 KiB
Raw Permalink Blame History

druid.rich_text API

at /druid/custom/rich_text/rich_text.lua

The component that handles a rich text display, allows to custom color, size, font, etc. of the parts of the text

Functions

Fields

init


rich_text:init(text_node, [value])
  • Parameters:
    • text_node (string|node): The text node to make Rich Text
    • [value] (string|nil): The initial text value. Default will be gui.get_text(text_node)

set_text


rich_text:set_text([text])

Set text for Rich Text

  • Parameters:

    • [text] (string|nil): The text to set
  • Returns:

    • words (druid.rich_text.word[]):
    • line_metrics (druid.rich_text.lines_metrics):
  • Example Usage:

-- Color
rich_text:set_text("color=redFoobar/color")
rich_text:set_text("color=1.0,0,0,1.0Foobar/color")
rich_text:set_text("color=#ff0000Foobar/color")
rich_text:set_text("color=#ff0000ffFoobar/color")
-- Shadow
rich_text:set_text("shadow=redFoobar/shadow")
rich_text:set_text("shadow=1.0,0,0,1.0Foobar/shadow")
rich_text:set_text("shadow=#ff0000Foobar/shadow")
rich_text:set_text("shadow=#ff0000ffFoobar/shadow")
-- Outline
rich_text:set_text("outline=redFoobar/outline")
rich_text:set_text("outline=1.0,0,0,1.0Foobar/outline")
rich_text:set_text("outline=#ff0000Foobar/outline")
rich_text:set_text("outline=#ff0000ffFoobar/outline")
-- Font
rich_text:set_text("font=MyCoolFontFoobar/font")
-- Size
rich_text:set_text("size=2Twice as large/size")
-- Line break
rich_text:set_text("br/Insert a line break")
-- No break
rich_text:set_text("nobrPrevent the text from breaking")
-- Image
rich_text:set_text("img=texture:imageDisplay image")
rich_text:set_text("img=texture:image,sizeDisplay image with size")
rich_text:set_text("img=texture:image,width,heightDisplay image with width and height")

get_text


rich_text:get_text()

Get the current text of the rich text

  • Returns:
    • text (string): The current text of the rich text

clear


rich_text:clear()

Clear all created words.

tagged


rich_text:tagged(tag)

Get all words, which has a passed tag.

  • Parameters:

    • tag (string): The tag to get the words for
  • Returns:

    • words (druid.rich_text.word[]): The words with the passed tag

get_words


rich_text:get_words()

Get all current created words, each word is a table that contains the information about the word

  • Returns:
    • `` (druid.rich_text.word[]):

get_line_metric


rich_text:get_line_metric()

Get the current line metrics

  • Returns:
    • lines_metrics (druid.rich_text.lines_metrics): The line metrics of the rich text

Fields

  • root (node): The root node of the rich text

  • text_prefab (node): The text prefab node

  • style (table)