2017-09-12 20:42:36 +00:00
<?xml version="1.0" encoding="UTF-8" ?>
2018-02-27 12:40:43 +00:00
<class name= "Color" category= "Built-In Types" version= "3.1" >
2017-09-12 20:42:36 +00:00
<brief_description >
Color in RGBA format with some support for ARGB format.
</brief_description>
<description >
A color is represented as red, green and blue (r,g,b) components. Additionally, "a" represents the alpha component, often used for transparency. Values are in floating point and usually range from 0 to 1. Some methods (such as set_modulate(color)) may accept values > 1.
2017-12-15 15:43:27 +00:00
You can also create a color from standardised color names with Color.ColorN (e.g. Color.green) or [method @GDScript.ColorN].
2017-09-12 20:42:36 +00:00
</description>
<tutorials >
</tutorials>
<demos >
</demos>
<methods >
<method name= "Color" >
<return type= "Color" >
</return>
2018-07-26 09:56:21 +00:00
<argument index= "0" name= "from" type= "String" >
2017-09-12 20:42:36 +00:00
</argument>
<description >
2018-07-26 09:56:21 +00:00
Constructs a color from an HTML hexadecimal color string in ARGB or RGB format. See also [method @GDScript.ColorN].
The following string formats are supported:
[code]"#ff00ff00"[/code] - ARGB format with '#'
[code]"ff00ff00"[/code] - ARGB format
[code]"#ff00ff"[/code] - RGB format with '#'
[code]"ff00ff"[/code] - RGB format
2017-09-12 20:42:36 +00:00
[codeblock]
2018-07-26 09:56:21 +00:00
# The following code creates the same color of an RGBA(178, 217, 10, 255)
var c1 = Color("#ffb2d90a") # ARGB format with '#'
var c2 = Color("ffb2d90a") # ARGB format
var c3 = Color("#b2d90a") # RGB format with '#'
var c4 = Color("b2d90a") # RGB format
2017-09-12 20:42:36 +00:00
[/codeblock]
</description>
</method>
<method name= "Color" >
<return type= "Color" >
</return>
2018-07-26 09:56:21 +00:00
<argument index= "0" name= "from" type= "int" >
2017-09-12 20:42:36 +00:00
</argument>
<description >
2018-07-26 09:56:21 +00:00
Constructs a color from a 32-bit integer (each byte represents a component of the RGBA profile).
2017-09-12 20:42:36 +00:00
[codeblock]
2018-07-26 09:56:21 +00:00
var c = Color(274) # a color of an RGBA(0, 0, 1, 18)
2017-09-12 20:42:36 +00:00
[/codeblock]
</description>
</method>
<method name= "Color" >
<return type= "Color" >
</return>
2018-07-26 09:56:21 +00:00
<argument index= "0" name= "r" type= "float" >
</argument>
<argument index= "1" name= "g" type= "float" >
</argument>
<argument index= "2" name= "b" type= "float" >
2017-09-12 20:42:36 +00:00
</argument>
<description >
2018-07-26 09:56:21 +00:00
Constructs a color from an RGB profile using values between 0 and 1 (float). Alpha will always be 1.
2017-09-12 20:42:36 +00:00
[codeblock]
2018-07-26 09:56:21 +00:00
var c = Color(0.2, 1.0, .7) # a color of an RGBA(51, 255, 178, 255)
2017-09-12 20:42:36 +00:00
[/codeblock]
</description>
</method>
<method name= "Color" >
<return type= "Color" >
</return>
2018-07-26 09:56:21 +00:00
<argument index= "0" name= "r" type= "float" >
</argument>
<argument index= "1" name= "g" type= "float" >
</argument>
<argument index= "2" name= "b" type= "float" >
</argument>
<argument index= "3" name= "a" type= "float" >
2017-09-12 20:42:36 +00:00
</argument>
<description >
2018-07-26 09:56:21 +00:00
Constructs a color from an RGBA profile using values between 0 and 1 (float).
2017-09-12 20:42:36 +00:00
[codeblock]
2018-07-26 09:56:21 +00:00
var c = Color(0.2, 1.0, .7, .8) # a color of an RGBA(51, 255, 178, 204)
2017-09-12 20:42:36 +00:00
[/codeblock]
</description>
</method>
<method name= "blend" >
<return type= "Color" >
</return>
<argument index= "0" name= "over" type= "Color" >
</argument>
<description >
Returns a new color resulting from blending this color over another color. If the color is opaque, the result would also be opaque. The other color could then take a range of values with different alpha values.
[codeblock]
var bg = Color(0.0, 1.0, 0.0, 0.5) # Green with alpha of 50%
var fg = Color(1.0, 0.0, 0.0, .5) # Red with alpha of 50%
var blendedColor = bg.blend(fg) # Brown with alpha of 75%
[/codeblock]
</description>
</method>
<method name= "contrasted" >
<return type= "Color" >
</return>
<description >
Returns the most contrasting color.
[codeblock]
var c = Color(.3, .4, .9)
var contrastedColor = c.contrasted() # a color of an RGBA(204, 229, 102, 255)
[/codeblock]
</description>
</method>
2017-11-24 08:16:27 +00:00
<method name= "darkened" >
<return type= "Color" >
</return>
<argument index= "0" name= "amount" type= "float" >
</argument>
<description >
Returns a new color resulting from making this color darker by the specified percentage (0-1).
[codeblock]
var green = Color(0.0, 1.0, 0.0)
var darkgreen = green.darkened(0.2) # 20% darker than regular green
[/codeblock]
</description>
</method>
2018-02-25 06:19:42 +00:00
<method name= "from_hsv" >
<return type= "Color" >
</return>
<argument index= "0" name= "h" type= "float" >
</argument>
<argument index= "1" name= "s" type= "float" >
</argument>
<argument index= "2" name= "v" type= "float" >
</argument>
<argument index= "3" name= "a" type= "float" default= "1" >
</argument>
<description >
2018-05-11 11:57:11 +00:00
Constructs a color from an HSV profile. [code]h[/code], [code]s[/code], and [code]v[/code] are values between 0 and 1.
2018-02-25 06:19:42 +00:00
[codeblock]
2018-05-11 11:57:11 +00:00
var c = Color.from_hsv(0.58, 0.5, 0.79, 0.8) # equivalent to HSV(210, 50, 79, 0.8) or Color8(100, 151, 201, 0.8)
2018-02-25 06:19:42 +00:00
[/codeblock]
</description>
</method>
2017-09-12 20:42:36 +00:00
<method name= "gray" >
<return type= "float" >
</return>
<description >
Returns the color's grayscale.
The gray is calculated by (r + g + b) / 3.
[codeblock]
var c = Color(0.2, 0.45, 0.82)
var gray = c.gray() # a value of 0.466667
[/codeblock]
</description>
</method>
<method name= "inverted" >
<return type= "Color" >
</return>
<description >
Returns the inverted color (1-r, 1-g, 1-b, 1-a).
[codeblock]
var c = Color(.3, .4, .9)
var invertedColor = c.inverted() # a color of an RGBA(178, 153, 26, 255)
[/codeblock]
</description>
</method>
2017-10-13 04:49:31 +00:00
<method name= "lightened" >
<return type= "Color" >
</return>
<argument index= "0" name= "amount" type= "float" >
</argument>
<description >
Returns a new color resulting from making this color lighter by the specified percentage (0-1).
[codeblock]
var green = Color(0.0, 1.0, 0.0)
var lightgreen = green.lightened(0.2) # 20% lighter than regular green
[/codeblock]
</description>
</method>
2017-09-12 20:42:36 +00:00
<method name= "linear_interpolate" >
<return type= "Color" >
</return>
<argument index= "0" name= "b" type= "Color" >
</argument>
<argument index= "1" name= "t" type= "float" >
</argument>
<description >
Returns the color of the linear interpolation with another color. The value t is between 0 and 1 (float).
[codeblock]
var c1 = Color(1.0, 0.0, 0.0)
var c2 = Color(0.0, 1.0, 0.0)
var li_c = c1.linear_interpolate(c2, 0.5) # a color of an RGBA(128, 128, 0, 255)
[/codeblock]
</description>
</method>
2018-07-26 09:56:21 +00:00
<method name= "to_abgr32" >
<return type= "int" >
2017-09-12 20:42:36 +00:00
</return>
<description >
2018-07-26 09:56:21 +00:00
Returns the color's 32-bit integer in ABGR format (each byte represents a component of the ABGR profile). ABGR is the reversed version of the default format.
2017-09-12 20:42:36 +00:00
[codeblock]
2018-07-26 09:56:21 +00:00
var c = Color(1, .5, .2)
print(c.to_abgr32()) # Prints 4281565439
2017-09-12 20:42:36 +00:00
[/codeblock]
</description>
</method>
2018-07-26 09:56:21 +00:00
<method name= "to_abgr64" >
2018-07-25 20:33:42 +00:00
<return type= "int" >
</return>
<description >
2018-07-26 09:56:21 +00:00
Returns the color's 64-bit integer in ABGR format (each word represents a component of the ABGR profile). ABGR is the reversed version of the default format.
2018-07-25 20:33:42 +00:00
[codeblock]
var c = Color(1, .5, .2)
2018-07-26 09:56:21 +00:00
print(c.to_abgr64()) # Prints -225178692812801
2018-07-25 20:33:42 +00:00
[/codeblock]
</description>
</method>
2018-07-26 09:56:21 +00:00
<method name= "to_argb32" >
2018-07-25 20:33:42 +00:00
<return type= "int" >
</return>
<description >
2018-07-26 09:56:21 +00:00
Returns the color's 32-bit integer in ARGB format (each byte represents a component of the ARGB profile). ARGB is more compatible with DirectX.
2018-07-25 20:33:42 +00:00
[codeblock]
var c = Color(1, .5, .2)
2018-07-26 09:56:21 +00:00
print(c.to_argb32()) # Prints 4294934323
2018-07-25 20:33:42 +00:00
[/codeblock]
</description>
</method>
2018-07-26 09:56:21 +00:00
<method name= "to_argb64" >
2017-09-12 20:42:36 +00:00
<return type= "int" >
</return>
<description >
2018-07-26 09:56:21 +00:00
Returns the color's 64-bit integer in ARGB format (each word represents a component of the ARGB profile). ARGB is more compatible with DirectX.
2018-07-25 20:33:42 +00:00
[codeblock]
var c = Color(1, .5, .2)
2018-07-26 09:56:21 +00:00
print(c.to_argb64()) # Prints -2147470541
2018-07-25 20:33:42 +00:00
[/codeblock]
</description>
</method>
2018-07-26 09:56:21 +00:00
<method name= "to_html" >
<return type= "String" >
2018-07-25 20:33:42 +00:00
</return>
2018-07-26 09:56:21 +00:00
<argument index= "0" name= "with_alpha" type= "bool" default= "True" >
</argument>
2018-07-25 20:33:42 +00:00
<description >
2018-07-26 09:56:21 +00:00
Returns the color's HTML hexadecimal color string in ARGB format (ex: [code]ff34f822[/code]).
Optionally flag 'false' to not include alpha in hexadecimal string.
2018-07-25 20:33:42 +00:00
[codeblock]
2018-07-26 09:56:21 +00:00
var c = Color(1, 1, 1, .5)
var s1 = c.to_html() # Results "7fffffff"
var s2 = c.to_html(false) # Results 'ffffff'
2018-07-25 20:33:42 +00:00
[/codeblock]
</description>
</method>
2018-07-26 09:56:21 +00:00
<method name= "to_rgba32" >
2018-07-25 20:33:42 +00:00
<return type= "int" >
</return>
<description >
2018-07-26 09:56:21 +00:00
Returns the color's 32-bit integer in RGBA format (each byte represents a component of the RGBA profile). RGBA is the format that Godot uses by default.
2018-07-25 20:33:42 +00:00
[codeblock]
var c = Color(1, .5, .2)
2018-07-26 09:56:21 +00:00
print(c.to_rgba32()) # Prints 4286526463
2018-07-25 20:33:42 +00:00
[/codeblock]
</description>
</method>
<method name= "to_rgba64" >
<return type= "int" >
</return>
<description >
Returns the color's 64-bit integer in RGBA format (each word represents a component of the RGBA profile). RGBA is the format that Godot uses by default.
2017-09-12 20:42:36 +00:00
[codeblock]
var c = Color(1, .5, .2)
2018-07-25 20:33:42 +00:00
print(c.to_rgba64()) # Prints -140736629309441
2017-09-12 20:42:36 +00:00
[/codeblock]
</description>
</method>
</methods>
<members >
2017-09-13 06:49:40 +00:00
<member name= "a" type= "float" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Alpha (0 to 1)
</member>
2017-09-13 06:49:40 +00:00
<member name= "a8" type= "int" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Alpha (0 to 255)
</member>
2017-09-13 06:49:40 +00:00
<member name= "b" type= "float" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Blue (0 to 1)
</member>
2017-09-13 06:49:40 +00:00
<member name= "b8" type= "int" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Blue (0 to 255)
</member>
2017-09-13 06:49:40 +00:00
<member name= "g" type= "float" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Green (0 to 1)
</member>
2017-09-13 06:49:40 +00:00
<member name= "g8" type= "int" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Green (0 to 255)
</member>
2017-09-13 06:49:40 +00:00
<member name= "h" type= "float" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Hue (0 to 1)
</member>
2017-09-13 06:49:40 +00:00
<member name= "r" type= "float" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Red (0 to 1)
</member>
2017-09-13 06:49:40 +00:00
<member name= "r8" type= "int" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Red (0 to 255)
</member>
2017-09-13 06:49:40 +00:00
<member name= "s" type= "float" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Saturation (0 to 1)
</member>
2017-09-13 06:49:40 +00:00
<member name= "v" type= "float" setter= "" getter= "" >
2017-09-12 20:42:36 +00:00
Value (0 to 1)
</member>
</members>
<constants >
</constants>
</class>