class_range.rst 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/make_rst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the Range.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_Range:
  6. Range
  7. =====
  8. **Inherits:** :ref:`Control<class_Control>` **<** :ref:`CanvasItem<class_CanvasItem>` **<** :ref:`Node<class_Node>` **<** :ref:`Object<class_Object>`
  9. **Inherited By:** :ref:`EditorSpinSlider<class_EditorSpinSlider>`, :ref:`ProgressBar<class_ProgressBar>`, :ref:`ScrollBar<class_ScrollBar>`, :ref:`Slider<class_Slider>`, :ref:`SpinBox<class_SpinBox>`, :ref:`TextureProgress<class_TextureProgress>`
  10. Abstract base class for range-based controls.
  11. Description
  12. -----------
  13. Range is a base class for :ref:`Control<class_Control>` nodes that change a floating-point *value* between a *minimum* and a *maximum*, using *step* and *page*, for example a :ref:`ScrollBar<class_ScrollBar>`.
  14. Properties
  15. ----------
  16. +---------------------------+----------------------------------------------------------+-----------+
  17. | :ref:`bool<class_bool>` | :ref:`allow_greater<class_Range_property_allow_greater>` | ``false`` |
  18. +---------------------------+----------------------------------------------------------+-----------+
  19. | :ref:`bool<class_bool>` | :ref:`allow_lesser<class_Range_property_allow_lesser>` | ``false`` |
  20. +---------------------------+----------------------------------------------------------+-----------+
  21. | :ref:`bool<class_bool>` | :ref:`exp_edit<class_Range_property_exp_edit>` | ``false`` |
  22. +---------------------------+----------------------------------------------------------+-----------+
  23. | :ref:`float<class_float>` | :ref:`max_value<class_Range_property_max_value>` | ``100.0`` |
  24. +---------------------------+----------------------------------------------------------+-----------+
  25. | :ref:`float<class_float>` | :ref:`min_value<class_Range_property_min_value>` | ``0.0`` |
  26. +---------------------------+----------------------------------------------------------+-----------+
  27. | :ref:`float<class_float>` | :ref:`page<class_Range_property_page>` | ``0.0`` |
  28. +---------------------------+----------------------------------------------------------+-----------+
  29. | :ref:`float<class_float>` | :ref:`ratio<class_Range_property_ratio>` | |
  30. +---------------------------+----------------------------------------------------------+-----------+
  31. | :ref:`bool<class_bool>` | :ref:`rounded<class_Range_property_rounded>` | ``false`` |
  32. +---------------------------+----------------------------------------------------------+-----------+
  33. | :ref:`float<class_float>` | :ref:`step<class_Range_property_step>` | ``1.0`` |
  34. +---------------------------+----------------------------------------------------------+-----------+
  35. | :ref:`float<class_float>` | :ref:`value<class_Range_property_value>` | ``0.0`` |
  36. +---------------------------+----------------------------------------------------------+-----------+
  37. Methods
  38. -------
  39. +------+---------------------------------------------------------------------------------+
  40. | void | :ref:`share<class_Range_method_share>` **(** :ref:`Node<class_Node>` with **)** |
  41. +------+---------------------------------------------------------------------------------+
  42. | void | :ref:`unshare<class_Range_method_unshare>` **(** **)** |
  43. +------+---------------------------------------------------------------------------------+
  44. Signals
  45. -------
  46. .. _class_Range_signal_changed:
  47. - **changed** **(** **)**
  48. Emitted when :ref:`min_value<class_Range_property_min_value>`, :ref:`max_value<class_Range_property_max_value>`, :ref:`page<class_Range_property_page>`, or :ref:`step<class_Range_property_step>` change.
  49. ----
  50. .. _class_Range_signal_value_changed:
  51. - **value_changed** **(** :ref:`float<class_float>` value **)**
  52. Emitted when :ref:`value<class_Range_property_value>` changes. When used on a :ref:`Slider<class_Slider>`, this is called continuously while dragging (potentially every frame). If you are performing an expensive operation in a function connected to :ref:`value_changed<class_Range_signal_value_changed>`, consider using a *debouncing* :ref:`Timer<class_Timer>` to call the function less often.
  53. **Note:** Unlike signals such as :ref:`LineEdit.text_changed<class_LineEdit_signal_text_changed>`, :ref:`value_changed<class_Range_signal_value_changed>` is also emitted when ``value`` is set directly via code.
  54. Property Descriptions
  55. ---------------------
  56. .. _class_Range_property_allow_greater:
  57. - :ref:`bool<class_bool>` **allow_greater**
  58. +-----------+--------------------------+
  59. | *Default* | ``false`` |
  60. +-----------+--------------------------+
  61. | *Setter* | set_allow_greater(value) |
  62. +-----------+--------------------------+
  63. | *Getter* | is_greater_allowed() |
  64. +-----------+--------------------------+
  65. If ``true``, :ref:`value<class_Range_property_value>` may be greater than :ref:`max_value<class_Range_property_max_value>`.
  66. ----
  67. .. _class_Range_property_allow_lesser:
  68. - :ref:`bool<class_bool>` **allow_lesser**
  69. +-----------+-------------------------+
  70. | *Default* | ``false`` |
  71. +-----------+-------------------------+
  72. | *Setter* | set_allow_lesser(value) |
  73. +-----------+-------------------------+
  74. | *Getter* | is_lesser_allowed() |
  75. +-----------+-------------------------+
  76. If ``true``, :ref:`value<class_Range_property_value>` may be less than :ref:`min_value<class_Range_property_min_value>`.
  77. ----
  78. .. _class_Range_property_exp_edit:
  79. - :ref:`bool<class_bool>` **exp_edit**
  80. +-----------+----------------------+
  81. | *Default* | ``false`` |
  82. +-----------+----------------------+
  83. | *Setter* | set_exp_ratio(value) |
  84. +-----------+----------------------+
  85. | *Getter* | is_ratio_exp() |
  86. +-----------+----------------------+
  87. If ``true``, and ``min_value`` is greater than 0, ``value`` will be represented exponentially rather than linearly.
  88. ----
  89. .. _class_Range_property_max_value:
  90. - :ref:`float<class_float>` **max_value**
  91. +-----------+----------------+
  92. | *Default* | ``100.0`` |
  93. +-----------+----------------+
  94. | *Setter* | set_max(value) |
  95. +-----------+----------------+
  96. | *Getter* | get_max() |
  97. +-----------+----------------+
  98. Maximum value. Range is clamped if ``value`` is greater than ``max_value``.
  99. ----
  100. .. _class_Range_property_min_value:
  101. - :ref:`float<class_float>` **min_value**
  102. +-----------+----------------+
  103. | *Default* | ``0.0`` |
  104. +-----------+----------------+
  105. | *Setter* | set_min(value) |
  106. +-----------+----------------+
  107. | *Getter* | get_min() |
  108. +-----------+----------------+
  109. Minimum value. Range is clamped if ``value`` is less than ``min_value``.
  110. ----
  111. .. _class_Range_property_page:
  112. - :ref:`float<class_float>` **page**
  113. +-----------+-----------------+
  114. | *Default* | ``0.0`` |
  115. +-----------+-----------------+
  116. | *Setter* | set_page(value) |
  117. +-----------+-----------------+
  118. | *Getter* | get_page() |
  119. +-----------+-----------------+
  120. Page size. Used mainly for :ref:`ScrollBar<class_ScrollBar>`. ScrollBar's length is its size multiplied by ``page`` over the difference between ``min_value`` and ``max_value``.
  121. ----
  122. .. _class_Range_property_ratio:
  123. - :ref:`float<class_float>` **ratio**
  124. +----------+---------------------+
  125. | *Setter* | set_as_ratio(value) |
  126. +----------+---------------------+
  127. | *Getter* | get_as_ratio() |
  128. +----------+---------------------+
  129. The value mapped between 0 and 1.
  130. ----
  131. .. _class_Range_property_rounded:
  132. - :ref:`bool<class_bool>` **rounded**
  133. +-----------+-------------------------------+
  134. | *Default* | ``false`` |
  135. +-----------+-------------------------------+
  136. | *Setter* | set_use_rounded_values(value) |
  137. +-----------+-------------------------------+
  138. | *Getter* | is_using_rounded_values() |
  139. +-----------+-------------------------------+
  140. If ``true``, ``value`` will always be rounded to the nearest integer.
  141. ----
  142. .. _class_Range_property_step:
  143. - :ref:`float<class_float>` **step**
  144. +-----------+-----------------+
  145. | *Default* | ``1.0`` |
  146. +-----------+-----------------+
  147. | *Setter* | set_step(value) |
  148. +-----------+-----------------+
  149. | *Getter* | get_step() |
  150. +-----------+-----------------+
  151. If greater than 0, ``value`` will always be rounded to a multiple of ``step``. If ``rounded`` is also ``true``, ``value`` will first be rounded to a multiple of ``step`` then rounded to the nearest integer.
  152. ----
  153. .. _class_Range_property_value:
  154. - :ref:`float<class_float>` **value**
  155. +-----------+------------------+
  156. | *Default* | ``0.0`` |
  157. +-----------+------------------+
  158. | *Setter* | set_value(value) |
  159. +-----------+------------------+
  160. | *Getter* | get_value() |
  161. +-----------+------------------+
  162. Range's current value.
  163. Method Descriptions
  164. -------------------
  165. .. _class_Range_method_share:
  166. - void **share** **(** :ref:`Node<class_Node>` with **)**
  167. Binds two ``Range``\ s together along with any ranges previously grouped with either of them. When any of range's member variables change, it will share the new value with all other ranges in its group.
  168. ----
  169. .. _class_Range_method_unshare:
  170. - void **unshare** **(** **)**
  171. Stops the ``Range`` from sharing its member variables with any other.
  172. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  173. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  174. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`