class_styleboxflat.rst 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/makerst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the StyleBoxFlat.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_StyleBoxFlat:
  6. StyleBoxFlat
  7. ============
  8. **Inherits:** :ref:`StyleBox<class_StyleBox>` **<** :ref:`Resource<class_Resource>` **<** :ref:`Reference<class_Reference>` **<** :ref:`Object<class_Object>`
  9. **Category:** Core
  10. Brief Description
  11. -----------------
  12. Customizable Stylebox with a given set of parameters. (no texture required)
  13. Properties
  14. ----------
  15. +---------------------------+-------------------------------------------------------------------------------------------+
  16. | :ref:`bool<class_bool>` | :ref:`anti_aliasing<class_StyleBoxFlat_property_anti_aliasing>` |
  17. +---------------------------+-------------------------------------------------------------------------------------------+
  18. | :ref:`int<class_int>` | :ref:`anti_aliasing_size<class_StyleBoxFlat_property_anti_aliasing_size>` |
  19. +---------------------------+-------------------------------------------------------------------------------------------+
  20. | :ref:`Color<class_Color>` | :ref:`bg_color<class_StyleBoxFlat_property_bg_color>` |
  21. +---------------------------+-------------------------------------------------------------------------------------------+
  22. | :ref:`bool<class_bool>` | :ref:`border_blend<class_StyleBoxFlat_property_border_blend>` |
  23. +---------------------------+-------------------------------------------------------------------------------------------+
  24. | :ref:`Color<class_Color>` | :ref:`border_color<class_StyleBoxFlat_property_border_color>` |
  25. +---------------------------+-------------------------------------------------------------------------------------------+
  26. | :ref:`int<class_int>` | :ref:`border_width_bottom<class_StyleBoxFlat_property_border_width_bottom>` |
  27. +---------------------------+-------------------------------------------------------------------------------------------+
  28. | :ref:`int<class_int>` | :ref:`border_width_left<class_StyleBoxFlat_property_border_width_left>` |
  29. +---------------------------+-------------------------------------------------------------------------------------------+
  30. | :ref:`int<class_int>` | :ref:`border_width_right<class_StyleBoxFlat_property_border_width_right>` |
  31. +---------------------------+-------------------------------------------------------------------------------------------+
  32. | :ref:`int<class_int>` | :ref:`border_width_top<class_StyleBoxFlat_property_border_width_top>` |
  33. +---------------------------+-------------------------------------------------------------------------------------------+
  34. | :ref:`int<class_int>` | :ref:`corner_detail<class_StyleBoxFlat_property_corner_detail>` |
  35. +---------------------------+-------------------------------------------------------------------------------------------+
  36. | :ref:`int<class_int>` | :ref:`corner_radius_bottom_left<class_StyleBoxFlat_property_corner_radius_bottom_left>` |
  37. +---------------------------+-------------------------------------------------------------------------------------------+
  38. | :ref:`int<class_int>` | :ref:`corner_radius_bottom_right<class_StyleBoxFlat_property_corner_radius_bottom_right>` |
  39. +---------------------------+-------------------------------------------------------------------------------------------+
  40. | :ref:`int<class_int>` | :ref:`corner_radius_top_left<class_StyleBoxFlat_property_corner_radius_top_left>` |
  41. +---------------------------+-------------------------------------------------------------------------------------------+
  42. | :ref:`int<class_int>` | :ref:`corner_radius_top_right<class_StyleBoxFlat_property_corner_radius_top_right>` |
  43. +---------------------------+-------------------------------------------------------------------------------------------+
  44. | :ref:`bool<class_bool>` | :ref:`draw_center<class_StyleBoxFlat_property_draw_center>` |
  45. +---------------------------+-------------------------------------------------------------------------------------------+
  46. | :ref:`float<class_float>` | :ref:`expand_margin_bottom<class_StyleBoxFlat_property_expand_margin_bottom>` |
  47. +---------------------------+-------------------------------------------------------------------------------------------+
  48. | :ref:`float<class_float>` | :ref:`expand_margin_left<class_StyleBoxFlat_property_expand_margin_left>` |
  49. +---------------------------+-------------------------------------------------------------------------------------------+
  50. | :ref:`float<class_float>` | :ref:`expand_margin_right<class_StyleBoxFlat_property_expand_margin_right>` |
  51. +---------------------------+-------------------------------------------------------------------------------------------+
  52. | :ref:`float<class_float>` | :ref:`expand_margin_top<class_StyleBoxFlat_property_expand_margin_top>` |
  53. +---------------------------+-------------------------------------------------------------------------------------------+
  54. | :ref:`Color<class_Color>` | :ref:`shadow_color<class_StyleBoxFlat_property_shadow_color>` |
  55. +---------------------------+-------------------------------------------------------------------------------------------+
  56. | :ref:`int<class_int>` | :ref:`shadow_size<class_StyleBoxFlat_property_shadow_size>` |
  57. +---------------------------+-------------------------------------------------------------------------------------------+
  58. Methods
  59. -------
  60. +-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  61. | :ref:`int<class_int>` | :ref:`get_border_width_min<class_StyleBoxFlat_method_get_border_width_min>` **(** **)** const |
  62. +-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  63. | void | :ref:`set_border_width_all<class_StyleBoxFlat_method_set_border_width_all>` **(** :ref:`int<class_int>` width **)** |
  64. +-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  65. | void | :ref:`set_corner_radius_all<class_StyleBoxFlat_method_set_corner_radius_all>` **(** :ref:`int<class_int>` radius **)** |
  66. +-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  67. | void | :ref:`set_corner_radius_individual<class_StyleBoxFlat_method_set_corner_radius_individual>` **(** :ref:`int<class_int>` radius_top_left, :ref:`int<class_int>` radius_top_right, :ref:`int<class_int>` radius_bottom_right, :ref:`int<class_int>` radius_bottom_left **)** |
  68. +-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  69. | void | :ref:`set_expand_margin_all<class_StyleBoxFlat_method_set_expand_margin_all>` **(** :ref:`float<class_float>` size **)** |
  70. +-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  71. | void | :ref:`set_expand_margin_individual<class_StyleBoxFlat_method_set_expand_margin_individual>` **(** :ref:`float<class_float>` size_left, :ref:`float<class_float>` size_top, :ref:`float<class_float>` size_right, :ref:`float<class_float>` size_bottom **)** |
  72. +-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  73. Description
  74. -----------
  75. This stylebox can be used to achieve all kinds of looks without the need of a texture. Those properties are customizable:
  76. - Color
  77. - Border width (individual width for each border)
  78. - Rounded corners (individual radius for each corner)
  79. - Shadow
  80. Setting corner radius to high values is allowed. As soon as corners would overlap the stylebox will switch to a relative system. Example:
  81. ::
  82. height = 30
  83. corner_radius_top_left = 50
  84. corner_radius_bottom_left = 100
  85. The relative system now would take the 1:2 ratio of the two left corners to calculate the actual corner width. Both corners added will **never** be more than the height. Result:
  86. ::
  87. corner_radius_top_left: 10
  88. corner_radius_bottom_left: 20
  89. Property Descriptions
  90. ---------------------
  91. .. _class_StyleBoxFlat_property_anti_aliasing:
  92. - :ref:`bool<class_bool>` **anti_aliasing**
  93. +----------+-------------------------+
  94. | *Setter* | set_anti_aliased(value) |
  95. +----------+-------------------------+
  96. | *Getter* | is_anti_aliased() |
  97. +----------+-------------------------+
  98. Anti Aliasing draws a small ring around edges. This ring fades to transparent. As a result edges look much smoother. This is only noticeable when using rounded corners.
  99. ----
  100. .. _class_StyleBoxFlat_property_anti_aliasing_size:
  101. - :ref:`int<class_int>` **anti_aliasing_size**
  102. +----------+--------------------+
  103. | *Setter* | set_aa_size(value) |
  104. +----------+--------------------+
  105. | *Getter* | get_aa_size() |
  106. +----------+--------------------+
  107. This changes the size of the faded ring. Higher values can be used to achieve a "blurry" effect.
  108. ----
  109. .. _class_StyleBoxFlat_property_bg_color:
  110. - :ref:`Color<class_Color>` **bg_color**
  111. +----------+---------------------+
  112. | *Setter* | set_bg_color(value) |
  113. +----------+---------------------+
  114. | *Getter* | get_bg_color() |
  115. +----------+---------------------+
  116. The background color of the stylebox.
  117. ----
  118. .. _class_StyleBoxFlat_property_border_blend:
  119. - :ref:`bool<class_bool>` **border_blend**
  120. +----------+-------------------------+
  121. | *Setter* | set_border_blend(value) |
  122. +----------+-------------------------+
  123. | *Getter* | get_border_blend() |
  124. +----------+-------------------------+
  125. When set to ``true``, the border will fade into the background color.
  126. ----
  127. .. _class_StyleBoxFlat_property_border_color:
  128. - :ref:`Color<class_Color>` **border_color**
  129. +----------+-------------------------+
  130. | *Setter* | set_border_color(value) |
  131. +----------+-------------------------+
  132. | *Getter* | get_border_color() |
  133. +----------+-------------------------+
  134. Sets the color of the border.
  135. ----
  136. .. _class_StyleBoxFlat_property_border_width_bottom:
  137. - :ref:`int<class_int>` **border_width_bottom**
  138. +----------+-------------------------+
  139. | *Setter* | set_border_width(value) |
  140. +----------+-------------------------+
  141. | *Getter* | get_border_width() |
  142. +----------+-------------------------+
  143. Border width for the bottom border.
  144. ----
  145. .. _class_StyleBoxFlat_property_border_width_left:
  146. - :ref:`int<class_int>` **border_width_left**
  147. +----------+-------------------------+
  148. | *Setter* | set_border_width(value) |
  149. +----------+-------------------------+
  150. | *Getter* | get_border_width() |
  151. +----------+-------------------------+
  152. Border width for the left border.
  153. ----
  154. .. _class_StyleBoxFlat_property_border_width_right:
  155. - :ref:`int<class_int>` **border_width_right**
  156. +----------+-------------------------+
  157. | *Setter* | set_border_width(value) |
  158. +----------+-------------------------+
  159. | *Getter* | get_border_width() |
  160. +----------+-------------------------+
  161. Border width for the right border.
  162. ----
  163. .. _class_StyleBoxFlat_property_border_width_top:
  164. - :ref:`int<class_int>` **border_width_top**
  165. +----------+-------------------------+
  166. | *Setter* | set_border_width(value) |
  167. +----------+-------------------------+
  168. | *Getter* | get_border_width() |
  169. +----------+-------------------------+
  170. Border width for the top border.
  171. ----
  172. .. _class_StyleBoxFlat_property_corner_detail:
  173. - :ref:`int<class_int>` **corner_detail**
  174. +----------+--------------------------+
  175. | *Setter* | set_corner_detail(value) |
  176. +----------+--------------------------+
  177. | *Getter* | get_corner_detail() |
  178. +----------+--------------------------+
  179. This sets the amount of vertices used for each corner. Higher values result in rounder corners but take more processing power to compute. When choosing a value you should take the corner radius (:ref:`set_corner_radius_all<class_StyleBoxFlat_method_set_corner_radius_all>`) into account.
  180. For corner radius smaller than 10, 4-5 should be enough.
  181. For corner radius smaller than 30, 8-12 should be enough.
  182. ----
  183. .. _class_StyleBoxFlat_property_corner_radius_bottom_left:
  184. - :ref:`int<class_int>` **corner_radius_bottom_left**
  185. +----------+--------------------------+
  186. | *Setter* | set_corner_radius(value) |
  187. +----------+--------------------------+
  188. | *Getter* | get_corner_radius() |
  189. +----------+--------------------------+
  190. The corner radius of the bottom left corner. When set to 0 the corner is not rounded.
  191. ----
  192. .. _class_StyleBoxFlat_property_corner_radius_bottom_right:
  193. - :ref:`int<class_int>` **corner_radius_bottom_right**
  194. +----------+--------------------------+
  195. | *Setter* | set_corner_radius(value) |
  196. +----------+--------------------------+
  197. | *Getter* | get_corner_radius() |
  198. +----------+--------------------------+
  199. The corner radius of the bottom right corner. When set to 0 the corner is not rounded.
  200. ----
  201. .. _class_StyleBoxFlat_property_corner_radius_top_left:
  202. - :ref:`int<class_int>` **corner_radius_top_left**
  203. +----------+--------------------------+
  204. | *Setter* | set_corner_radius(value) |
  205. +----------+--------------------------+
  206. | *Getter* | get_corner_radius() |
  207. +----------+--------------------------+
  208. The corner radius of the top left corner. When set to 0 the corner is not rounded.
  209. ----
  210. .. _class_StyleBoxFlat_property_corner_radius_top_right:
  211. - :ref:`int<class_int>` **corner_radius_top_right**
  212. +----------+--------------------------+
  213. | *Setter* | set_corner_radius(value) |
  214. +----------+--------------------------+
  215. | *Getter* | get_corner_radius() |
  216. +----------+--------------------------+
  217. The corner radius of the top right corner. When set to 0 the corner is not rounded.
  218. ----
  219. .. _class_StyleBoxFlat_property_draw_center:
  220. - :ref:`bool<class_bool>` **draw_center**
  221. +----------+--------------------------+
  222. | *Setter* | set_draw_center(value) |
  223. +----------+--------------------------+
  224. | *Getter* | is_draw_center_enabled() |
  225. +----------+--------------------------+
  226. Toggels drawing of the inner part of the stylebox.
  227. ----
  228. .. _class_StyleBoxFlat_property_expand_margin_bottom:
  229. - :ref:`float<class_float>` **expand_margin_bottom**
  230. +----------+--------------------------+
  231. | *Setter* | set_expand_margin(value) |
  232. +----------+--------------------------+
  233. | *Getter* | get_expand_margin() |
  234. +----------+--------------------------+
  235. Expands the stylebox outside of the control rect on the bottom edge. Useful in combination with border_width_bottom. To draw a border outside the control rect.
  236. ----
  237. .. _class_StyleBoxFlat_property_expand_margin_left:
  238. - :ref:`float<class_float>` **expand_margin_left**
  239. +----------+--------------------------+
  240. | *Setter* | set_expand_margin(value) |
  241. +----------+--------------------------+
  242. | *Getter* | get_expand_margin() |
  243. +----------+--------------------------+
  244. Expands the stylebox outside of the control rect on the left edge. Useful in combination with border_width_left. To draw a border outside the control rect.
  245. ----
  246. .. _class_StyleBoxFlat_property_expand_margin_right:
  247. - :ref:`float<class_float>` **expand_margin_right**
  248. +----------+--------------------------+
  249. | *Setter* | set_expand_margin(value) |
  250. +----------+--------------------------+
  251. | *Getter* | get_expand_margin() |
  252. +----------+--------------------------+
  253. Expands the stylebox outside of the control rect on the right edge. Useful in combination with border_width_right. To draw a border outside the control rect.
  254. ----
  255. .. _class_StyleBoxFlat_property_expand_margin_top:
  256. - :ref:`float<class_float>` **expand_margin_top**
  257. +----------+--------------------------+
  258. | *Setter* | set_expand_margin(value) |
  259. +----------+--------------------------+
  260. | *Getter* | get_expand_margin() |
  261. +----------+--------------------------+
  262. Expands the stylebox outside of the control rect on the top edge. Useful in combination with border_width_top. To draw a border outside the control rect.
  263. ----
  264. .. _class_StyleBoxFlat_property_shadow_color:
  265. - :ref:`Color<class_Color>` **shadow_color**
  266. +----------+-------------------------+
  267. | *Setter* | set_shadow_color(value) |
  268. +----------+-------------------------+
  269. | *Getter* | get_shadow_color() |
  270. +----------+-------------------------+
  271. The color of the shadow. (This has no effect when shadow_size < 1)
  272. ----
  273. .. _class_StyleBoxFlat_property_shadow_size:
  274. - :ref:`int<class_int>` **shadow_size**
  275. +----------+------------------------+
  276. | *Setter* | set_shadow_size(value) |
  277. +----------+------------------------+
  278. | *Getter* | get_shadow_size() |
  279. +----------+------------------------+
  280. The shadow size in pixels.
  281. Method Descriptions
  282. -------------------
  283. .. _class_StyleBoxFlat_method_get_border_width_min:
  284. - :ref:`int<class_int>` **get_border_width_min** **(** **)** const
  285. ----
  286. .. _class_StyleBoxFlat_method_set_border_width_all:
  287. - void **set_border_width_all** **(** :ref:`int<class_int>` width **)**
  288. ----
  289. .. _class_StyleBoxFlat_method_set_corner_radius_all:
  290. - void **set_corner_radius_all** **(** :ref:`int<class_int>` radius **)**
  291. ----
  292. .. _class_StyleBoxFlat_method_set_corner_radius_individual:
  293. - void **set_corner_radius_individual** **(** :ref:`int<class_int>` radius_top_left, :ref:`int<class_int>` radius_top_right, :ref:`int<class_int>` radius_bottom_right, :ref:`int<class_int>` radius_bottom_left **)**
  294. ----
  295. .. _class_StyleBoxFlat_method_set_expand_margin_all:
  296. - void **set_expand_margin_all** **(** :ref:`float<class_float>` size **)**
  297. ----
  298. .. _class_StyleBoxFlat_method_set_expand_margin_individual:
  299. - void **set_expand_margin_individual** **(** :ref:`float<class_float>` size_left, :ref:`float<class_float>` size_top, :ref:`float<class_float>` size_right, :ref:`float<class_float>` size_bottom **)**