| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260 |
- <?xml version="1.0" encoding="UTF-8" ?>
- <class name="float" version="4.0">
- <brief_description>
- Float built-in type.
- </brief_description>
- <description>
- The [float] built-in type is a 64-bit double-precision floating-point number, equivalent to [code]double[/code] in C++. This type has 14 reliable decimal digits of precision. The [float] type can be stored in [Variant], which is the generic type used by the engine. The maximum value of [float] is approximately [code]1.79769e308[/code], and the minimum is approximately [code]-1.79769e308[/code].
- Many methods and properties in the engine use 32-bit single-precision floating-point numbers instead, equivalent to [code]float[/code] in C++, which have 6 reliable decimal digits of precision. For data structures such as [Vector2] and [Vector3], Godot uses 32-bit floating-point numbers by default, but it can be changed to use 64-bit doubles if Godot is compiled with the [code]float=64[/code] option.
- Math done using the [float] type is not guaranteed to be exact or deterministic, and will often result in small errors. You should usually use the [method @GlobalScope.is_equal_approx] and [method @GlobalScope.is_zero_approx] methods instead of [code]==[/code] to compare [float] values for equality.
- </description>
- <tutorials>
- <link title="Wikipedia: Double-precision floating-point format">https://en.wikipedia.org/wiki/Double-precision_floating-point_format</link>
- <link title="Wikipedia: Single-precision floating-point format">https://en.wikipedia.org/wiki/Single-precision_floating-point_format</link>
- </tutorials>
- <constructors>
- <constructor name="float">
- <return type="float" />
- <description>
- Constructs a default-initialized [float] set to [code]0.0[/code].
- </description>
- </constructor>
- <constructor name="float">
- <return type="float" />
- <argument index="0" name="from" type="float" />
- <description>
- Constructs a [float] as a copy of the given [float].
- </description>
- </constructor>
- <constructor name="float">
- <return type="float" />
- <argument index="0" name="from" type="bool" />
- <description>
- Cast a [bool] value to a floating-point value, [code]float(true)[/code] will be equal to 1.0 and [code]float(false)[/code] will be equal to 0.0.
- </description>
- </constructor>
- <constructor name="float">
- <return type="float" />
- <argument index="0" name="from" type="int" />
- <description>
- Cast an [int] value to a floating-point value, [code]float(1)[/code] will be equal to [code]1.0[/code].
- </description>
- </constructor>
- </constructors>
- <operators>
- <operator name="operator !=">
- <return type="bool" />
- <description>
- </description>
- </operator>
- <operator name="operator !=">
- <return type="bool" />
- <argument index="0" name="right" type="float" />
- <description>
- Returns [code]true[/code] if two floats are different from each other.
- </description>
- </operator>
- <operator name="operator !=">
- <return type="bool" />
- <argument index="0" name="right" type="int" />
- <description>
- Returns [code]true[/code] if the integer has different value than the float.
- </description>
- </operator>
- <operator name="operator *">
- <return type="float" />
- <argument index="0" name="right" type="float" />
- <description>
- Multiplies two [float]s.
- </description>
- </operator>
- <operator name="operator *">
- <return type="Quaternion" />
- <argument index="0" name="right" type="Quaternion" />
- <description>
- Multiplies each component of the [Quaternion] by the given [float].
- </description>
- </operator>
- <operator name="operator *">
- <return type="Vector2" />
- <argument index="0" name="right" type="Vector2" />
- <description>
- Multiplies each component of the [Vector2] by the given [float].
- [codeblock]
- print(2.5 * Vector2(1, 1)) # Vector2(2.5, 2.5)
- [/codeblock]
- </description>
- </operator>
- <operator name="operator *">
- <return type="Vector2i" />
- <argument index="0" name="right" type="Vector2i" />
- <description>
- Multiplies each component of the [Vector2i] by the given [float].
- [codeblock]
- print(2.0 * Vector2i(1, 1)) # Vector2i(2.0, 2.0)
- [/codeblock]
- </description>
- </operator>
- <operator name="operator *">
- <return type="Vector3" />
- <argument index="0" name="right" type="Vector3" />
- <description>
- Multiplies each component of the [Vector3] by the given [float].
- </description>
- </operator>
- <operator name="operator *">
- <return type="Vector3i" />
- <argument index="0" name="right" type="Vector3i" />
- <description>
- Multiplies each component of the [Vector3i] by the given [float].
- </description>
- </operator>
- <operator name="operator *">
- <return type="Color" />
- <argument index="0" name="right" type="Color" />
- <description>
- Multiplies each component of the [Color] by the given [float].
- [codeblock]
- print(1.5 * Color(0.5, 0.5, 0.5)) # Color(0.75, 0.75, 0.75)
- [/codeblock]
- </description>
- </operator>
- <operator name="operator *">
- <return type="float" />
- <argument index="0" name="right" type="int" />
- <description>
- Multiplies a [float] and an [int]. The result is a [float].
- </description>
- </operator>
- <operator name="operator +">
- <return type="float" />
- <argument index="0" name="right" type="float" />
- <description>
- Adds two floats.
- </description>
- </operator>
- <operator name="operator +">
- <return type="float" />
- <argument index="0" name="right" type="int" />
- <description>
- Adds a [float] and an [int]. The result is a [float].
- </description>
- </operator>
- <operator name="operator -">
- <return type="float" />
- <argument index="0" name="right" type="float" />
- <description>
- Subtracts a float from a float.
- </description>
- </operator>
- <operator name="operator -">
- <return type="float" />
- <argument index="0" name="right" type="int" />
- <description>
- Subtracts an [int] from a [float]. The result is a [float].
- </description>
- </operator>
- <operator name="operator /">
- <return type="float" />
- <argument index="0" name="right" type="float" />
- <description>
- Divides two floats.
- </description>
- </operator>
- <operator name="operator /">
- <return type="float" />
- <argument index="0" name="right" type="int" />
- <description>
- Divides a [float] by an [int]. The result is a [float].
- </description>
- </operator>
- <operator name="operator <">
- <return type="bool" />
- <argument index="0" name="right" type="float" />
- <description>
- Returns [code]true[/code] the left float is less than the right one.
- </description>
- </operator>
- <operator name="operator <">
- <return type="bool" />
- <argument index="0" name="right" type="int" />
- <description>
- Returns [code]true[/code] if this [float] is less than the given [int].
- </description>
- </operator>
- <operator name="operator <=">
- <return type="bool" />
- <argument index="0" name="right" type="float" />
- <description>
- Returns [code]true[/code] the left integer is less than or equal to the right one.
- </description>
- </operator>
- <operator name="operator <=">
- <return type="bool" />
- <argument index="0" name="right" type="int" />
- <description>
- Returns [code]true[/code] if this [float] is less than or equal to the given [int].
- </description>
- </operator>
- <operator name="operator ==">
- <return type="bool" />
- <description>
- </description>
- </operator>
- <operator name="operator ==">
- <return type="bool" />
- <argument index="0" name="right" type="float" />
- <description>
- Returns [code]true[/code] if both floats are exactly equal.
- [b]Note:[/b] Due to floating-point precision errors, consider using [method @GlobalScope.is_equal_approx] or [method @GlobalScope.is_zero_approx] instead, which are more reliable.
- </description>
- </operator>
- <operator name="operator ==">
- <return type="bool" />
- <argument index="0" name="right" type="int" />
- <description>
- Returns [code]true[/code] if the [float] and the given [int] are equal.
- </description>
- </operator>
- <operator name="operator >">
- <return type="bool" />
- <argument index="0" name="right" type="float" />
- <description>
- Returns [code]true[/code] the left float is greater than the right one.
- </description>
- </operator>
- <operator name="operator >">
- <return type="bool" />
- <argument index="0" name="right" type="int" />
- <description>
- Returns [code]true[/code] if this [float] is greater than the given [int].
- </description>
- </operator>
- <operator name="operator >=">
- <return type="bool" />
- <argument index="0" name="right" type="float" />
- <description>
- Returns [code]true[/code] the left float is greater than or equal to the right one.
- </description>
- </operator>
- <operator name="operator >=">
- <return type="bool" />
- <argument index="0" name="right" type="int" />
- <description>
- Returns [code]true[/code] if this [float] is greater than or equal to the given [int].
- </description>
- </operator>
- <operator name="operator unary+">
- <return type="float" />
- <description>
- Returns the same value as if the [code]+[/code] was not there. Unary [code]+[/code] does nothing, but sometimes it can make your code more readable.
- </description>
- </operator>
- <operator name="operator unary-">
- <return type="float" />
- <description>
- Returns the negative value of the [float]. If positive, turns the number negative. If negative, turns the number positive. With floats, the number zero can be either positive or negative.
- </description>
- </operator>
- </operators>
- </class>
|