class_richtextlabel.rst 166 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264
  1. :github_url: hide
  2. .. DO NOT EDIT THIS FILE!!!
  3. .. Generated automatically from Godot engine sources.
  4. .. Generator: https://github.com/godotengine/godot/tree/4.2/doc/tools/make_rst.py.
  5. .. XML source: https://github.com/godotengine/godot/tree/4.2/doc/classes/RichTextLabel.xml.
  6. .. _class_RichTextLabel:
  7. RichTextLabel
  8. =============
  9. **Inherits:** :ref:`Control<class_Control>` **<** :ref:`CanvasItem<class_CanvasItem>` **<** :ref:`Node<class_Node>` **<** :ref:`Object<class_Object>`
  10. A control for displaying text that can contain different font styles, images, and basic formatting.
  11. .. rst-class:: classref-introduction-group
  12. Description
  13. -----------
  14. A control for displaying text that can contain custom fonts, images, and basic formatting. **RichTextLabel** manages these as an internal tag stack. It also adapts itself to given width/heights.
  15. \ **Note:** Assignments to :ref:`text<class_RichTextLabel_property_text>` clear the tag stack and reconstruct it from the property's contents. Any edits made to :ref:`text<class_RichTextLabel_property_text>` will erase previous edits made from other manual sources such as :ref:`append_text<class_RichTextLabel_method_append_text>` and the ``push_*`` / :ref:`pop<class_RichTextLabel_method_pop>` methods.
  16. \ **Note:** RichTextLabel doesn't support entangled BBCode tags. For example, instead of using ``[b]bold[i]bold italic[/b]italic[/i]``, use ``[b]bold[i]bold italic[/i][/b][i]italic[/i]``.
  17. \ **Note:** ``push_*/pop_*`` functions won't affect BBCode.
  18. \ **Note:** Unlike :ref:`Label<class_Label>`, **RichTextLabel** doesn't have a *property* to horizontally align text to the center. Instead, enable :ref:`bbcode_enabled<class_RichTextLabel_property_bbcode_enabled>` and surround the text in a ``[center]`` tag as follows: ``[center]Example[/center]``. There is currently no built-in way to vertically align text either, but this can be emulated by relying on anchors/containers and the :ref:`fit_content<class_RichTextLabel_property_fit_content>` property.
  19. .. rst-class:: classref-introduction-group
  20. Tutorials
  21. ---------
  22. - :doc:`BBCode in RichTextLabel <../tutorials/ui/bbcode_in_richtextlabel>`
  23. - `GUI Rich Text/BBcode Demo <https://godotengine.org/asset-library/asset/132>`__
  24. - `OS Test Demo <https://godotengine.org/asset-library/asset/677>`__
  25. .. rst-class:: classref-reftable-group
  26. Properties
  27. ----------
  28. .. table::
  29. :widths: auto
  30. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  31. | :ref:`AutowrapMode<enum_TextServer_AutowrapMode>` | :ref:`autowrap_mode<class_RichTextLabel_property_autowrap_mode>` | ``3`` |
  32. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  33. | :ref:`bool<class_bool>` | :ref:`bbcode_enabled<class_RichTextLabel_property_bbcode_enabled>` | ``false`` |
  34. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  35. | :ref:`bool<class_bool>` | clip_contents | ``true`` (overrides :ref:`Control<class_Control_property_clip_contents>`) |
  36. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  37. | :ref:`bool<class_bool>` | :ref:`context_menu_enabled<class_RichTextLabel_property_context_menu_enabled>` | ``false`` |
  38. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  39. | :ref:`Array<class_Array>` | :ref:`custom_effects<class_RichTextLabel_property_custom_effects>` | ``[]`` |
  40. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  41. | :ref:`bool<class_bool>` | :ref:`deselect_on_focus_loss_enabled<class_RichTextLabel_property_deselect_on_focus_loss_enabled>` | ``true`` |
  42. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  43. | :ref:`bool<class_bool>` | :ref:`drag_and_drop_selection_enabled<class_RichTextLabel_property_drag_and_drop_selection_enabled>` | ``true`` |
  44. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  45. | :ref:`bool<class_bool>` | :ref:`fit_content<class_RichTextLabel_property_fit_content>` | ``false`` |
  46. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  47. | :ref:`bool<class_bool>` | :ref:`hint_underlined<class_RichTextLabel_property_hint_underlined>` | ``true`` |
  48. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  49. | :ref:`String<class_String>` | :ref:`language<class_RichTextLabel_property_language>` | ``""`` |
  50. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  51. | :ref:`bool<class_bool>` | :ref:`meta_underlined<class_RichTextLabel_property_meta_underlined>` | ``true`` |
  52. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  53. | :ref:`int<class_int>` | :ref:`progress_bar_delay<class_RichTextLabel_property_progress_bar_delay>` | ``1000`` |
  54. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  55. | :ref:`bool<class_bool>` | :ref:`scroll_active<class_RichTextLabel_property_scroll_active>` | ``true`` |
  56. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  57. | :ref:`bool<class_bool>` | :ref:`scroll_following<class_RichTextLabel_property_scroll_following>` | ``false`` |
  58. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  59. | :ref:`bool<class_bool>` | :ref:`selection_enabled<class_RichTextLabel_property_selection_enabled>` | ``false`` |
  60. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  61. | :ref:`bool<class_bool>` | :ref:`shortcut_keys_enabled<class_RichTextLabel_property_shortcut_keys_enabled>` | ``true`` |
  62. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  63. | :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` | :ref:`structured_text_bidi_override<class_RichTextLabel_property_structured_text_bidi_override>` | ``0`` |
  64. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  65. | :ref:`Array<class_Array>` | :ref:`structured_text_bidi_override_options<class_RichTextLabel_property_structured_text_bidi_override_options>` | ``[]`` |
  66. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  67. | :ref:`int<class_int>` | :ref:`tab_size<class_RichTextLabel_property_tab_size>` | ``4`` |
  68. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  69. | :ref:`String<class_String>` | :ref:`text<class_RichTextLabel_property_text>` | ``""`` |
  70. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  71. | :ref:`TextDirection<enum_Control_TextDirection>` | :ref:`text_direction<class_RichTextLabel_property_text_direction>` | ``0`` |
  72. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  73. | :ref:`bool<class_bool>` | :ref:`threaded<class_RichTextLabel_property_threaded>` | ``false`` |
  74. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  75. | :ref:`int<class_int>` | :ref:`visible_characters<class_RichTextLabel_property_visible_characters>` | ``-1`` |
  76. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  77. | :ref:`VisibleCharactersBehavior<enum_TextServer_VisibleCharactersBehavior>` | :ref:`visible_characters_behavior<class_RichTextLabel_property_visible_characters_behavior>` | ``0`` |
  78. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  79. | :ref:`float<class_float>` | :ref:`visible_ratio<class_RichTextLabel_property_visible_ratio>` | ``1.0`` |
  80. +-----------------------------------------------------------------------------+------------------------------------------------------------------------------------------------------------------+---------------------------------------------------------------------------+
  81. .. rst-class:: classref-reftable-group
  82. Methods
  83. -------
  84. .. table::
  85. :widths: auto
  86. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  87. | void | :ref:`add_image<class_RichTextLabel_method_add_image>` **(** :ref:`Texture2D<class_Texture2D>` image, :ref:`int<class_int>` width=0, :ref:`int<class_int>` height=0, :ref:`Color<class_Color>` color=Color(1, 1, 1, 1), :ref:`InlineAlignment<enum_@GlobalScope_InlineAlignment>` inline_align=5, :ref:`Rect2<class_Rect2>` region=Rect2(0, 0, 0, 0), :ref:`Variant<class_Variant>` key=null, :ref:`bool<class_bool>` pad=false, :ref:`String<class_String>` tooltip="", :ref:`bool<class_bool>` size_in_percent=false **)** |
  88. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  89. | void | :ref:`add_text<class_RichTextLabel_method_add_text>` **(** :ref:`String<class_String>` text **)** |
  90. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  91. | void | :ref:`append_text<class_RichTextLabel_method_append_text>` **(** :ref:`String<class_String>` bbcode **)** |
  92. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  93. | void | :ref:`clear<class_RichTextLabel_method_clear>` **(** **)** |
  94. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  95. | void | :ref:`deselect<class_RichTextLabel_method_deselect>` **(** **)** |
  96. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  97. | :ref:`int<class_int>` | :ref:`get_character_line<class_RichTextLabel_method_get_character_line>` **(** :ref:`int<class_int>` character **)** |
  98. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  99. | :ref:`int<class_int>` | :ref:`get_character_paragraph<class_RichTextLabel_method_get_character_paragraph>` **(** :ref:`int<class_int>` character **)** |
  100. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  101. | :ref:`int<class_int>` | :ref:`get_content_height<class_RichTextLabel_method_get_content_height>` **(** **)** |const| |
  102. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  103. | :ref:`int<class_int>` | :ref:`get_content_width<class_RichTextLabel_method_get_content_width>` **(** **)** |const| |
  104. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  105. | :ref:`int<class_int>` | :ref:`get_line_count<class_RichTextLabel_method_get_line_count>` **(** **)** |const| |
  106. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  107. | :ref:`float<class_float>` | :ref:`get_line_offset<class_RichTextLabel_method_get_line_offset>` **(** :ref:`int<class_int>` line **)** |
  108. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  109. | :ref:`PopupMenu<class_PopupMenu>` | :ref:`get_menu<class_RichTextLabel_method_get_menu>` **(** **)** |const| |
  110. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  111. | :ref:`int<class_int>` | :ref:`get_paragraph_count<class_RichTextLabel_method_get_paragraph_count>` **(** **)** |const| |
  112. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  113. | :ref:`float<class_float>` | :ref:`get_paragraph_offset<class_RichTextLabel_method_get_paragraph_offset>` **(** :ref:`int<class_int>` paragraph **)** |
  114. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  115. | :ref:`String<class_String>` | :ref:`get_parsed_text<class_RichTextLabel_method_get_parsed_text>` **(** **)** |const| |
  116. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  117. | :ref:`String<class_String>` | :ref:`get_selected_text<class_RichTextLabel_method_get_selected_text>` **(** **)** |const| |
  118. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  119. | :ref:`int<class_int>` | :ref:`get_selection_from<class_RichTextLabel_method_get_selection_from>` **(** **)** |const| |
  120. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  121. | :ref:`int<class_int>` | :ref:`get_selection_to<class_RichTextLabel_method_get_selection_to>` **(** **)** |const| |
  122. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  123. | :ref:`int<class_int>` | :ref:`get_total_character_count<class_RichTextLabel_method_get_total_character_count>` **(** **)** |const| |
  124. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  125. | :ref:`VScrollBar<class_VScrollBar>` | :ref:`get_v_scroll_bar<class_RichTextLabel_method_get_v_scroll_bar>` **(** **)** |
  126. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  127. | :ref:`int<class_int>` | :ref:`get_visible_line_count<class_RichTextLabel_method_get_visible_line_count>` **(** **)** |const| |
  128. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  129. | :ref:`int<class_int>` | :ref:`get_visible_paragraph_count<class_RichTextLabel_method_get_visible_paragraph_count>` **(** **)** |const| |
  130. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  131. | void | :ref:`install_effect<class_RichTextLabel_method_install_effect>` **(** :ref:`Variant<class_Variant>` effect **)** |
  132. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  133. | :ref:`bool<class_bool>` | :ref:`is_menu_visible<class_RichTextLabel_method_is_menu_visible>` **(** **)** |const| |
  134. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  135. | :ref:`bool<class_bool>` | :ref:`is_ready<class_RichTextLabel_method_is_ready>` **(** **)** |const| |
  136. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  137. | void | :ref:`menu_option<class_RichTextLabel_method_menu_option>` **(** :ref:`int<class_int>` option **)** |
  138. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  139. | void | :ref:`newline<class_RichTextLabel_method_newline>` **(** **)** |
  140. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  141. | void | :ref:`parse_bbcode<class_RichTextLabel_method_parse_bbcode>` **(** :ref:`String<class_String>` bbcode **)** |
  142. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  143. | :ref:`Dictionary<class_Dictionary>` | :ref:`parse_expressions_for_values<class_RichTextLabel_method_parse_expressions_for_values>` **(** :ref:`PackedStringArray<class_PackedStringArray>` expressions **)** |
  144. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  145. | void | :ref:`pop<class_RichTextLabel_method_pop>` **(** **)** |
  146. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  147. | void | :ref:`pop_all<class_RichTextLabel_method_pop_all>` **(** **)** |
  148. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  149. | void | :ref:`pop_context<class_RichTextLabel_method_pop_context>` **(** **)** |
  150. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  151. | void | :ref:`push_bgcolor<class_RichTextLabel_method_push_bgcolor>` **(** :ref:`Color<class_Color>` bgcolor **)** |
  152. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  153. | void | :ref:`push_bold<class_RichTextLabel_method_push_bold>` **(** **)** |
  154. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  155. | void | :ref:`push_bold_italics<class_RichTextLabel_method_push_bold_italics>` **(** **)** |
  156. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  157. | void | :ref:`push_cell<class_RichTextLabel_method_push_cell>` **(** **)** |
  158. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  159. | void | :ref:`push_color<class_RichTextLabel_method_push_color>` **(** :ref:`Color<class_Color>` color **)** |
  160. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  161. | void | :ref:`push_context<class_RichTextLabel_method_push_context>` **(** **)** |
  162. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  163. | void | :ref:`push_customfx<class_RichTextLabel_method_push_customfx>` **(** :ref:`RichTextEffect<class_RichTextEffect>` effect, :ref:`Dictionary<class_Dictionary>` env **)** |
  164. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  165. | void | :ref:`push_dropcap<class_RichTextLabel_method_push_dropcap>` **(** :ref:`String<class_String>` string, :ref:`Font<class_Font>` font, :ref:`int<class_int>` size, :ref:`Rect2<class_Rect2>` dropcap_margins=Rect2(0, 0, 0, 0), :ref:`Color<class_Color>` color=Color(1, 1, 1, 1), :ref:`int<class_int>` outline_size=0, :ref:`Color<class_Color>` outline_color=Color(0, 0, 0, 0) **)** |
  166. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  167. | void | :ref:`push_fgcolor<class_RichTextLabel_method_push_fgcolor>` **(** :ref:`Color<class_Color>` fgcolor **)** |
  168. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  169. | void | :ref:`push_font<class_RichTextLabel_method_push_font>` **(** :ref:`Font<class_Font>` font, :ref:`int<class_int>` font_size=0 **)** |
  170. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  171. | void | :ref:`push_font_size<class_RichTextLabel_method_push_font_size>` **(** :ref:`int<class_int>` font_size **)** |
  172. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  173. | void | :ref:`push_hint<class_RichTextLabel_method_push_hint>` **(** :ref:`String<class_String>` description **)** |
  174. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  175. | void | :ref:`push_indent<class_RichTextLabel_method_push_indent>` **(** :ref:`int<class_int>` level **)** |
  176. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  177. | void | :ref:`push_italics<class_RichTextLabel_method_push_italics>` **(** **)** |
  178. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  179. | void | :ref:`push_language<class_RichTextLabel_method_push_language>` **(** :ref:`String<class_String>` language **)** |
  180. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  181. | void | :ref:`push_list<class_RichTextLabel_method_push_list>` **(** :ref:`int<class_int>` level, :ref:`ListType<enum_RichTextLabel_ListType>` type, :ref:`bool<class_bool>` capitalize, :ref:`String<class_String>` bullet="•" **)** |
  182. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  183. | void | :ref:`push_meta<class_RichTextLabel_method_push_meta>` **(** :ref:`Variant<class_Variant>` data **)** |
  184. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  185. | void | :ref:`push_mono<class_RichTextLabel_method_push_mono>` **(** **)** |
  186. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  187. | void | :ref:`push_normal<class_RichTextLabel_method_push_normal>` **(** **)** |
  188. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  189. | void | :ref:`push_outline_color<class_RichTextLabel_method_push_outline_color>` **(** :ref:`Color<class_Color>` color **)** |
  190. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  191. | void | :ref:`push_outline_size<class_RichTextLabel_method_push_outline_size>` **(** :ref:`int<class_int>` outline_size **)** |
  192. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  193. | void | :ref:`push_paragraph<class_RichTextLabel_method_push_paragraph>` **(** :ref:`HorizontalAlignment<enum_@GlobalScope_HorizontalAlignment>` alignment, :ref:`TextDirection<enum_Control_TextDirection>` base_direction=0, :ref:`String<class_String>` language="", :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` st_parser=0, |bitfield|\<:ref:`JustificationFlag<enum_TextServer_JustificationFlag>`\> justification_flags=163, :ref:`PackedFloat32Array<class_PackedFloat32Array>` tab_stops=PackedFloat32Array() **)** |
  194. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  195. | void | :ref:`push_strikethrough<class_RichTextLabel_method_push_strikethrough>` **(** **)** |
  196. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  197. | void | :ref:`push_table<class_RichTextLabel_method_push_table>` **(** :ref:`int<class_int>` columns, :ref:`InlineAlignment<enum_@GlobalScope_InlineAlignment>` inline_align=0, :ref:`int<class_int>` align_to_row=-1 **)** |
  198. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  199. | void | :ref:`push_underline<class_RichTextLabel_method_push_underline>` **(** **)** |
  200. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  201. | :ref:`bool<class_bool>` | :ref:`remove_paragraph<class_RichTextLabel_method_remove_paragraph>` **(** :ref:`int<class_int>` paragraph **)** |
  202. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  203. | void | :ref:`scroll_to_line<class_RichTextLabel_method_scroll_to_line>` **(** :ref:`int<class_int>` line **)** |
  204. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  205. | void | :ref:`scroll_to_paragraph<class_RichTextLabel_method_scroll_to_paragraph>` **(** :ref:`int<class_int>` paragraph **)** |
  206. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  207. | void | :ref:`scroll_to_selection<class_RichTextLabel_method_scroll_to_selection>` **(** **)** |
  208. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  209. | void | :ref:`select_all<class_RichTextLabel_method_select_all>` **(** **)** |
  210. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  211. | void | :ref:`set_cell_border_color<class_RichTextLabel_method_set_cell_border_color>` **(** :ref:`Color<class_Color>` color **)** |
  212. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  213. | void | :ref:`set_cell_padding<class_RichTextLabel_method_set_cell_padding>` **(** :ref:`Rect2<class_Rect2>` padding **)** |
  214. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  215. | void | :ref:`set_cell_row_background_color<class_RichTextLabel_method_set_cell_row_background_color>` **(** :ref:`Color<class_Color>` odd_row_bg, :ref:`Color<class_Color>` even_row_bg **)** |
  216. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  217. | void | :ref:`set_cell_size_override<class_RichTextLabel_method_set_cell_size_override>` **(** :ref:`Vector2<class_Vector2>` min_size, :ref:`Vector2<class_Vector2>` max_size **)** |
  218. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  219. | void | :ref:`set_table_column_expand<class_RichTextLabel_method_set_table_column_expand>` **(** :ref:`int<class_int>` column, :ref:`bool<class_bool>` expand, :ref:`int<class_int>` ratio=1 **)** |
  220. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  221. | void | :ref:`update_image<class_RichTextLabel_method_update_image>` **(** :ref:`Variant<class_Variant>` key, |bitfield|\<:ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>`\> mask, :ref:`Texture2D<class_Texture2D>` image, :ref:`int<class_int>` width=0, :ref:`int<class_int>` height=0, :ref:`Color<class_Color>` color=Color(1, 1, 1, 1), :ref:`InlineAlignment<enum_@GlobalScope_InlineAlignment>` inline_align=5, :ref:`Rect2<class_Rect2>` region=Rect2(0, 0, 0, 0), :ref:`bool<class_bool>` pad=false, :ref:`String<class_String>` tooltip="", :ref:`bool<class_bool>` size_in_percent=false **)** |
  222. +-------------------------------------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  223. .. rst-class:: classref-reftable-group
  224. Theme Properties
  225. ----------------
  226. .. table::
  227. :widths: auto
  228. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  229. | :ref:`Color<class_Color>` | :ref:`default_color<class_RichTextLabel_theme_color_default_color>` | ``Color(1, 1, 1, 1)`` |
  230. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  231. | :ref:`Color<class_Color>` | :ref:`font_outline_color<class_RichTextLabel_theme_color_font_outline_color>` | ``Color(1, 1, 1, 1)`` |
  232. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  233. | :ref:`Color<class_Color>` | :ref:`font_selected_color<class_RichTextLabel_theme_color_font_selected_color>` | ``Color(0, 0, 0, 0)`` |
  234. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  235. | :ref:`Color<class_Color>` | :ref:`font_shadow_color<class_RichTextLabel_theme_color_font_shadow_color>` | ``Color(0, 0, 0, 0)`` |
  236. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  237. | :ref:`Color<class_Color>` | :ref:`selection_color<class_RichTextLabel_theme_color_selection_color>` | ``Color(0.1, 0.1, 1, 0.8)`` |
  238. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  239. | :ref:`Color<class_Color>` | :ref:`table_border<class_RichTextLabel_theme_color_table_border>` | ``Color(0, 0, 0, 0)`` |
  240. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  241. | :ref:`Color<class_Color>` | :ref:`table_even_row_bg<class_RichTextLabel_theme_color_table_even_row_bg>` | ``Color(0, 0, 0, 0)`` |
  242. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  243. | :ref:`Color<class_Color>` | :ref:`table_odd_row_bg<class_RichTextLabel_theme_color_table_odd_row_bg>` | ``Color(0, 0, 0, 0)`` |
  244. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  245. | :ref:`int<class_int>` | :ref:`line_separation<class_RichTextLabel_theme_constant_line_separation>` | ``0`` |
  246. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  247. | :ref:`int<class_int>` | :ref:`outline_size<class_RichTextLabel_theme_constant_outline_size>` | ``0`` |
  248. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  249. | :ref:`int<class_int>` | :ref:`shadow_offset_x<class_RichTextLabel_theme_constant_shadow_offset_x>` | ``1`` |
  250. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  251. | :ref:`int<class_int>` | :ref:`shadow_offset_y<class_RichTextLabel_theme_constant_shadow_offset_y>` | ``1`` |
  252. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  253. | :ref:`int<class_int>` | :ref:`shadow_outline_size<class_RichTextLabel_theme_constant_shadow_outline_size>` | ``1`` |
  254. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  255. | :ref:`int<class_int>` | :ref:`table_h_separation<class_RichTextLabel_theme_constant_table_h_separation>` | ``3`` |
  256. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  257. | :ref:`int<class_int>` | :ref:`table_v_separation<class_RichTextLabel_theme_constant_table_v_separation>` | ``3`` |
  258. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  259. | :ref:`int<class_int>` | :ref:`text_highlight_h_padding<class_RichTextLabel_theme_constant_text_highlight_h_padding>` | ``3`` |
  260. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  261. | :ref:`int<class_int>` | :ref:`text_highlight_v_padding<class_RichTextLabel_theme_constant_text_highlight_v_padding>` | ``3`` |
  262. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  263. | :ref:`Font<class_Font>` | :ref:`bold_font<class_RichTextLabel_theme_font_bold_font>` | |
  264. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  265. | :ref:`Font<class_Font>` | :ref:`bold_italics_font<class_RichTextLabel_theme_font_bold_italics_font>` | |
  266. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  267. | :ref:`Font<class_Font>` | :ref:`italics_font<class_RichTextLabel_theme_font_italics_font>` | |
  268. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  269. | :ref:`Font<class_Font>` | :ref:`mono_font<class_RichTextLabel_theme_font_mono_font>` | |
  270. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  271. | :ref:`Font<class_Font>` | :ref:`normal_font<class_RichTextLabel_theme_font_normal_font>` | |
  272. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  273. | :ref:`int<class_int>` | :ref:`bold_font_size<class_RichTextLabel_theme_font_size_bold_font_size>` | |
  274. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  275. | :ref:`int<class_int>` | :ref:`bold_italics_font_size<class_RichTextLabel_theme_font_size_bold_italics_font_size>` | |
  276. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  277. | :ref:`int<class_int>` | :ref:`italics_font_size<class_RichTextLabel_theme_font_size_italics_font_size>` | |
  278. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  279. | :ref:`int<class_int>` | :ref:`mono_font_size<class_RichTextLabel_theme_font_size_mono_font_size>` | |
  280. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  281. | :ref:`int<class_int>` | :ref:`normal_font_size<class_RichTextLabel_theme_font_size_normal_font_size>` | |
  282. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  283. | :ref:`StyleBox<class_StyleBox>` | :ref:`focus<class_RichTextLabel_theme_style_focus>` | |
  284. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  285. | :ref:`StyleBox<class_StyleBox>` | :ref:`normal<class_RichTextLabel_theme_style_normal>` | |
  286. +---------------------------------+----------------------------------------------------------------------------------------------+-----------------------------+
  287. .. rst-class:: classref-section-separator
  288. ----
  289. .. rst-class:: classref-descriptions-group
  290. Signals
  291. -------
  292. .. _class_RichTextLabel_signal_finished:
  293. .. rst-class:: classref-signal
  294. **finished** **(** **)**
  295. Triggered when the document is fully loaded.
  296. .. rst-class:: classref-item-separator
  297. ----
  298. .. _class_RichTextLabel_signal_meta_clicked:
  299. .. rst-class:: classref-signal
  300. **meta_clicked** **(** :ref:`Variant<class_Variant>` meta **)**
  301. Triggered when the user clicks on content between meta (URL) tags. If the meta is defined in BBCode, e.g. ``[url={"key": "value"}]Text[/url]``, then the parameter for this signal will always be a :ref:`String<class_String>` type. If a particular type or an object is desired, the :ref:`push_meta<class_RichTextLabel_method_push_meta>` method must be used to manually insert the data into the tag stack. Alternatively, you can convert the :ref:`String<class_String>` input to the desired type based on its contents (such as calling :ref:`JSON.parse<class_JSON_method_parse>` on it).
  302. For example, the following method can be connected to :ref:`meta_clicked<class_RichTextLabel_signal_meta_clicked>` to open clicked URLs using the user's default web browser:
  303. .. tabs::
  304. .. code-tab:: gdscript
  305. # This assumes RichTextLabel's `meta_clicked` signal was connected to
  306. # the function below using the signal connection dialog.
  307. func _richtextlabel_on_meta_clicked(meta):
  308. # `meta` is of Variant type, so convert it to a String to avoid script errors at run-time.
  309. OS.shell_open(str(meta))
  310. .. rst-class:: classref-item-separator
  311. ----
  312. .. _class_RichTextLabel_signal_meta_hover_ended:
  313. .. rst-class:: classref-signal
  314. **meta_hover_ended** **(** :ref:`Variant<class_Variant>` meta **)**
  315. Triggers when the mouse exits a meta tag.
  316. .. rst-class:: classref-item-separator
  317. ----
  318. .. _class_RichTextLabel_signal_meta_hover_started:
  319. .. rst-class:: classref-signal
  320. **meta_hover_started** **(** :ref:`Variant<class_Variant>` meta **)**
  321. Triggers when the mouse enters a meta tag.
  322. .. rst-class:: classref-section-separator
  323. ----
  324. .. rst-class:: classref-descriptions-group
  325. Enumerations
  326. ------------
  327. .. _enum_RichTextLabel_ListType:
  328. .. rst-class:: classref-enumeration
  329. enum **ListType**:
  330. .. _class_RichTextLabel_constant_LIST_NUMBERS:
  331. .. rst-class:: classref-enumeration-constant
  332. :ref:`ListType<enum_RichTextLabel_ListType>` **LIST_NUMBERS** = ``0``
  333. Each list item has a number marker.
  334. .. _class_RichTextLabel_constant_LIST_LETTERS:
  335. .. rst-class:: classref-enumeration-constant
  336. :ref:`ListType<enum_RichTextLabel_ListType>` **LIST_LETTERS** = ``1``
  337. Each list item has a letter marker.
  338. .. _class_RichTextLabel_constant_LIST_ROMAN:
  339. .. rst-class:: classref-enumeration-constant
  340. :ref:`ListType<enum_RichTextLabel_ListType>` **LIST_ROMAN** = ``2``
  341. Each list item has a roman number marker.
  342. .. _class_RichTextLabel_constant_LIST_DOTS:
  343. .. rst-class:: classref-enumeration-constant
  344. :ref:`ListType<enum_RichTextLabel_ListType>` **LIST_DOTS** = ``3``
  345. Each list item has a filled circle marker.
  346. .. rst-class:: classref-item-separator
  347. ----
  348. .. _enum_RichTextLabel_MenuItems:
  349. .. rst-class:: classref-enumeration
  350. enum **MenuItems**:
  351. .. _class_RichTextLabel_constant_MENU_COPY:
  352. .. rst-class:: classref-enumeration-constant
  353. :ref:`MenuItems<enum_RichTextLabel_MenuItems>` **MENU_COPY** = ``0``
  354. Copies the selected text.
  355. .. _class_RichTextLabel_constant_MENU_SELECT_ALL:
  356. .. rst-class:: classref-enumeration-constant
  357. :ref:`MenuItems<enum_RichTextLabel_MenuItems>` **MENU_SELECT_ALL** = ``1``
  358. Selects the whole **RichTextLabel** text.
  359. .. _class_RichTextLabel_constant_MENU_MAX:
  360. .. rst-class:: classref-enumeration-constant
  361. :ref:`MenuItems<enum_RichTextLabel_MenuItems>` **MENU_MAX** = ``2``
  362. Represents the size of the :ref:`MenuItems<enum_RichTextLabel_MenuItems>` enum.
  363. .. rst-class:: classref-item-separator
  364. ----
  365. .. _enum_RichTextLabel_ImageUpdateMask:
  366. .. rst-class:: classref-enumeration
  367. flags **ImageUpdateMask**:
  368. .. _class_RichTextLabel_constant_UPDATE_TEXTURE:
  369. .. rst-class:: classref-enumeration-constant
  370. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_TEXTURE** = ``1``
  371. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image texture.
  372. .. _class_RichTextLabel_constant_UPDATE_SIZE:
  373. .. rst-class:: classref-enumeration-constant
  374. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_SIZE** = ``2``
  375. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image size.
  376. .. _class_RichTextLabel_constant_UPDATE_COLOR:
  377. .. rst-class:: classref-enumeration-constant
  378. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_COLOR** = ``4``
  379. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image color.
  380. .. _class_RichTextLabel_constant_UPDATE_ALIGNMENT:
  381. .. rst-class:: classref-enumeration-constant
  382. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_ALIGNMENT** = ``8``
  383. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image inline alignment.
  384. .. _class_RichTextLabel_constant_UPDATE_REGION:
  385. .. rst-class:: classref-enumeration-constant
  386. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_REGION** = ``16``
  387. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image texture region.
  388. .. _class_RichTextLabel_constant_UPDATE_PAD:
  389. .. rst-class:: classref-enumeration-constant
  390. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_PAD** = ``32``
  391. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image padding.
  392. .. _class_RichTextLabel_constant_UPDATE_TOOLTIP:
  393. .. rst-class:: classref-enumeration-constant
  394. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_TOOLTIP** = ``64``
  395. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image tooltip.
  396. .. _class_RichTextLabel_constant_UPDATE_WIDTH_IN_PERCENT:
  397. .. rst-class:: classref-enumeration-constant
  398. :ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>` **UPDATE_WIDTH_IN_PERCENT** = ``128``
  399. If this bit is set, :ref:`update_image<class_RichTextLabel_method_update_image>` changes image width from/to percents.
  400. .. rst-class:: classref-section-separator
  401. ----
  402. .. rst-class:: classref-descriptions-group
  403. Property Descriptions
  404. ---------------------
  405. .. _class_RichTextLabel_property_autowrap_mode:
  406. .. rst-class:: classref-property
  407. :ref:`AutowrapMode<enum_TextServer_AutowrapMode>` **autowrap_mode** = ``3``
  408. .. rst-class:: classref-property-setget
  409. - void **set_autowrap_mode** **(** :ref:`AutowrapMode<enum_TextServer_AutowrapMode>` value **)**
  410. - :ref:`AutowrapMode<enum_TextServer_AutowrapMode>` **get_autowrap_mode** **(** **)**
  411. If set to something other than :ref:`TextServer.AUTOWRAP_OFF<class_TextServer_constant_AUTOWRAP_OFF>`, the text gets wrapped inside the node's bounding rectangle. To see how each mode behaves, see :ref:`AutowrapMode<enum_TextServer_AutowrapMode>`.
  412. .. rst-class:: classref-item-separator
  413. ----
  414. .. _class_RichTextLabel_property_bbcode_enabled:
  415. .. rst-class:: classref-property
  416. :ref:`bool<class_bool>` **bbcode_enabled** = ``false``
  417. .. rst-class:: classref-property-setget
  418. - void **set_use_bbcode** **(** :ref:`bool<class_bool>` value **)**
  419. - :ref:`bool<class_bool>` **is_using_bbcode** **(** **)**
  420. If ``true``, the label uses BBCode formatting.
  421. .. rst-class:: classref-item-separator
  422. ----
  423. .. _class_RichTextLabel_property_context_menu_enabled:
  424. .. rst-class:: classref-property
  425. :ref:`bool<class_bool>` **context_menu_enabled** = ``false``
  426. .. rst-class:: classref-property-setget
  427. - void **set_context_menu_enabled** **(** :ref:`bool<class_bool>` value **)**
  428. - :ref:`bool<class_bool>` **is_context_menu_enabled** **(** **)**
  429. If ``true``, a right-click displays the context menu.
  430. .. rst-class:: classref-item-separator
  431. ----
  432. .. _class_RichTextLabel_property_custom_effects:
  433. .. rst-class:: classref-property
  434. :ref:`Array<class_Array>` **custom_effects** = ``[]``
  435. .. rst-class:: classref-property-setget
  436. - void **set_effects** **(** :ref:`Array<class_Array>` value **)**
  437. - :ref:`Array<class_Array>` **get_effects** **(** **)**
  438. The currently installed custom effects. This is an array of :ref:`RichTextEffect<class_RichTextEffect>`\ s.
  439. To add a custom effect, it's more convenient to use :ref:`install_effect<class_RichTextLabel_method_install_effect>`.
  440. .. rst-class:: classref-item-separator
  441. ----
  442. .. _class_RichTextLabel_property_deselect_on_focus_loss_enabled:
  443. .. rst-class:: classref-property
  444. :ref:`bool<class_bool>` **deselect_on_focus_loss_enabled** = ``true``
  445. .. rst-class:: classref-property-setget
  446. - void **set_deselect_on_focus_loss_enabled** **(** :ref:`bool<class_bool>` value **)**
  447. - :ref:`bool<class_bool>` **is_deselect_on_focus_loss_enabled** **(** **)**
  448. If ``true``, the selected text will be deselected when focus is lost.
  449. .. rst-class:: classref-item-separator
  450. ----
  451. .. _class_RichTextLabel_property_drag_and_drop_selection_enabled:
  452. .. rst-class:: classref-property
  453. :ref:`bool<class_bool>` **drag_and_drop_selection_enabled** = ``true``
  454. .. rst-class:: classref-property-setget
  455. - void **set_drag_and_drop_selection_enabled** **(** :ref:`bool<class_bool>` value **)**
  456. - :ref:`bool<class_bool>` **is_drag_and_drop_selection_enabled** **(** **)**
  457. If ``true``, allow drag and drop of selected text.
  458. .. rst-class:: classref-item-separator
  459. ----
  460. .. _class_RichTextLabel_property_fit_content:
  461. .. rst-class:: classref-property
  462. :ref:`bool<class_bool>` **fit_content** = ``false``
  463. .. rst-class:: classref-property-setget
  464. - void **set_fit_content** **(** :ref:`bool<class_bool>` value **)**
  465. - :ref:`bool<class_bool>` **is_fit_content_enabled** **(** **)**
  466. If ``true``, the label's minimum size will be automatically updated to fit its content, matching the behavior of :ref:`Label<class_Label>`.
  467. .. rst-class:: classref-item-separator
  468. ----
  469. .. _class_RichTextLabel_property_hint_underlined:
  470. .. rst-class:: classref-property
  471. :ref:`bool<class_bool>` **hint_underlined** = ``true``
  472. .. rst-class:: classref-property-setget
  473. - void **set_hint_underline** **(** :ref:`bool<class_bool>` value **)**
  474. - :ref:`bool<class_bool>` **is_hint_underlined** **(** **)**
  475. If ``true``, the label underlines hint tags such as ``[hint=description]{text}[/hint]``.
  476. .. rst-class:: classref-item-separator
  477. ----
  478. .. _class_RichTextLabel_property_language:
  479. .. rst-class:: classref-property
  480. :ref:`String<class_String>` **language** = ``""``
  481. .. rst-class:: classref-property-setget
  482. - void **set_language** **(** :ref:`String<class_String>` value **)**
  483. - :ref:`String<class_String>` **get_language** **(** **)**
  484. Language code used for line-breaking and text shaping algorithms, if left empty current locale is used instead.
  485. .. rst-class:: classref-item-separator
  486. ----
  487. .. _class_RichTextLabel_property_meta_underlined:
  488. .. rst-class:: classref-property
  489. :ref:`bool<class_bool>` **meta_underlined** = ``true``
  490. .. rst-class:: classref-property-setget
  491. - void **set_meta_underline** **(** :ref:`bool<class_bool>` value **)**
  492. - :ref:`bool<class_bool>` **is_meta_underlined** **(** **)**
  493. If ``true``, the label underlines meta tags such as ``[url]{text}[/url]``. These tags can call a function when clicked if :ref:`meta_clicked<class_RichTextLabel_signal_meta_clicked>` is connected to a function.
  494. .. rst-class:: classref-item-separator
  495. ----
  496. .. _class_RichTextLabel_property_progress_bar_delay:
  497. .. rst-class:: classref-property
  498. :ref:`int<class_int>` **progress_bar_delay** = ``1000``
  499. .. rst-class:: classref-property-setget
  500. - void **set_progress_bar_delay** **(** :ref:`int<class_int>` value **)**
  501. - :ref:`int<class_int>` **get_progress_bar_delay** **(** **)**
  502. The delay after which the loading progress bar is displayed, in milliseconds. Set to ``-1`` to disable progress bar entirely.
  503. \ **Note:** Progress bar is displayed only if :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled.
  504. .. rst-class:: classref-item-separator
  505. ----
  506. .. _class_RichTextLabel_property_scroll_active:
  507. .. rst-class:: classref-property
  508. :ref:`bool<class_bool>` **scroll_active** = ``true``
  509. .. rst-class:: classref-property-setget
  510. - void **set_scroll_active** **(** :ref:`bool<class_bool>` value **)**
  511. - :ref:`bool<class_bool>` **is_scroll_active** **(** **)**
  512. If ``true``, the scrollbar is visible. Setting this to ``false`` does not block scrolling completely. See :ref:`scroll_to_line<class_RichTextLabel_method_scroll_to_line>`.
  513. .. rst-class:: classref-item-separator
  514. ----
  515. .. _class_RichTextLabel_property_scroll_following:
  516. .. rst-class:: classref-property
  517. :ref:`bool<class_bool>` **scroll_following** = ``false``
  518. .. rst-class:: classref-property-setget
  519. - void **set_scroll_follow** **(** :ref:`bool<class_bool>` value **)**
  520. - :ref:`bool<class_bool>` **is_scroll_following** **(** **)**
  521. If ``true``, the window scrolls down to display new content automatically.
  522. .. rst-class:: classref-item-separator
  523. ----
  524. .. _class_RichTextLabel_property_selection_enabled:
  525. .. rst-class:: classref-property
  526. :ref:`bool<class_bool>` **selection_enabled** = ``false``
  527. .. rst-class:: classref-property-setget
  528. - void **set_selection_enabled** **(** :ref:`bool<class_bool>` value **)**
  529. - :ref:`bool<class_bool>` **is_selection_enabled** **(** **)**
  530. If ``true``, the label allows text selection.
  531. .. rst-class:: classref-item-separator
  532. ----
  533. .. _class_RichTextLabel_property_shortcut_keys_enabled:
  534. .. rst-class:: classref-property
  535. :ref:`bool<class_bool>` **shortcut_keys_enabled** = ``true``
  536. .. rst-class:: classref-property-setget
  537. - void **set_shortcut_keys_enabled** **(** :ref:`bool<class_bool>` value **)**
  538. - :ref:`bool<class_bool>` **is_shortcut_keys_enabled** **(** **)**
  539. If ``true``, shortcut keys for context menu items are enabled, even if the context menu is disabled.
  540. .. rst-class:: classref-item-separator
  541. ----
  542. .. _class_RichTextLabel_property_structured_text_bidi_override:
  543. .. rst-class:: classref-property
  544. :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` **structured_text_bidi_override** = ``0``
  545. .. rst-class:: classref-property-setget
  546. - void **set_structured_text_bidi_override** **(** :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` value **)**
  547. - :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` **get_structured_text_bidi_override** **(** **)**
  548. Set BiDi algorithm override for the structured text.
  549. .. rst-class:: classref-item-separator
  550. ----
  551. .. _class_RichTextLabel_property_structured_text_bidi_override_options:
  552. .. rst-class:: classref-property
  553. :ref:`Array<class_Array>` **structured_text_bidi_override_options** = ``[]``
  554. .. rst-class:: classref-property-setget
  555. - void **set_structured_text_bidi_override_options** **(** :ref:`Array<class_Array>` value **)**
  556. - :ref:`Array<class_Array>` **get_structured_text_bidi_override_options** **(** **)**
  557. Set additional options for BiDi override.
  558. .. rst-class:: classref-item-separator
  559. ----
  560. .. _class_RichTextLabel_property_tab_size:
  561. .. rst-class:: classref-property
  562. :ref:`int<class_int>` **tab_size** = ``4``
  563. .. rst-class:: classref-property-setget
  564. - void **set_tab_size** **(** :ref:`int<class_int>` value **)**
  565. - :ref:`int<class_int>` **get_tab_size** **(** **)**
  566. The number of spaces associated with a single tab length. Does not affect ``\t`` in text tags, only indent tags.
  567. .. rst-class:: classref-item-separator
  568. ----
  569. .. _class_RichTextLabel_property_text:
  570. .. rst-class:: classref-property
  571. :ref:`String<class_String>` **text** = ``""``
  572. .. rst-class:: classref-property-setget
  573. - void **set_text** **(** :ref:`String<class_String>` value **)**
  574. - :ref:`String<class_String>` **get_text** **(** **)**
  575. The label's text in BBCode format. Is not representative of manual modifications to the internal tag stack. Erases changes made by other methods when edited.
  576. \ **Note:** If :ref:`bbcode_enabled<class_RichTextLabel_property_bbcode_enabled>` is ``true``, it is unadvised to use the ``+=`` operator with :ref:`text<class_RichTextLabel_property_text>` (e.g. ``text += "some string"``) as it replaces the whole text and can cause slowdowns. It will also erase all BBCode that was added to stack using ``push_*`` methods. Use :ref:`append_text<class_RichTextLabel_method_append_text>` for adding text instead, unless you absolutely need to close a tag that was opened in an earlier method call.
  577. .. rst-class:: classref-item-separator
  578. ----
  579. .. _class_RichTextLabel_property_text_direction:
  580. .. rst-class:: classref-property
  581. :ref:`TextDirection<enum_Control_TextDirection>` **text_direction** = ``0``
  582. .. rst-class:: classref-property-setget
  583. - void **set_text_direction** **(** :ref:`TextDirection<enum_Control_TextDirection>` value **)**
  584. - :ref:`TextDirection<enum_Control_TextDirection>` **get_text_direction** **(** **)**
  585. Base text writing direction.
  586. .. rst-class:: classref-item-separator
  587. ----
  588. .. _class_RichTextLabel_property_threaded:
  589. .. rst-class:: classref-property
  590. :ref:`bool<class_bool>` **threaded** = ``false``
  591. .. rst-class:: classref-property-setget
  592. - void **set_threaded** **(** :ref:`bool<class_bool>` value **)**
  593. - :ref:`bool<class_bool>` **is_threaded** **(** **)**
  594. If ``true``, text processing is done in a background thread.
  595. .. rst-class:: classref-item-separator
  596. ----
  597. .. _class_RichTextLabel_property_visible_characters:
  598. .. rst-class:: classref-property
  599. :ref:`int<class_int>` **visible_characters** = ``-1``
  600. .. rst-class:: classref-property-setget
  601. - void **set_visible_characters** **(** :ref:`int<class_int>` value **)**
  602. - :ref:`int<class_int>` **get_visible_characters** **(** **)**
  603. The number of characters to display. If set to ``-1``, all characters are displayed. This can be useful when animating the text appearing in a dialog box.
  604. \ **Note:** Setting this property updates :ref:`visible_ratio<class_RichTextLabel_property_visible_ratio>` accordingly.
  605. .. rst-class:: classref-item-separator
  606. ----
  607. .. _class_RichTextLabel_property_visible_characters_behavior:
  608. .. rst-class:: classref-property
  609. :ref:`VisibleCharactersBehavior<enum_TextServer_VisibleCharactersBehavior>` **visible_characters_behavior** = ``0``
  610. .. rst-class:: classref-property-setget
  611. - void **set_visible_characters_behavior** **(** :ref:`VisibleCharactersBehavior<enum_TextServer_VisibleCharactersBehavior>` value **)**
  612. - :ref:`VisibleCharactersBehavior<enum_TextServer_VisibleCharactersBehavior>` **get_visible_characters_behavior** **(** **)**
  613. Sets the clipping behavior when :ref:`visible_characters<class_RichTextLabel_property_visible_characters>` or :ref:`visible_ratio<class_RichTextLabel_property_visible_ratio>` is set. See :ref:`VisibleCharactersBehavior<enum_TextServer_VisibleCharactersBehavior>` for more info.
  614. .. rst-class:: classref-item-separator
  615. ----
  616. .. _class_RichTextLabel_property_visible_ratio:
  617. .. rst-class:: classref-property
  618. :ref:`float<class_float>` **visible_ratio** = ``1.0``
  619. .. rst-class:: classref-property-setget
  620. - void **set_visible_ratio** **(** :ref:`float<class_float>` value **)**
  621. - :ref:`float<class_float>` **get_visible_ratio** **(** **)**
  622. The fraction of characters to display, relative to the total number of characters (see :ref:`get_total_character_count<class_RichTextLabel_method_get_total_character_count>`). If set to ``1.0``, all characters are displayed. If set to ``0.5``, only half of the characters will be displayed. This can be useful when animating the text appearing in a dialog box.
  623. \ **Note:** Setting this property updates :ref:`visible_characters<class_RichTextLabel_property_visible_characters>` accordingly.
  624. .. rst-class:: classref-section-separator
  625. ----
  626. .. rst-class:: classref-descriptions-group
  627. Method Descriptions
  628. -------------------
  629. .. _class_RichTextLabel_method_add_image:
  630. .. rst-class:: classref-method
  631. void **add_image** **(** :ref:`Texture2D<class_Texture2D>` image, :ref:`int<class_int>` width=0, :ref:`int<class_int>` height=0, :ref:`Color<class_Color>` color=Color(1, 1, 1, 1), :ref:`InlineAlignment<enum_@GlobalScope_InlineAlignment>` inline_align=5, :ref:`Rect2<class_Rect2>` region=Rect2(0, 0, 0, 0), :ref:`Variant<class_Variant>` key=null, :ref:`bool<class_bool>` pad=false, :ref:`String<class_String>` tooltip="", :ref:`bool<class_bool>` size_in_percent=false **)**
  632. Adds an image's opening and closing tags to the tag stack, optionally providing a ``width`` and ``height`` to resize the image, a ``color`` to tint the image and a ``region`` to only use parts of the image.
  633. If ``width`` or ``height`` is set to 0, the image size will be adjusted in order to keep the original aspect ratio.
  634. If ``width`` and ``height`` are not set, but ``region`` is, the region's rect will be used.
  635. \ ``key`` is an optional identifier, that can be used to modify the image via :ref:`update_image<class_RichTextLabel_method_update_image>`.
  636. If ``pad`` is set, and the image is smaller than the size specified by ``width`` and ``height``, the image padding is added to match the size instead of upscaling.
  637. If ``size_in_percent`` is set, ``width`` and ``height`` values are percentages of the control width instead of pixels.
  638. .. rst-class:: classref-item-separator
  639. ----
  640. .. _class_RichTextLabel_method_add_text:
  641. .. rst-class:: classref-method
  642. void **add_text** **(** :ref:`String<class_String>` text **)**
  643. Adds raw non-BBCode-parsed text to the tag stack.
  644. .. rst-class:: classref-item-separator
  645. ----
  646. .. _class_RichTextLabel_method_append_text:
  647. .. rst-class:: classref-method
  648. void **append_text** **(** :ref:`String<class_String>` bbcode **)**
  649. Parses ``bbcode`` and adds tags to the tag stack as needed.
  650. \ **Note:** Using this method, you can't close a tag that was opened in a previous :ref:`append_text<class_RichTextLabel_method_append_text>` call. This is done to improve performance, especially when updating large RichTextLabels since rebuilding the whole BBCode every time would be slower. If you absolutely need to close a tag in a future method call, append the :ref:`text<class_RichTextLabel_property_text>` instead of using :ref:`append_text<class_RichTextLabel_method_append_text>`.
  651. .. rst-class:: classref-item-separator
  652. ----
  653. .. _class_RichTextLabel_method_clear:
  654. .. rst-class:: classref-method
  655. void **clear** **(** **)**
  656. Clears the tag stack.
  657. \ **Note:** This method will not modify :ref:`text<class_RichTextLabel_property_text>`, but setting :ref:`text<class_RichTextLabel_property_text>` to an empty string also clears the stack.
  658. .. rst-class:: classref-item-separator
  659. ----
  660. .. _class_RichTextLabel_method_deselect:
  661. .. rst-class:: classref-method
  662. void **deselect** **(** **)**
  663. Clears the current selection.
  664. .. rst-class:: classref-item-separator
  665. ----
  666. .. _class_RichTextLabel_method_get_character_line:
  667. .. rst-class:: classref-method
  668. :ref:`int<class_int>` **get_character_line** **(** :ref:`int<class_int>` character **)**
  669. Returns the line number of the character position provided. Line and character numbers are both zero-indexed.
  670. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  671. .. rst-class:: classref-item-separator
  672. ----
  673. .. _class_RichTextLabel_method_get_character_paragraph:
  674. .. rst-class:: classref-method
  675. :ref:`int<class_int>` **get_character_paragraph** **(** :ref:`int<class_int>` character **)**
  676. Returns the paragraph number of the character position provided. Paragraph and character numbers are both zero-indexed.
  677. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  678. .. rst-class:: classref-item-separator
  679. ----
  680. .. _class_RichTextLabel_method_get_content_height:
  681. .. rst-class:: classref-method
  682. :ref:`int<class_int>` **get_content_height** **(** **)** |const|
  683. Returns the height of the content.
  684. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  685. .. rst-class:: classref-item-separator
  686. ----
  687. .. _class_RichTextLabel_method_get_content_width:
  688. .. rst-class:: classref-method
  689. :ref:`int<class_int>` **get_content_width** **(** **)** |const|
  690. Returns the width of the content.
  691. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  692. .. rst-class:: classref-item-separator
  693. ----
  694. .. _class_RichTextLabel_method_get_line_count:
  695. .. rst-class:: classref-method
  696. :ref:`int<class_int>` **get_line_count** **(** **)** |const|
  697. Returns the total number of lines in the text. Wrapped text is counted as multiple lines.
  698. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  699. .. rst-class:: classref-item-separator
  700. ----
  701. .. _class_RichTextLabel_method_get_line_offset:
  702. .. rst-class:: classref-method
  703. :ref:`float<class_float>` **get_line_offset** **(** :ref:`int<class_int>` line **)**
  704. Returns the vertical offset of the line found at the provided index.
  705. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  706. .. rst-class:: classref-item-separator
  707. ----
  708. .. _class_RichTextLabel_method_get_menu:
  709. .. rst-class:: classref-method
  710. :ref:`PopupMenu<class_PopupMenu>` **get_menu** **(** **)** |const|
  711. Returns the :ref:`PopupMenu<class_PopupMenu>` of this **RichTextLabel**. By default, this menu is displayed when right-clicking on the **RichTextLabel**.
  712. You can add custom menu items or remove standard ones. Make sure your IDs don't conflict with the standard ones (see :ref:`MenuItems<enum_RichTextLabel_MenuItems>`). For example:
  713. .. tabs::
  714. .. code-tab:: gdscript
  715. func _ready():
  716. var menu = get_menu()
  717. # Remove "Select All" item.
  718. menu.remove_item(MENU_SELECT_ALL)
  719. # Add custom items.
  720. menu.add_separator()
  721. menu.add_item("Duplicate Text", MENU_MAX + 1)
  722. # Connect callback.
  723. menu.id_pressed.connect(_on_item_pressed)
  724. func _on_item_pressed(id):
  725. if id == MENU_MAX + 1:
  726. add_text("\n" + get_parsed_text())
  727. .. code-tab:: csharp
  728. public override void _Ready()
  729. {
  730. var menu = GetMenu();
  731. // Remove "Select All" item.
  732. menu.RemoveItem(RichTextLabel.MenuItems.SelectAll);
  733. // Add custom items.
  734. menu.AddSeparator();
  735. menu.AddItem("Duplicate Text", RichTextLabel.MenuItems.Max + 1);
  736. // Add event handler.
  737. menu.IdPressed += OnItemPressed;
  738. }
  739. public void OnItemPressed(int id)
  740. {
  741. if (id == TextEdit.MenuItems.Max + 1)
  742. {
  743. AddText("\n" + GetParsedText());
  744. }
  745. }
  746. \ **Warning:** This is a required internal node, removing and freeing it may cause a crash. If you wish to hide it or any of its children, use their :ref:`Window.visible<class_Window_property_visible>` property.
  747. .. rst-class:: classref-item-separator
  748. ----
  749. .. _class_RichTextLabel_method_get_paragraph_count:
  750. .. rst-class:: classref-method
  751. :ref:`int<class_int>` **get_paragraph_count** **(** **)** |const|
  752. Returns the total number of paragraphs (newlines or ``p`` tags in the tag stack's text tags). Considers wrapped text as one paragraph.
  753. .. rst-class:: classref-item-separator
  754. ----
  755. .. _class_RichTextLabel_method_get_paragraph_offset:
  756. .. rst-class:: classref-method
  757. :ref:`float<class_float>` **get_paragraph_offset** **(** :ref:`int<class_int>` paragraph **)**
  758. Returns the vertical offset of the paragraph found at the provided index.
  759. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  760. .. rst-class:: classref-item-separator
  761. ----
  762. .. _class_RichTextLabel_method_get_parsed_text:
  763. .. rst-class:: classref-method
  764. :ref:`String<class_String>` **get_parsed_text** **(** **)** |const|
  765. Returns the text without BBCode mark-up.
  766. .. rst-class:: classref-item-separator
  767. ----
  768. .. _class_RichTextLabel_method_get_selected_text:
  769. .. rst-class:: classref-method
  770. :ref:`String<class_String>` **get_selected_text** **(** **)** |const|
  771. Returns the current selection text. Does not include BBCodes.
  772. .. rst-class:: classref-item-separator
  773. ----
  774. .. _class_RichTextLabel_method_get_selection_from:
  775. .. rst-class:: classref-method
  776. :ref:`int<class_int>` **get_selection_from** **(** **)** |const|
  777. Returns the current selection first character index if a selection is active, ``-1`` otherwise. Does not include BBCodes.
  778. .. rst-class:: classref-item-separator
  779. ----
  780. .. _class_RichTextLabel_method_get_selection_to:
  781. .. rst-class:: classref-method
  782. :ref:`int<class_int>` **get_selection_to** **(** **)** |const|
  783. Returns the current selection last character index if a selection is active, ``-1`` otherwise. Does not include BBCodes.
  784. .. rst-class:: classref-item-separator
  785. ----
  786. .. _class_RichTextLabel_method_get_total_character_count:
  787. .. rst-class:: classref-method
  788. :ref:`int<class_int>` **get_total_character_count** **(** **)** |const|
  789. Returns the total number of characters from text tags. Does not include BBCodes.
  790. .. rst-class:: classref-item-separator
  791. ----
  792. .. _class_RichTextLabel_method_get_v_scroll_bar:
  793. .. rst-class:: classref-method
  794. :ref:`VScrollBar<class_VScrollBar>` **get_v_scroll_bar** **(** **)**
  795. Returns the vertical scrollbar.
  796. \ **Warning:** This is a required internal node, removing and freeing it may cause a crash. If you wish to hide it or any of its children, use their :ref:`CanvasItem.visible<class_CanvasItem_property_visible>` property.
  797. .. rst-class:: classref-item-separator
  798. ----
  799. .. _class_RichTextLabel_method_get_visible_line_count:
  800. .. rst-class:: classref-method
  801. :ref:`int<class_int>` **get_visible_line_count** **(** **)** |const|
  802. Returns the number of visible lines.
  803. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  804. .. rst-class:: classref-item-separator
  805. ----
  806. .. _class_RichTextLabel_method_get_visible_paragraph_count:
  807. .. rst-class:: classref-method
  808. :ref:`int<class_int>` **get_visible_paragraph_count** **(** **)** |const|
  809. Returns the number of visible paragraphs. A paragraph is considered visible if at least one of its lines is visible.
  810. \ **Note:** If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, this method returns a value for the loaded part of the document. Use :ref:`is_ready<class_RichTextLabel_method_is_ready>` or :ref:`finished<class_RichTextLabel_signal_finished>` to determine whether document is fully loaded.
  811. .. rst-class:: classref-item-separator
  812. ----
  813. .. _class_RichTextLabel_method_install_effect:
  814. .. rst-class:: classref-method
  815. void **install_effect** **(** :ref:`Variant<class_Variant>` effect **)**
  816. Installs a custom effect. This can also be done in the RichTextLabel inspector using the :ref:`custom_effects<class_RichTextLabel_property_custom_effects>` property. ``effect`` should be a valid :ref:`RichTextEffect<class_RichTextEffect>`.
  817. Example RichTextEffect:
  818. ::
  819. # effect.gd
  820. class_name MyCustomEffect
  821. extends RichTextEffect
  822. var bbcode = "my_custom_effect"
  823. # ...
  824. Registering the above effect in RichTextLabel from script:
  825. ::
  826. # rich_text_label.gd
  827. extends RichTextLabel
  828. func _ready():
  829. install_effect(MyCustomEffect.new())
  830. # Alternatively, if not using `class_name` in the script that extends RichTextEffect:
  831. install_effect(preload("res://effect.gd").new())
  832. .. rst-class:: classref-item-separator
  833. ----
  834. .. _class_RichTextLabel_method_is_menu_visible:
  835. .. rst-class:: classref-method
  836. :ref:`bool<class_bool>` **is_menu_visible** **(** **)** |const|
  837. Returns whether the menu is visible. Use this instead of ``get_menu().visible`` to improve performance (so the creation of the menu is avoided).
  838. .. rst-class:: classref-item-separator
  839. ----
  840. .. _class_RichTextLabel_method_is_ready:
  841. .. rst-class:: classref-method
  842. :ref:`bool<class_bool>` **is_ready** **(** **)** |const|
  843. If :ref:`threaded<class_RichTextLabel_property_threaded>` is enabled, returns ``true`` if the background thread has finished text processing, otherwise always return ``true``.
  844. .. rst-class:: classref-item-separator
  845. ----
  846. .. _class_RichTextLabel_method_menu_option:
  847. .. rst-class:: classref-method
  848. void **menu_option** **(** :ref:`int<class_int>` option **)**
  849. Executes a given action as defined in the :ref:`MenuItems<enum_RichTextLabel_MenuItems>` enum.
  850. .. rst-class:: classref-item-separator
  851. ----
  852. .. _class_RichTextLabel_method_newline:
  853. .. rst-class:: classref-method
  854. void **newline** **(** **)**
  855. Adds a newline tag to the tag stack.
  856. .. rst-class:: classref-item-separator
  857. ----
  858. .. _class_RichTextLabel_method_parse_bbcode:
  859. .. rst-class:: classref-method
  860. void **parse_bbcode** **(** :ref:`String<class_String>` bbcode **)**
  861. The assignment version of :ref:`append_text<class_RichTextLabel_method_append_text>`. Clears the tag stack and inserts the new content.
  862. .. rst-class:: classref-item-separator
  863. ----
  864. .. _class_RichTextLabel_method_parse_expressions_for_values:
  865. .. rst-class:: classref-method
  866. :ref:`Dictionary<class_Dictionary>` **parse_expressions_for_values** **(** :ref:`PackedStringArray<class_PackedStringArray>` expressions **)**
  867. Parses BBCode parameter ``expressions`` into a dictionary.
  868. .. rst-class:: classref-item-separator
  869. ----
  870. .. _class_RichTextLabel_method_pop:
  871. .. rst-class:: classref-method
  872. void **pop** **(** **)**
  873. Terminates the current tag. Use after ``push_*`` methods to close BBCodes manually. Does not need to follow ``add_*`` methods.
  874. .. rst-class:: classref-item-separator
  875. ----
  876. .. _class_RichTextLabel_method_pop_all:
  877. .. rst-class:: classref-method
  878. void **pop_all** **(** **)**
  879. Terminates all tags opened by ``push_*`` methods.
  880. .. rst-class:: classref-item-separator
  881. ----
  882. .. _class_RichTextLabel_method_pop_context:
  883. .. rst-class:: classref-method
  884. void **pop_context** **(** **)**
  885. Terminates tags opened after the last :ref:`push_context<class_RichTextLabel_method_push_context>` call (including context marker), or all tags if there's no context marker on the stack.
  886. .. rst-class:: classref-item-separator
  887. ----
  888. .. _class_RichTextLabel_method_push_bgcolor:
  889. .. rst-class:: classref-method
  890. void **push_bgcolor** **(** :ref:`Color<class_Color>` bgcolor **)**
  891. Adds a ``[bgcolor]`` tag to the tag stack.
  892. .. rst-class:: classref-item-separator
  893. ----
  894. .. _class_RichTextLabel_method_push_bold:
  895. .. rst-class:: classref-method
  896. void **push_bold** **(** **)**
  897. Adds a ``[font]`` tag with a bold font to the tag stack. This is the same as adding a ``[b]`` tag if not currently in a ``[i]`` tag.
  898. .. rst-class:: classref-item-separator
  899. ----
  900. .. _class_RichTextLabel_method_push_bold_italics:
  901. .. rst-class:: classref-method
  902. void **push_bold_italics** **(** **)**
  903. Adds a ``[font]`` tag with a bold italics font to the tag stack.
  904. .. rst-class:: classref-item-separator
  905. ----
  906. .. _class_RichTextLabel_method_push_cell:
  907. .. rst-class:: classref-method
  908. void **push_cell** **(** **)**
  909. Adds a ``[cell]`` tag to the tag stack. Must be inside a ``[table]`` tag. See :ref:`push_table<class_RichTextLabel_method_push_table>` for details.
  910. .. rst-class:: classref-item-separator
  911. ----
  912. .. _class_RichTextLabel_method_push_color:
  913. .. rst-class:: classref-method
  914. void **push_color** **(** :ref:`Color<class_Color>` color **)**
  915. Adds a ``[color]`` tag to the tag stack.
  916. .. rst-class:: classref-item-separator
  917. ----
  918. .. _class_RichTextLabel_method_push_context:
  919. .. rst-class:: classref-method
  920. void **push_context** **(** **)**
  921. Adds a context marker to the tag stack. See :ref:`pop_context<class_RichTextLabel_method_pop_context>`.
  922. .. rst-class:: classref-item-separator
  923. ----
  924. .. _class_RichTextLabel_method_push_customfx:
  925. .. rst-class:: classref-method
  926. void **push_customfx** **(** :ref:`RichTextEffect<class_RichTextEffect>` effect, :ref:`Dictionary<class_Dictionary>` env **)**
  927. Adds a custom effect tag to the tag stack. The effect does not need to be in :ref:`custom_effects<class_RichTextLabel_property_custom_effects>`. The environment is directly passed to the effect.
  928. .. rst-class:: classref-item-separator
  929. ----
  930. .. _class_RichTextLabel_method_push_dropcap:
  931. .. rst-class:: classref-method
  932. void **push_dropcap** **(** :ref:`String<class_String>` string, :ref:`Font<class_Font>` font, :ref:`int<class_int>` size, :ref:`Rect2<class_Rect2>` dropcap_margins=Rect2(0, 0, 0, 0), :ref:`Color<class_Color>` color=Color(1, 1, 1, 1), :ref:`int<class_int>` outline_size=0, :ref:`Color<class_Color>` outline_color=Color(0, 0, 0, 0) **)**
  933. Adds a ``[dropcap]`` tag to the tag stack. Drop cap (dropped capital) is a decorative element at the beginning of a paragraph that is larger than the rest of the text.
  934. .. rst-class:: classref-item-separator
  935. ----
  936. .. _class_RichTextLabel_method_push_fgcolor:
  937. .. rst-class:: classref-method
  938. void **push_fgcolor** **(** :ref:`Color<class_Color>` fgcolor **)**
  939. Adds a ``[fgcolor]`` tag to the tag stack.
  940. .. rst-class:: classref-item-separator
  941. ----
  942. .. _class_RichTextLabel_method_push_font:
  943. .. rst-class:: classref-method
  944. void **push_font** **(** :ref:`Font<class_Font>` font, :ref:`int<class_int>` font_size=0 **)**
  945. Adds a ``[font]`` tag to the tag stack. Overrides default fonts for its duration.
  946. Passing ``0`` to ``font_size`` will use the existing default font size.
  947. .. rst-class:: classref-item-separator
  948. ----
  949. .. _class_RichTextLabel_method_push_font_size:
  950. .. rst-class:: classref-method
  951. void **push_font_size** **(** :ref:`int<class_int>` font_size **)**
  952. Adds a ``[font_size]`` tag to the tag stack. Overrides default font size for its duration.
  953. .. rst-class:: classref-item-separator
  954. ----
  955. .. _class_RichTextLabel_method_push_hint:
  956. .. rst-class:: classref-method
  957. void **push_hint** **(** :ref:`String<class_String>` description **)**
  958. Adds a ``[hint]`` tag to the tag stack. Same as BBCode ``[hint=something]{text}[/hint]``.
  959. .. rst-class:: classref-item-separator
  960. ----
  961. .. _class_RichTextLabel_method_push_indent:
  962. .. rst-class:: classref-method
  963. void **push_indent** **(** :ref:`int<class_int>` level **)**
  964. Adds an ``[indent]`` tag to the tag stack. Multiplies ``level`` by current :ref:`tab_size<class_RichTextLabel_property_tab_size>` to determine new margin length.
  965. .. rst-class:: classref-item-separator
  966. ----
  967. .. _class_RichTextLabel_method_push_italics:
  968. .. rst-class:: classref-method
  969. void **push_italics** **(** **)**
  970. Adds a ``[font]`` tag with an italics font to the tag stack. This is the same as adding an ``[i]`` tag if not currently in a ``[b]`` tag.
  971. .. rst-class:: classref-item-separator
  972. ----
  973. .. _class_RichTextLabel_method_push_language:
  974. .. rst-class:: classref-method
  975. void **push_language** **(** :ref:`String<class_String>` language **)**
  976. Adds language code used for text shaping algorithm and Open-Type font features.
  977. .. rst-class:: classref-item-separator
  978. ----
  979. .. _class_RichTextLabel_method_push_list:
  980. .. rst-class:: classref-method
  981. void **push_list** **(** :ref:`int<class_int>` level, :ref:`ListType<enum_RichTextLabel_ListType>` type, :ref:`bool<class_bool>` capitalize, :ref:`String<class_String>` bullet="•" **)**
  982. Adds ``[ol]`` or ``[ul]`` tag to the tag stack. Multiplies ``level`` by current :ref:`tab_size<class_RichTextLabel_property_tab_size>` to determine new margin length.
  983. .. rst-class:: classref-item-separator
  984. ----
  985. .. _class_RichTextLabel_method_push_meta:
  986. .. rst-class:: classref-method
  987. void **push_meta** **(** :ref:`Variant<class_Variant>` data **)**
  988. Adds a meta tag to the tag stack. Similar to the BBCode ``[url=something]{text}[/url]``, but supports non-:ref:`String<class_String>` metadata types.
  989. \ **Note:** Meta tags do nothing by default when clicked. To assign behavior when clicked, connect :ref:`meta_clicked<class_RichTextLabel_signal_meta_clicked>` to a function that is called when the meta tag is clicked.
  990. .. rst-class:: classref-item-separator
  991. ----
  992. .. _class_RichTextLabel_method_push_mono:
  993. .. rst-class:: classref-method
  994. void **push_mono** **(** **)**
  995. Adds a ``[font]`` tag with a monospace font to the tag stack.
  996. .. rst-class:: classref-item-separator
  997. ----
  998. .. _class_RichTextLabel_method_push_normal:
  999. .. rst-class:: classref-method
  1000. void **push_normal** **(** **)**
  1001. Adds a ``[font]`` tag with a normal font to the tag stack.
  1002. .. rst-class:: classref-item-separator
  1003. ----
  1004. .. _class_RichTextLabel_method_push_outline_color:
  1005. .. rst-class:: classref-method
  1006. void **push_outline_color** **(** :ref:`Color<class_Color>` color **)**
  1007. Adds a ``[outline_color]`` tag to the tag stack. Adds text outline for its duration.
  1008. .. rst-class:: classref-item-separator
  1009. ----
  1010. .. _class_RichTextLabel_method_push_outline_size:
  1011. .. rst-class:: classref-method
  1012. void **push_outline_size** **(** :ref:`int<class_int>` outline_size **)**
  1013. Adds a ``[outline_size]`` tag to the tag stack. Overrides default text outline size for its duration.
  1014. .. rst-class:: classref-item-separator
  1015. ----
  1016. .. _class_RichTextLabel_method_push_paragraph:
  1017. .. rst-class:: classref-method
  1018. void **push_paragraph** **(** :ref:`HorizontalAlignment<enum_@GlobalScope_HorizontalAlignment>` alignment, :ref:`TextDirection<enum_Control_TextDirection>` base_direction=0, :ref:`String<class_String>` language="", :ref:`StructuredTextParser<enum_TextServer_StructuredTextParser>` st_parser=0, |bitfield|\<:ref:`JustificationFlag<enum_TextServer_JustificationFlag>`\> justification_flags=163, :ref:`PackedFloat32Array<class_PackedFloat32Array>` tab_stops=PackedFloat32Array() **)**
  1019. Adds a ``[p]`` tag to the tag stack.
  1020. .. rst-class:: classref-item-separator
  1021. ----
  1022. .. _class_RichTextLabel_method_push_strikethrough:
  1023. .. rst-class:: classref-method
  1024. void **push_strikethrough** **(** **)**
  1025. Adds a ``[s]`` tag to the tag stack.
  1026. .. rst-class:: classref-item-separator
  1027. ----
  1028. .. _class_RichTextLabel_method_push_table:
  1029. .. rst-class:: classref-method
  1030. void **push_table** **(** :ref:`int<class_int>` columns, :ref:`InlineAlignment<enum_@GlobalScope_InlineAlignment>` inline_align=0, :ref:`int<class_int>` align_to_row=-1 **)**
  1031. Adds a ``[table=columns,inline_align]`` tag to the tag stack.
  1032. .. rst-class:: classref-item-separator
  1033. ----
  1034. .. _class_RichTextLabel_method_push_underline:
  1035. .. rst-class:: classref-method
  1036. void **push_underline** **(** **)**
  1037. Adds a ``[u]`` tag to the tag stack.
  1038. .. rst-class:: classref-item-separator
  1039. ----
  1040. .. _class_RichTextLabel_method_remove_paragraph:
  1041. .. rst-class:: classref-method
  1042. :ref:`bool<class_bool>` **remove_paragraph** **(** :ref:`int<class_int>` paragraph **)**
  1043. Removes a paragraph of content from the label. Returns ``true`` if the paragraph exists.
  1044. The ``paragraph`` argument is the index of the paragraph to remove, it can take values in the interval ``[0, get_paragraph_count() - 1]``.
  1045. .. rst-class:: classref-item-separator
  1046. ----
  1047. .. _class_RichTextLabel_method_scroll_to_line:
  1048. .. rst-class:: classref-method
  1049. void **scroll_to_line** **(** :ref:`int<class_int>` line **)**
  1050. Scrolls the window's top line to match ``line``.
  1051. .. rst-class:: classref-item-separator
  1052. ----
  1053. .. _class_RichTextLabel_method_scroll_to_paragraph:
  1054. .. rst-class:: classref-method
  1055. void **scroll_to_paragraph** **(** :ref:`int<class_int>` paragraph **)**
  1056. Scrolls the window's top line to match first line of the ``paragraph``.
  1057. .. rst-class:: classref-item-separator
  1058. ----
  1059. .. _class_RichTextLabel_method_scroll_to_selection:
  1060. .. rst-class:: classref-method
  1061. void **scroll_to_selection** **(** **)**
  1062. Scrolls to the beginning of the current selection.
  1063. .. rst-class:: classref-item-separator
  1064. ----
  1065. .. _class_RichTextLabel_method_select_all:
  1066. .. rst-class:: classref-method
  1067. void **select_all** **(** **)**
  1068. Select all the text.
  1069. If :ref:`selection_enabled<class_RichTextLabel_property_selection_enabled>` is ``false``, no selection will occur.
  1070. .. rst-class:: classref-item-separator
  1071. ----
  1072. .. _class_RichTextLabel_method_set_cell_border_color:
  1073. .. rst-class:: classref-method
  1074. void **set_cell_border_color** **(** :ref:`Color<class_Color>` color **)**
  1075. Sets color of a table cell border.
  1076. .. rst-class:: classref-item-separator
  1077. ----
  1078. .. _class_RichTextLabel_method_set_cell_padding:
  1079. .. rst-class:: classref-method
  1080. void **set_cell_padding** **(** :ref:`Rect2<class_Rect2>` padding **)**
  1081. Sets inner padding of a table cell.
  1082. .. rst-class:: classref-item-separator
  1083. ----
  1084. .. _class_RichTextLabel_method_set_cell_row_background_color:
  1085. .. rst-class:: classref-method
  1086. void **set_cell_row_background_color** **(** :ref:`Color<class_Color>` odd_row_bg, :ref:`Color<class_Color>` even_row_bg **)**
  1087. Sets color of a table cell. Separate colors for alternating rows can be specified.
  1088. .. rst-class:: classref-item-separator
  1089. ----
  1090. .. _class_RichTextLabel_method_set_cell_size_override:
  1091. .. rst-class:: classref-method
  1092. void **set_cell_size_override** **(** :ref:`Vector2<class_Vector2>` min_size, :ref:`Vector2<class_Vector2>` max_size **)**
  1093. Sets minimum and maximum size overrides for a table cell.
  1094. .. rst-class:: classref-item-separator
  1095. ----
  1096. .. _class_RichTextLabel_method_set_table_column_expand:
  1097. .. rst-class:: classref-method
  1098. void **set_table_column_expand** **(** :ref:`int<class_int>` column, :ref:`bool<class_bool>` expand, :ref:`int<class_int>` ratio=1 **)**
  1099. Edits the selected column's expansion options. If ``expand`` is ``true``, the column expands in proportion to its expansion ratio versus the other columns' ratios.
  1100. For example, 2 columns with ratios 3 and 4 plus 70 pixels in available width would expand 30 and 40 pixels, respectively.
  1101. If ``expand`` is ``false``, the column will not contribute to the total ratio.
  1102. .. rst-class:: classref-item-separator
  1103. ----
  1104. .. _class_RichTextLabel_method_update_image:
  1105. .. rst-class:: classref-method
  1106. void **update_image** **(** :ref:`Variant<class_Variant>` key, |bitfield|\<:ref:`ImageUpdateMask<enum_RichTextLabel_ImageUpdateMask>`\> mask, :ref:`Texture2D<class_Texture2D>` image, :ref:`int<class_int>` width=0, :ref:`int<class_int>` height=0, :ref:`Color<class_Color>` color=Color(1, 1, 1, 1), :ref:`InlineAlignment<enum_@GlobalScope_InlineAlignment>` inline_align=5, :ref:`Rect2<class_Rect2>` region=Rect2(0, 0, 0, 0), :ref:`bool<class_bool>` pad=false, :ref:`String<class_String>` tooltip="", :ref:`bool<class_bool>` size_in_percent=false **)**
  1107. Updates the existing images with the key ``key``. Only properties specified by ``mask`` bits are updated. See :ref:`add_image<class_RichTextLabel_method_add_image>`.
  1108. .. rst-class:: classref-section-separator
  1109. ----
  1110. .. rst-class:: classref-descriptions-group
  1111. Theme Property Descriptions
  1112. ---------------------------
  1113. .. _class_RichTextLabel_theme_color_default_color:
  1114. .. rst-class:: classref-themeproperty
  1115. :ref:`Color<class_Color>` **default_color** = ``Color(1, 1, 1, 1)``
  1116. The default text color.
  1117. .. rst-class:: classref-item-separator
  1118. ----
  1119. .. _class_RichTextLabel_theme_color_font_outline_color:
  1120. .. rst-class:: classref-themeproperty
  1121. :ref:`Color<class_Color>` **font_outline_color** = ``Color(1, 1, 1, 1)``
  1122. The default tint of text outline.
  1123. .. rst-class:: classref-item-separator
  1124. ----
  1125. .. _class_RichTextLabel_theme_color_font_selected_color:
  1126. .. rst-class:: classref-themeproperty
  1127. :ref:`Color<class_Color>` **font_selected_color** = ``Color(0, 0, 0, 0)``
  1128. The color of selected text, used when :ref:`selection_enabled<class_RichTextLabel_property_selection_enabled>` is ``true``. If equal to ``Color(0, 0, 0, 0)``, it will be ignored.
  1129. .. rst-class:: classref-item-separator
  1130. ----
  1131. .. _class_RichTextLabel_theme_color_font_shadow_color:
  1132. .. rst-class:: classref-themeproperty
  1133. :ref:`Color<class_Color>` **font_shadow_color** = ``Color(0, 0, 0, 0)``
  1134. The color of the font's shadow.
  1135. .. rst-class:: classref-item-separator
  1136. ----
  1137. .. _class_RichTextLabel_theme_color_selection_color:
  1138. .. rst-class:: classref-themeproperty
  1139. :ref:`Color<class_Color>` **selection_color** = ``Color(0.1, 0.1, 1, 0.8)``
  1140. The color of the selection box.
  1141. .. rst-class:: classref-item-separator
  1142. ----
  1143. .. _class_RichTextLabel_theme_color_table_border:
  1144. .. rst-class:: classref-themeproperty
  1145. :ref:`Color<class_Color>` **table_border** = ``Color(0, 0, 0, 0)``
  1146. The default cell border color.
  1147. .. rst-class:: classref-item-separator
  1148. ----
  1149. .. _class_RichTextLabel_theme_color_table_even_row_bg:
  1150. .. rst-class:: classref-themeproperty
  1151. :ref:`Color<class_Color>` **table_even_row_bg** = ``Color(0, 0, 0, 0)``
  1152. The default background color for even rows.
  1153. .. rst-class:: classref-item-separator
  1154. ----
  1155. .. _class_RichTextLabel_theme_color_table_odd_row_bg:
  1156. .. rst-class:: classref-themeproperty
  1157. :ref:`Color<class_Color>` **table_odd_row_bg** = ``Color(0, 0, 0, 0)``
  1158. The default background color for odd rows.
  1159. .. rst-class:: classref-item-separator
  1160. ----
  1161. .. _class_RichTextLabel_theme_constant_line_separation:
  1162. .. rst-class:: classref-themeproperty
  1163. :ref:`int<class_int>` **line_separation** = ``0``
  1164. The vertical space between lines.
  1165. .. rst-class:: classref-item-separator
  1166. ----
  1167. .. _class_RichTextLabel_theme_constant_outline_size:
  1168. .. rst-class:: classref-themeproperty
  1169. :ref:`int<class_int>` **outline_size** = ``0``
  1170. The size of the text outline.
  1171. \ **Note:** If using a font with :ref:`FontFile.multichannel_signed_distance_field<class_FontFile_property_multichannel_signed_distance_field>` enabled, its :ref:`FontFile.msdf_pixel_range<class_FontFile_property_msdf_pixel_range>` must be set to at least *twice* the value of :ref:`outline_size<class_RichTextLabel_theme_constant_outline_size>` for outline rendering to look correct. Otherwise, the outline may appear to be cut off earlier than intended.
  1172. .. rst-class:: classref-item-separator
  1173. ----
  1174. .. _class_RichTextLabel_theme_constant_shadow_offset_x:
  1175. .. rst-class:: classref-themeproperty
  1176. :ref:`int<class_int>` **shadow_offset_x** = ``1``
  1177. The horizontal offset of the font's shadow.
  1178. .. rst-class:: classref-item-separator
  1179. ----
  1180. .. _class_RichTextLabel_theme_constant_shadow_offset_y:
  1181. .. rst-class:: classref-themeproperty
  1182. :ref:`int<class_int>` **shadow_offset_y** = ``1``
  1183. The vertical offset of the font's shadow.
  1184. .. rst-class:: classref-item-separator
  1185. ----
  1186. .. _class_RichTextLabel_theme_constant_shadow_outline_size:
  1187. .. rst-class:: classref-themeproperty
  1188. :ref:`int<class_int>` **shadow_outline_size** = ``1``
  1189. The size of the shadow outline.
  1190. .. rst-class:: classref-item-separator
  1191. ----
  1192. .. _class_RichTextLabel_theme_constant_table_h_separation:
  1193. .. rst-class:: classref-themeproperty
  1194. :ref:`int<class_int>` **table_h_separation** = ``3``
  1195. The horizontal separation of elements in a table.
  1196. .. rst-class:: classref-item-separator
  1197. ----
  1198. .. _class_RichTextLabel_theme_constant_table_v_separation:
  1199. .. rst-class:: classref-themeproperty
  1200. :ref:`int<class_int>` **table_v_separation** = ``3``
  1201. The vertical separation of elements in a table.
  1202. .. rst-class:: classref-item-separator
  1203. ----
  1204. .. _class_RichTextLabel_theme_constant_text_highlight_h_padding:
  1205. .. rst-class:: classref-themeproperty
  1206. :ref:`int<class_int>` **text_highlight_h_padding** = ``3``
  1207. The horizontal padding around boxes drawn by the ``[fgcolor]`` and ``[bgcolor]`` tags. This does not affect the appearance of text selection.
  1208. .. rst-class:: classref-item-separator
  1209. ----
  1210. .. _class_RichTextLabel_theme_constant_text_highlight_v_padding:
  1211. .. rst-class:: classref-themeproperty
  1212. :ref:`int<class_int>` **text_highlight_v_padding** = ``3``
  1213. The vertical padding around boxes drawn by the ``[fgcolor]`` and ``[bgcolor]`` tags. This does not affect the appearance of text selection.
  1214. .. rst-class:: classref-item-separator
  1215. ----
  1216. .. _class_RichTextLabel_theme_font_bold_font:
  1217. .. rst-class:: classref-themeproperty
  1218. :ref:`Font<class_Font>` **bold_font**
  1219. The font used for bold text.
  1220. .. rst-class:: classref-item-separator
  1221. ----
  1222. .. _class_RichTextLabel_theme_font_bold_italics_font:
  1223. .. rst-class:: classref-themeproperty
  1224. :ref:`Font<class_Font>` **bold_italics_font**
  1225. The font used for bold italics text.
  1226. .. rst-class:: classref-item-separator
  1227. ----
  1228. .. _class_RichTextLabel_theme_font_italics_font:
  1229. .. rst-class:: classref-themeproperty
  1230. :ref:`Font<class_Font>` **italics_font**
  1231. The font used for italics text.
  1232. .. rst-class:: classref-item-separator
  1233. ----
  1234. .. _class_RichTextLabel_theme_font_mono_font:
  1235. .. rst-class:: classref-themeproperty
  1236. :ref:`Font<class_Font>` **mono_font**
  1237. The font used for monospace text.
  1238. .. rst-class:: classref-item-separator
  1239. ----
  1240. .. _class_RichTextLabel_theme_font_normal_font:
  1241. .. rst-class:: classref-themeproperty
  1242. :ref:`Font<class_Font>` **normal_font**
  1243. The default text font.
  1244. .. rst-class:: classref-item-separator
  1245. ----
  1246. .. _class_RichTextLabel_theme_font_size_bold_font_size:
  1247. .. rst-class:: classref-themeproperty
  1248. :ref:`int<class_int>` **bold_font_size**
  1249. The font size used for bold text.
  1250. .. rst-class:: classref-item-separator
  1251. ----
  1252. .. _class_RichTextLabel_theme_font_size_bold_italics_font_size:
  1253. .. rst-class:: classref-themeproperty
  1254. :ref:`int<class_int>` **bold_italics_font_size**
  1255. The font size used for bold italics text.
  1256. .. rst-class:: classref-item-separator
  1257. ----
  1258. .. _class_RichTextLabel_theme_font_size_italics_font_size:
  1259. .. rst-class:: classref-themeproperty
  1260. :ref:`int<class_int>` **italics_font_size**
  1261. The font size used for italics text.
  1262. .. rst-class:: classref-item-separator
  1263. ----
  1264. .. _class_RichTextLabel_theme_font_size_mono_font_size:
  1265. .. rst-class:: classref-themeproperty
  1266. :ref:`int<class_int>` **mono_font_size**
  1267. The font size used for monospace text.
  1268. .. rst-class:: classref-item-separator
  1269. ----
  1270. .. _class_RichTextLabel_theme_font_size_normal_font_size:
  1271. .. rst-class:: classref-themeproperty
  1272. :ref:`int<class_int>` **normal_font_size**
  1273. The default text font size.
  1274. .. rst-class:: classref-item-separator
  1275. ----
  1276. .. _class_RichTextLabel_theme_style_focus:
  1277. .. rst-class:: classref-themeproperty
  1278. :ref:`StyleBox<class_StyleBox>` **focus**
  1279. The background used when the **RichTextLabel** is focused. The :ref:`focus<class_RichTextLabel_theme_style_focus>` :ref:`StyleBox<class_StyleBox>` is displayed *over* the base :ref:`StyleBox<class_StyleBox>`, so a partially transparent :ref:`StyleBox<class_StyleBox>` should be used to ensure the base :ref:`StyleBox<class_StyleBox>` remains visible. A :ref:`StyleBox<class_StyleBox>` that represents an outline or an underline works well for this purpose. To disable the focus visual effect, assign a :ref:`StyleBoxEmpty<class_StyleBoxEmpty>` resource. Note that disabling the focus visual effect will harm keyboard/controller navigation usability, so this is not recommended for accessibility reasons.
  1280. .. rst-class:: classref-item-separator
  1281. ----
  1282. .. _class_RichTextLabel_theme_style_normal:
  1283. .. rst-class:: classref-themeproperty
  1284. :ref:`StyleBox<class_StyleBox>` **normal**
  1285. The normal background for the **RichTextLabel**.
  1286. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  1287. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  1288. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
  1289. .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
  1290. .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
  1291. .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
  1292. .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`