NAME

Graphics::Raylib::Color - Use predefined Raylib colors or define your own

VERSION

version 0.017

SYNOPSIS

use Graphics::Raylib::Color;
my $color   = Graphics::Raylib::Color::BLACK;
# alternatively:
use Graphics::Raylib::Color qw(:all);
my $color2  = MAROON;

my $gray    = Graphics::Raylib::Color::rgb(127,127,127);
my $rainbow = Graphics::Raylib::Color::rainbow(colors => 100);
push @colors, $rainbow->cycle for (1..100);

DESCRIPTION

Colors you can pass to raylib.

IMPLEMENTATION

As a color is basically a 32-bit integer (RGBA) in raylib, the constructors rgba and rgb do little more packing it into an integer and blessing it. Interpolating a color into a string results in a tuple of the form "(r: %u, g: %u, b: %u, a: %u)".

METHODS AND ARGUMENTS

rgba($red, $green, $blue, $alpha)

Constructs a new Graphics::Raylib::Color out of 8-bit (0-255) components.

rgb($red, $green, $blue)

Constructs a new Graphics::Raylib::Color instance out of an opaque color. Calls rgba with $alpha = 255.

($r, $g, $b, $a) = colors

Returns a list with the red, green, blue and alpha components of the color.

rgb($red, $green, $blue)

Constructs a new Graphics::Raylib::Color instance out of an opaque color. Calls rgba with $alpha = 255.

color($color_32bit)

Constructs a Color out of a 32 bit integer.

new($string, [$alpha = 255])

Returns a new Color that represent the color specified by the string. This string should be prefixed by the name of the color space to which it applies. For example

rgb:RED,GREEN,BLUE
rgb8:RRGGBB
rgb16:RRRRGGGGBBBB
hsv:HUE,SAT,VAL
hsl:HUE,SAT,LUM
cmy:CYAN,MAGENTA,YELLOW
cmyk:CYAN,MAGENTA,YELLOW,KEY

vga:NAME
vga:INDEX

x11:NAME

This leverages Convert::Color under the hood. Refer to its documentation for more information.

hsv($hue, $sat, $val, [$alpha = 255])

Returns a new Color out of HSV components.

PREDEFINED COLORS

use constant LIGHTGRAY => rgb( 200, 200, 200 );
use constant GRAY      => rgb( 130, 130, 130 );
use constant DARKGRAY  => rgb( 80,  80,  80  );
use constant LIGHTGREY => rgb( 200, 200, 200 );
use constant GREY      => rgb( 130, 130, 130 );
use constant DARKGREY  => rgb( 80,  80,  80  );
use constant YELLOW    => rgb( 253, 249, 0   );
use constant GOLD      => rgb( 255, 203, 0   );
use constant ORANGE    => rgb( 255, 161, 0   );
use constant PINK      => rgb( 255, 109, 194 );
use constant RED       => rgb( 230, 41,  55  );
use constant MAROON    => rgb( 190, 33,  55  );
use constant GREEN     => rgb( 0,   228, 48  );
use constant LIME      => rgb( 0,   158, 47  );
use constant DARKGREEN => rgb( 0,   117, 44  );
use constant SKYBLUE   => rgb( 102, 191, 255 );
use constant BLUE      => rgb( 0,   121, 241 );
use constant DARKBLUE  => rgb( 0,   82,  172 );
use constant PURPLE    => rgb( 200, 122, 255 );
use constant VIOLET    => rgb( 135, 60,  190 );
use constant DARKPURPL => rgb( 112, 31,  126 );
use constant BEIGE     => rgb( 211, 176, 131 );
use constant BROWN     => rgb( 127, 106, 79  );
use constant DARKBROWN => rgb( 76,  63,  47  );

use constant WHITE     => rgb( 255, 255, 255 );
use constant BLACK     => rgb( 0,   0,   0   );
use constant BLANK     => rgba(  0, 0, 0, 0  );
use constant MAGENTA   => rgb( 255, 0,   255 );
use constant RAYWHITE  => rgb( 245, 245, 245 );
rainbow(colors => $color_count)

Returns a code reference that cycles through the rainbow colors on each evaluation. $color_count is the total number of colors before bouncing back. Default is 7.

GIT REPOSITORY

http://github.com/athreef/Graphics-Raylib

SEE ALSO

Graphics-Raylib

Graphics-Raylib-XS

AUTHOR

Ahmad Fatoum <athreef@cpan.org>, http://a3f.at

COPYRIGHT AND LICENSE

Copyright (C) 2017 Ahmad Fatoum

This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.