|  |  |  | GIMP Color Library Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
                    GimpRGB;
enum                GimpRGBCompositeMode;
void                gimp_rgb_set                        (GimpRGB *rgb,
                                                         gdouble red,
                                                         gdouble green,
                                                         gdouble blue);
void                gimp_rgb_set_alpha                  (GimpRGB *rgb,
                                                         gdouble alpha);
void                gimp_rgb_set_uchar                  (GimpRGB *rgb,
                                                         guchar red,
                                                         guchar green,
                                                         guchar blue);
void                gimp_rgb_get_uchar                  (const GimpRGB *rgb,
                                                         guchar *red,
                                                         guchar *green,
                                                         guchar *blue);
gboolean            gimp_rgb_parse_name                 (GimpRGB *rgb,
                                                         const gchar *name,
                                                         gint len);
gboolean            gimp_rgb_parse_hex                  (GimpRGB *rgb,
                                                         const gchar *hex,
                                                         gint len);
gboolean            gimp_rgb_parse_css                  (GimpRGB *rgb,
                                                         const gchar *css,
                                                         gint len);
gint                gimp_rgb_list_names                 (const gchar ***names,
                                                         GimpRGB **colors);
void                gimp_rgb_add                        (GimpRGB *rgb1,
                                                         const GimpRGB *rgb2);
void                gimp_rgb_subtract                   (GimpRGB *rgb1,
                                                         const GimpRGB *rgb2);
void                gimp_rgb_multiply                   (GimpRGB *rgb1,
                                                         gdouble factor);
gdouble             gimp_rgb_distance                   (const GimpRGB *rgb1,
                                                         const GimpRGB *rgb2);
gdouble             gimp_rgb_max                        (const GimpRGB *rgb);
gdouble             gimp_rgb_min                        (const GimpRGB *rgb);
void                gimp_rgb_clamp                      (GimpRGB *rgb);
void                gimp_rgb_gamma                      (GimpRGB *rgb,
                                                         gdouble gamma);
gdouble             gimp_rgb_luminance                  (const GimpRGB *rgb);
guchar              gimp_rgb_luminance_uchar            (const GimpRGB *rgb);
gdouble             gimp_rgb_intensity                  (const GimpRGB *rgb);
guchar              gimp_rgb_intensity_uchar            (const GimpRGB *rgb);
void                gimp_rgb_composite                  (GimpRGB *color1,
                                                         const GimpRGB *color2,
                                                         GimpRGBCompositeMode mode);
void                gimp_rgba_set                       (GimpRGB *rgba,
                                                         gdouble red,
                                                         gdouble green,
                                                         gdouble blue,
                                                         gdouble alpha);
void                gimp_rgba_set_uchar                 (GimpRGB *rgba,
                                                         guchar red,
                                                         guchar green,
                                                         guchar blue,
                                                         guchar alpha);
void                gimp_rgba_get_uchar                 (const GimpRGB *rgba,
                                                         guchar *red,
                                                         guchar *green,
                                                         guchar *blue,
                                                         guchar *alpha);
gboolean            gimp_rgba_parse_css                 (GimpRGB *rgba,
                                                         const gchar *css,
                                                         gint len);
void                gimp_rgba_add                       (GimpRGB *rgba1,
                                                         const GimpRGB *rgba2);
void                gimp_rgba_subtract                  (GimpRGB *rgba1,
                                                         const GimpRGB *rgba2);
void                gimp_rgba_multiply                  (GimpRGB *rgba,
                                                         gdouble factor);
gdouble             gimp_rgba_distance                  (const GimpRGB *rgba1,
                                                         const GimpRGB *rgba2);
#define             GIMP_RGB_LUMINANCE                  (r,g,b)
#define             GIMP_RGB_LUMINANCE_RED
#define             GIMP_RGB_LUMINANCE_GREEN
#define             GIMP_RGB_LUMINANCE_BLUE
#define             GIMP_RGB_INTENSITY                  (r,g,b)
#define             GIMP_RGB_INTENSITY_RED
#define             GIMP_RGB_INTENSITY_GREEN
#define             GIMP_RGB_INTENSITY_BLUE
#define             GIMP_TYPE_RGB
#define             GIMP_TYPE_PARAM_RGB
GParamSpec *        gimp_param_spec_rgb                 (const gchar *name,
                                                         const gchar *nick,
                                                         const gchar *blurb,
                                                         gboolean has_alpha,
                                                         const GimpRGB *default_value,
                                                         GParamFlags flags);
gboolean            gimp_param_spec_rgb_has_alpha       (GParamSpec *pspec);
#define             GIMP_VALUE_HOLDS_RGB                (value)
void                gimp_value_get_rgb                  (const GValue *value,
                                                         GimpRGB *rgb);
void                gimp_value_set_rgb                  (GValue *value,
                                                         const GimpRGB *rgb);
typedef enum
{
  GIMP_RGB_COMPOSITE_NONE = 0,
  GIMP_RGB_COMPOSITE_NORMAL,
  GIMP_RGB_COMPOSITE_BEHIND
} GimpRGBCompositeMode;
void gimp_rgb_set (GimpRGB *rgb, gdouble red, gdouble green, gdouble blue);
Sets the red, green and blue components of rgb and leaves the
alpha component unchanged. The color values should be between 0.0
and 1.0 but there is no check to enforce this and the values are
set exactly as they are passed in.
| 
 | a GimpRGB struct | 
| 
 | |
| 
 | |
| 
 | 
void gimp_rgb_set_alpha (GimpRGB *rgb, gdouble alpha);
Sets the alpha component of rgb and leaves the RGB components unchanged.
| 
 | a GimpRGB struct | 
| 
 | 
void gimp_rgb_set_uchar (GimpRGB *rgb, guchar red, guchar green, guchar blue);
Sets the red, green and blue components of rgb from 8bit values
(0 to 255) and leaves the alpha component unchanged.
| 
 | a GimpRGB struct | 
| 
 | |
| 
 | |
| 
 | 
void gimp_rgb_get_uchar (const GimpRGB *rgb, guchar *red, guchar *green, guchar *blue);
| 
 | |
| 
 | |
| 
 | |
| 
 | 
gboolean gimp_rgb_parse_name (GimpRGB *rgb, const gchar *name, gint len);
Attempts to parse a color name. This function accepts SVG 1.0 color keywords.
This function does not touch the alpha component of rgb.
| 
 | a GimpRGB struct used to return the parsed color | 
| 
 | a color name (in UTF-8 encoding) | 
| 
 | the length of name, in bytes. or -1 ifnameis nul-terminated | 
| Returns : | TRUEifnamewas parsed successfully andrgbhas
              been set,FALSEotherwise | 
Since GIMP 2.2
gboolean gimp_rgb_parse_hex (GimpRGB *rgb, const gchar *hex, gint len);
Attempts to parse a string describing an RGB color in hexadecimal notation (optionally prefixed with a '#').
This function does not touch the alpha component of rgb.
| 
 | a GimpRGB struct used to return the parsed color | 
| 
 | a string describing a color in hexadecimal notation | 
| 
 | the length of hex, in bytes. or -1 ifhexis nul-terminated | 
| Returns : | TRUEifhexwas parsed successfully andrgbhas
              been set,FALSEotherwise | 
Since GIMP 2.2
gboolean gimp_rgb_parse_css (GimpRGB *rgb, const gchar *css, gint len);
Attempts to parse a string describing an RGB color in CSS
notation. This can be either a numerical representation
(rgb(255,0,0) or rgb(100%,0%,0%))
or a hexadecimal notation as parsed by gimp_rgb_parse_hex()
(#ff0000) or a color name as parsed by
gimp_rgb_parse_name() (red).
This function does not touch the alpha component of rgb.
| 
 | a GimpRGB struct used to return the parsed color | 
| 
 | a string describing a color in CSS notation | 
| 
 | the length of hex, in bytes. or -1 ifhexis nul-terminated | 
| Returns : | TRUEifcsswas parsed successfully andrgbhas been
              set,FALSEotherwise | 
Since GIMP 2.2
gint gimp_rgb_list_names (const gchar ***names, GimpRGB **colors);
Allows to retrieve the list of SVG 1.0 color
keywords that is used by gimp_rgb_parse_name().
The returned strings are const and must not be freed. Only the two
arrays are allocated dynamically. You must call g_free() on the
names and colors arrays when they are not any longer needed.
| 
 | return location for an array of color names | 
| 
 | return location for an array of GimpRGB structs | 
| Returns : | the number of named colors (i.e. the length of the returned arrays) | 
Since GIMP 2.2
gdouble gimp_rgb_distance (const GimpRGB *rgb1, const GimpRGB *rgb2);
| 
 | |
| 
 | |
| Returns : | 
gdouble gimp_rgb_luminance (const GimpRGB *rgb);
| 
 | |
| Returns : | the luminous intensity of the range from 0.0 to 1.0. | 
Since GIMP 2.4
guchar gimp_rgb_luminance_uchar (const GimpRGB *rgb);
| 
 | |
| Returns : | the luminous intensity in the range from 0 to 255. | 
Since GIMP 2.4
gdouble gimp_rgb_intensity (const GimpRGB *rgb);
gimp_rgb_intensity is deprecated and should not be used in newly-written code.
This function is deprecated! Use gimp_rgb_luminance() instead.
| 
 | |
| Returns : | the intensity in the range from 0.0 to 1.0. | 
guchar gimp_rgb_intensity_uchar (const GimpRGB *rgb);
gimp_rgb_intensity_uchar is deprecated and should not be used in newly-written code.
This function is deprecated! Use gimp_rgb_luminance_uchar() instead.
| 
 | |
| Returns : | the intensity in the range from 0 to 255. | 
void gimp_rgb_composite (GimpRGB *color1, const GimpRGB *color2, GimpRGBCompositeMode mode);
| 
 | |
| 
 | |
| 
 | 
void gimp_rgba_set (GimpRGB *rgba, gdouble red, gdouble green, gdouble blue, gdouble alpha);
Sets the red, green, blue and alpha components of rgb. The values
should be between 0.0 and 1.0 but there is no check to enforce this
and the values are set exactly as they are passed in.
| 
 | a GimpRGB struct | 
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void gimp_rgba_set_uchar (GimpRGB *rgba, guchar red, guchar green, guchar blue, guchar alpha);
Sets the red, green, blue and alpha components of rgb from 8bit
values (0 to 255).
| 
 | a GimpRGB struct | 
| 
 | |
| 
 | |
| 
 | |
| 
 | 
void gimp_rgba_get_uchar (const GimpRGB *rgba, guchar *red, guchar *green, guchar *blue, guchar *alpha);
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | 
gboolean gimp_rgba_parse_css (GimpRGB *rgba, const gchar *css, gint len);
Similar to gimp_rgb_parse_css() but handles RGB colors with alpha
channel in the numerical CSS notation (rgba(255,0,0,255)
or rgba(100%,0%,0%,1000%)).
It doesn't handle the hexadecimal notation or color names because they leave the alpha channel unspecified.
| 
 | a GimpRGB struct used to return the parsed color | 
| 
 | a string describing a color in CSS notation | 
| 
 | the length of hex, in bytes. or -1 ifhexis nul-terminated | 
| Returns : | TRUEifcsswas parsed successfully andrgbhas been
              set,FALSEotherwise | 
Since GIMP 2.2
void gimp_rgba_subtract (GimpRGB *rgba1, const GimpRGB *rgba2);
| 
 | |
| 
 | 
gdouble gimp_rgba_distance (const GimpRGB *rgba1, const GimpRGB *rgba2);
| 
 | |
| 
 | |
| Returns : | 
#define GIMP_RGB_INTENSITY(r,g,b)
GIMP_RGB_INTENSITY is deprecated and should not be used in newly-written code.
This macro calculates the intensity of an RGB value based on coefficients taken from the NTSC analog television standard.
| 
 | red | 
| 
 | green | 
| 
 | blue | 
#define GIMP_RGB_INTENSITY_RED (0.30)
GIMP_RGB_INTENSITY_RED is deprecated and should not be used in newly-written code.
#define GIMP_RGB_INTENSITY_GREEN (0.59)
GIMP_RGB_INTENSITY_GREEN is deprecated and should not be used in newly-written code.
#define GIMP_RGB_INTENSITY_BLUE (0.11)
GIMP_RGB_INTENSITY_BLUE is deprecated and should not be used in newly-written code.
#define GIMP_TYPE_RGB (gimp_rgb_get_type ())
GIMP_TYPE_RGB is a GType derived from G_TYPE_BOXED.
GParamSpec * gimp_param_spec_rgb (const gchar *name, const gchar *nick, const gchar *blurb, gboolean has_alpha, const GimpRGB *default_value, GParamFlags flags);
Creates a param spec to hold an GimpRGB value.
See g_param_spec_internal() for more information.
| 
 | Canonical name of the param | 
| 
 | Nickname of the param | 
| 
 | Brief desciption of param. | 
| 
 | TRUEif the alpha channel has relevance. | 
| 
 | Value to use if none is assigned. | 
| 
 | a combination of GParamFlags | 
| Returns : | a newly allocated GParamSpec instance | 
Since GIMP 2.4
gboolean gimp_param_spec_rgb_has_alpha (GParamSpec *pspec);
| 
 | a GParamSpec to hold an GimpRGB value. | 
| Returns : | TRUEif the alpha channel is relevant. | 
Since GIMP 2.4
#define GIMP_VALUE_HOLDS_RGB(value) (G_TYPE_CHECK_VALUE_TYPE ((value), GIMP_TYPE_RGB))
| 
 |