mirror of https://github.com/GNOME/gimp.git
app/color_notebook.[ch] app/color_select.c libgimp/gimpcolorselector.h
2001-01-15 Michael Natterer <mitch@gimp.org> * app/color_notebook.[ch] * app/color_select.c * libgimp/gimpcolorselector.h * modules/colorsel_gtk.c * modules/colorsel_triangle.c * modules/colorsel_water.c: use GimpRGB and GimpHSV. * libgimp/gimpcolor.c * libgimp/gimpcolorspace.[ch]: All rgb_to_hsv functions: if r == g == b the difference between the max and min value is 0 and we should avoid to divide by it ;-)
This commit is contained in:
parent
4c1f53a979
commit
368d0efe9b
15
ChangeLog
15
ChangeLog
|
@ -1,3 +1,18 @@
|
||||||
|
2001-01-15 Michael Natterer <mitch@gimp.org>
|
||||||
|
|
||||||
|
* app/color_notebook.[ch]
|
||||||
|
* app/color_select.c
|
||||||
|
* libgimp/gimpcolorselector.h
|
||||||
|
* modules/colorsel_gtk.c
|
||||||
|
* modules/colorsel_triangle.c
|
||||||
|
* modules/colorsel_water.c: use GimpRGB and GimpHSV.
|
||||||
|
|
||||||
|
* libgimp/gimpcolor.c
|
||||||
|
* libgimp/gimpcolorspace.[ch]: All rgb_to_hsv functions:
|
||||||
|
|
||||||
|
if r == g == b the difference between the max and min value
|
||||||
|
is 0 and we should avoid to divide by it ;-)
|
||||||
|
|
||||||
2001-01-15 Sven Neumann <sven@gimp.org>
|
2001-01-15 Sven Neumann <sven@gimp.org>
|
||||||
|
|
||||||
* plug-ins/gdyntext/gdyntext.[ch]
|
* plug-ins/gdyntext/gdyntext.[ch]
|
||||||
|
|
|
@ -72,9 +72,10 @@ struct _ColorNotebook
|
||||||
|
|
||||||
GdkGC *gc;
|
GdkGC *gc;
|
||||||
|
|
||||||
gint values[7];
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gint orig_values[4];
|
GimpRGB orig_rgb;
|
||||||
|
|
||||||
GimpColorSelectorChannelType active_channel;
|
GimpColorSelectorChannelType active_channel;
|
||||||
|
|
||||||
|
@ -121,13 +122,8 @@ static void color_notebook_ok_callback (GtkWidget *widget,
|
||||||
static void color_notebook_cancel_callback (GtkWidget *widget,
|
static void color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
static void color_notebook_update_callback (gpointer data,
|
static void color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb);
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha);
|
|
||||||
static void color_notebook_page_switch (GtkWidget *widget,
|
static void color_notebook_page_switch (GtkWidget *widget,
|
||||||
GtkNotebookPage *page,
|
GtkNotebookPage *page,
|
||||||
guint page_num,
|
guint page_num,
|
||||||
|
@ -203,8 +199,6 @@ color_notebook_new (GimpRGB *color,
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
static gchar *toggle_titles[] =
|
static gchar *toggle_titles[] =
|
||||||
{
|
{
|
||||||
N_("H"),
|
N_("H"),
|
||||||
|
@ -225,14 +219,13 @@ color_notebook_new (GimpRGB *color,
|
||||||
N_("Blue"),
|
N_("Blue"),
|
||||||
N_("Alpha")
|
N_("Alpha")
|
||||||
};
|
};
|
||||||
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 255 };
|
static gdouble slider_initial_vals[] = { 0, 0, 0, 0, 0, 0, 0 };
|
||||||
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 16 };
|
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 100 };
|
||||||
|
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 10 };
|
||||||
|
|
||||||
g_return_val_if_fail (selector_info != NULL, NULL);
|
g_return_val_if_fail (selector_info != NULL, NULL);
|
||||||
g_return_val_if_fail (color != NULL, NULL);
|
g_return_val_if_fail (color != NULL, NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
|
||||||
|
|
||||||
cnp = g_new0 (ColorNotebook, 1);
|
cnp = g_new0 (ColorNotebook, 1);
|
||||||
|
|
||||||
cnp->gc = NULL;
|
cnp->gc = NULL;
|
||||||
|
@ -244,10 +237,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->selectors = NULL;
|
cnp->selectors = NULL;
|
||||||
cnp->cur_page = NULL;
|
cnp->cur_page = NULL;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
cnp->rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
|
||||||
|
@ -295,13 +286,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
csel->info = info;
|
csel->info = info;
|
||||||
info->refs++;
|
info->refs++;
|
||||||
csel->frame =
|
csel->frame =
|
||||||
info->methods.new (cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
info->methods.new (&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA],
|
|
||||||
show_alpha,
|
show_alpha,
|
||||||
color_notebook_update_callback, csel,
|
color_notebook_update_callback, csel,
|
||||||
&csel->selector_data);
|
&csel->selector_data);
|
||||||
|
@ -418,6 +404,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
||||||
gtk_table_attach (GTK_TABLE (table), label,
|
gtk_table_attach (GTK_TABLE (table), label,
|
||||||
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
||||||
|
gtk_widget_show (label);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -438,7 +425,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
||||||
NULL,
|
NULL,
|
||||||
80, 55,
|
80, 55,
|
||||||
cnp->values[i],
|
slider_initial_vals[i],
|
||||||
0.0, slider_max_vals[i],
|
0.0, slider_max_vals[i],
|
||||||
1.0, slider_incs[i],
|
1.0, slider_incs[i],
|
||||||
0, TRUE, 0.0, 0.0,
|
0, TRUE, 0.0, 0.0,
|
||||||
|
@ -455,7 +442,10 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_widget_show (hbox);
|
gtk_widget_show (hbox);
|
||||||
|
|
||||||
cnp->hex_entry = gtk_entry_new ();
|
cnp->hex_entry = gtk_entry_new ();
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x", red, green, blue);
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
|
(gint) (color->r * 255.999),
|
||||||
|
(gint) (color->g * 255.999),
|
||||||
|
(gint) (color->b * 255.999));
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
||||||
|
@ -471,6 +461,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
||||||
gtk_widget_show (label);
|
gtk_widget_show (label);
|
||||||
|
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
gtk_widget_show (cnp->shell);
|
gtk_widget_show (cnp->shell);
|
||||||
|
|
||||||
/* this must come after showing the widget, otherwise we get a
|
/* this must come after showing the widget, otherwise we get a
|
||||||
|
@ -537,19 +529,14 @@ void
|
||||||
color_notebook_set_color (ColorNotebook *cnp,
|
color_notebook_set_color (ColorNotebook *cnp,
|
||||||
GimpRGB *color)
|
GimpRGB *color)
|
||||||
{
|
{
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
g_return_if_fail (cnp != NULL);
|
g_return_if_fail (cnp != NULL);
|
||||||
g_return_if_fail (color != NULL);
|
g_return_if_fail (color != NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
cnp->rgb = *color;
|
||||||
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
color_notebook_update (cnp,
|
color_notebook_update (cnp,
|
||||||
UPDATE_NOTEBOOK |
|
UPDATE_NOTEBOOK |
|
||||||
|
@ -562,29 +549,21 @@ color_notebook_set_color (ColorNotebook *cnp,
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
color_notebook_update_callback (gpointer data,
|
color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb)
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha)
|
|
||||||
{
|
{
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
|
|
||||||
g_return_if_fail (data != NULL);
|
g_return_if_fail (data != NULL);
|
||||||
|
g_return_if_fail (hsv != NULL);
|
||||||
|
g_return_if_fail (rgb != NULL);
|
||||||
|
|
||||||
csel = (ColorSelectorInstance *) data;
|
csel = (ColorSelectorInstance *) data;
|
||||||
cnp = csel->color_notebook;
|
cnp = csel->color_notebook;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = hue;
|
cnp->hsv = *hsv;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = saturation;
|
cnp->rgb = *rgb;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = value;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
|
@ -598,19 +577,12 @@ color_notebook_ok_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_OK,
|
COLOR_NOTEBOOK_OK,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -621,19 +593,12 @@ color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->orig_rgb,
|
||||||
COLOR_NOTEBOOK_CANCEL,
|
COLOR_NOTEBOOK_CANCEL,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -800,13 +765,8 @@ color_notebook_update_notebook (ColorNotebook *cnp)
|
||||||
|
|
||||||
csel = cnp->cur_page;
|
csel = cnp->cur_page;
|
||||||
csel->info->methods.set_color (csel->selector_data,
|
csel->info->methods.set_color (csel->selector_data,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb);
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -824,17 +784,9 @@ color_notebook_update_channel (ColorNotebook *cnp)
|
||||||
static void
|
static void
|
||||||
color_notebook_update_caller (ColorNotebook *cnp)
|
color_notebook_update_caller (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
gimp_rgba_set (&color,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] / 255.0);
|
|
||||||
|
|
||||||
if (cnp && cnp->callback)
|
if (cnp && cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_UPDATE,
|
COLOR_NOTEBOOK_UPDATE,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -846,7 +798,7 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
{
|
{
|
||||||
GdkWindow *window;
|
GdkWindow *window;
|
||||||
GdkColor color;
|
GdkColor color;
|
||||||
gint red, green, blue;
|
guchar red, green, blue;
|
||||||
gint width, height;
|
gint width, height;
|
||||||
|
|
||||||
if (!cnp)
|
if (!cnp)
|
||||||
|
@ -855,16 +807,14 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
if (which == UPDATE_ORIG_COLOR)
|
if (which == UPDATE_ORIG_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->orig_color->window;
|
window = cnp->orig_color->window;
|
||||||
red = cnp->orig_values[0];
|
|
||||||
green = cnp->orig_values[1];
|
gimp_rgb_get_uchar (&cnp->orig_rgb, &red, &green, &blue);
|
||||||
blue = cnp->orig_values[2];
|
|
||||||
}
|
}
|
||||||
else if (which == UPDATE_NEW_COLOR)
|
else if (which == UPDATE_NEW_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->new_color->window;
|
window = cnp->new_color->window;
|
||||||
red = cnp->values[GIMP_COLOR_SELECTOR_RED];
|
|
||||||
green = cnp->values[GIMP_COLOR_SELECTOR_GREEN];
|
gimp_rgb_get_uchar (&cnp->rgb, &red, &green, &blue);
|
||||||
blue = cnp->values[GIMP_COLOR_SELECTOR_BLUE];
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -892,64 +842,55 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
static void
|
static void
|
||||||
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble h, s, v;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
h = cnp->values[GIMP_COLOR_SELECTOR_HUE] / 360.0;
|
gimp_hsv_to_rgb (&cnp->hsv, &cnp->rgb);
|
||||||
s = cnp->values[GIMP_COLOR_SELECTOR_SATURATION] / 100.0;
|
|
||||||
v = cnp->values[GIMP_COLOR_SELECTOR_VALUE] / 100.0;
|
|
||||||
|
|
||||||
gimp_hsv_to_rgb_double (&h, &s, &v);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = h * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = s * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = v * 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble r, g, b;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0;
|
gimp_rgb_to_hsv (&cnp->rgb, &cnp->hsv);
|
||||||
g = cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0;
|
|
||||||
b = cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0;
|
|
||||||
|
|
||||||
gimp_rgb_to_hsv_double (&r, &g, &b);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = r * 360.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = g * 100.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = b * 100.0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_scales (ColorNotebook *cnp,
|
color_notebook_update_scales (ColorNotebook *cnp,
|
||||||
gint skip)
|
gint skip)
|
||||||
{
|
{
|
||||||
|
gint values[7];
|
||||||
gchar buffer[16];
|
gchar buffer[16];
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
values[GIMP_COLOR_SELECTOR_HUE] = (gint) (cnp->hsv.h * 360.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_SATURATION] = (gint) (cnp->hsv.s * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_VALUE] = (gint) (cnp->hsv.v * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_RED] = (gint) (cnp->rgb.r * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_GREEN] = (gint) (cnp->rgb.g * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_BLUE] = (gint) (cnp->rgb.b * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) (cnp->rgb.a * 100.999);
|
||||||
|
|
||||||
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
||||||
if (i != skip)
|
if (i != skip)
|
||||||
{
|
{
|
||||||
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
||||||
cnp->values[i]);
|
values[i]);
|
||||||
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
}
|
}
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
values[GIMP_COLOR_SELECTOR_RED],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
values[GIMP_COLOR_SELECTOR_GREEN],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
values[GIMP_COLOR_SELECTOR_BLUE]);
|
||||||
|
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
}
|
}
|
||||||
|
@ -1024,7 +965,36 @@ color_notebook_scale_update (GtkAdjustment *adjustment,
|
||||||
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
cnp->values[i] = (gint) (GTK_ADJUSTMENT (adjustment)->value);
|
switch (i)
|
||||||
|
{
|
||||||
|
case GIMP_COLOR_SELECTOR_HUE:
|
||||||
|
cnp->hsv.h = GTK_ADJUSTMENT (adjustment)->value / 360.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_SATURATION:
|
||||||
|
cnp->hsv.s = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_VALUE:
|
||||||
|
cnp->hsv.v = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_RED:
|
||||||
|
cnp->rgb.r = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_GREEN:
|
||||||
|
cnp->rgb.g = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_BLUE:
|
||||||
|
cnp->rgb.b = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_ALPHA:
|
||||||
|
cnp->hsv.a = cnp->rgb.a = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
||||||
{
|
{
|
||||||
|
@ -1069,9 +1039,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
(gint) (cnp->rgb.r * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
(gint) (cnp->rgb.g * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
(gint) (cnp->rgb.b * 255.999));
|
||||||
|
|
||||||
if ((strlen (hex_color) == 7) &&
|
if ((strlen (hex_color) == 7) &&
|
||||||
(g_strcasecmp (buffer, hex_color) != 0))
|
(g_strcasecmp (buffer, hex_color) != 0))
|
||||||
|
@ -1079,9 +1049,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
||||||
(hex_rgb < (1 << 24)))
|
(hex_rgb < (1 << 24)))
|
||||||
{
|
{
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (hex_rgb & 0xff0000) >> 16;
|
cnp->rgb.r = ((hex_rgb & 0xff0000) >> 16) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (hex_rgb & 0x00ff00) >> 8;
|
cnp->rgb.g = ((hex_rgb & 0x00ff00) >> 8) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (hex_rgb & 0x0000ff);
|
cnp->rgb.b = ((hex_rgb & 0x0000ff)) / 255.0;
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1114,11 +1084,7 @@ color_notebook_drag_new_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->rgb;
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1127,16 +1093,10 @@ color_notebook_drop_new_color (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
guchar r, g, b, a;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &r, &g, &b, &a);
|
cnp->rgb = *color;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (gint) r;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (gint) g;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (gint) b;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) a;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1156,9 +1116,5 @@ color_notebook_drag_old_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->orig_rgb;
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,6 +33,7 @@ typedef void (* ColorNotebookCallback) (GimpRGB *color,
|
||||||
|
|
||||||
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
||||||
|
|
||||||
|
|
||||||
ColorNotebook * color_notebook_new (GimpRGB *color,
|
ColorNotebook * color_notebook_new (GimpRGB *color,
|
||||||
ColorNotebookCallback callback,
|
ColorNotebookCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "session.h"
|
#include "session.h"
|
||||||
#include "color_area.h"
|
#include "color_area.h"
|
||||||
|
|
||||||
|
#include "libgimp/gimpcolorspace.h"
|
||||||
#include "libgimp/gimpcolorselector.h"
|
#include "libgimp/gimpcolorselector.h"
|
||||||
#include "libgimp/gimphelpui.h"
|
#include "libgimp/gimphelpui.h"
|
||||||
|
|
||||||
|
@ -82,13 +83,8 @@ typedef enum
|
||||||
UPDATE_CALLER = 1 << 6
|
UPDATE_CALLER = 1 << 6
|
||||||
} ColorSelectUpdateType;
|
} ColorSelectUpdateType;
|
||||||
|
|
||||||
typedef void (* ColorSelectCallback) (gint h,
|
typedef void (* ColorSelectCallback) (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gpointer data);
|
gpointer data);
|
||||||
|
|
||||||
typedef struct _ColorSelect ColorSelect;
|
typedef struct _ColorSelect ColorSelect;
|
||||||
|
@ -99,7 +95,10 @@ struct _ColorSelect
|
||||||
GtkWidget *z_color;
|
GtkWidget *z_color;
|
||||||
|
|
||||||
gint pos[3];
|
gint pos[3];
|
||||||
gint values[7];
|
|
||||||
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gint z_color_fill;
|
gint z_color_fill;
|
||||||
gint xy_color_fill;
|
gint xy_color_fill;
|
||||||
GdkGC *gc;
|
GdkGC *gc;
|
||||||
|
@ -118,28 +117,26 @@ struct _ColorSelectFill
|
||||||
gint y;
|
gint y;
|
||||||
gint width;
|
gint width;
|
||||||
gint height;
|
gint height;
|
||||||
gint *values;
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
ColorSelectFillUpdateProc update;
|
ColorSelectFillUpdateProc update;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static GtkWidget * color_select_widget_new (ColorSelect *,
|
static GtkWidget * color_select_widget_new (ColorSelect *csp,
|
||||||
gint ,
|
const GimpRGB *color);
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint );
|
|
||||||
|
|
||||||
static void color_select_drop_color (GtkWidget *widget,
|
static void color_select_drop_color (GtkWidget *widget,
|
||||||
GimpRGB *color,
|
GimpRGB *color,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
static void color_select_update (ColorSelect *,
|
static void color_select_update (ColorSelect *csp,
|
||||||
ColorSelectUpdateType);
|
ColorSelectUpdateType);
|
||||||
static void color_select_update_caller (ColorSelect *);
|
static void color_select_update_caller (ColorSelect *csp);
|
||||||
static void color_select_update_values (ColorSelect *);
|
static void color_select_update_values (ColorSelect *csp);
|
||||||
static void color_select_update_rgb_values (ColorSelect *);
|
static void color_select_update_rgb_values (ColorSelect *csp);
|
||||||
static void color_select_update_hsv_values (ColorSelect *);
|
static void color_select_update_hsv_values (ColorSelect *csp);
|
||||||
static void color_select_update_pos (ColorSelect *);
|
static void color_select_update_pos (ColorSelect *csp);
|
||||||
|
|
||||||
static gint color_select_xy_expose (GtkWidget *widget,
|
static gint color_select_xy_expose (GtkWidget *widget,
|
||||||
GdkEventExpose *eevent,
|
GdkEventExpose *eevent,
|
||||||
|
@ -156,55 +153,41 @@ static gint color_select_z_events (GtkWidget *widet,
|
||||||
|
|
||||||
static void color_select_image_fill (GtkWidget *,
|
static void color_select_image_fill (GtkWidget *,
|
||||||
ColorSelectFillType,
|
ColorSelectFillType,
|
||||||
gint *);
|
const GimpHSV *hsv,
|
||||||
|
const GimpRGB *rgb);
|
||||||
|
|
||||||
static void color_select_draw_z_marker (ColorSelect *,
|
static void color_select_draw_z_marker (ColorSelect *csp,
|
||||||
GdkRectangle *);
|
GdkRectangle *);
|
||||||
static void color_select_draw_xy_marker (ColorSelect *,
|
static void color_select_draw_xy_marker (ColorSelect *csp,
|
||||||
GdkRectangle *);
|
GdkRectangle *);
|
||||||
|
|
||||||
static void color_select_update_red (ColorSelectFill *);
|
static void color_select_update_red (ColorSelectFill *csf);
|
||||||
static void color_select_update_green (ColorSelectFill *);
|
static void color_select_update_green (ColorSelectFill *csf);
|
||||||
static void color_select_update_blue (ColorSelectFill *);
|
static void color_select_update_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue (ColorSelectFill *);
|
static void color_select_update_hue (ColorSelectFill *csf);
|
||||||
static void color_select_update_saturation (ColorSelectFill *);
|
static void color_select_update_saturation (ColorSelectFill *csf);
|
||||||
static void color_select_update_value (ColorSelectFill *);
|
static void color_select_update_value (ColorSelectFill *csf);
|
||||||
static void color_select_update_red_green (ColorSelectFill *);
|
static void color_select_update_red_green (ColorSelectFill *csf);
|
||||||
static void color_select_update_red_blue (ColorSelectFill *);
|
static void color_select_update_red_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_green_blue (ColorSelectFill *);
|
static void color_select_update_green_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue_saturation (ColorSelectFill *);
|
static void color_select_update_hue_saturation (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue_value (ColorSelectFill *);
|
static void color_select_update_hue_value (ColorSelectFill *csf);
|
||||||
static void color_select_update_saturation_value (ColorSelectFill *);
|
static void color_select_update_saturation_value (ColorSelectFill *csf);
|
||||||
|
|
||||||
static GtkWidget * color_select_notebook_new (gint ,
|
static GtkWidget * color_select_notebook_new (const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb,
|
||||||
gint ,
|
gboolean show_alpha,
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gboolean ,
|
|
||||||
GimpColorSelectorCallback,
|
GimpColorSelectorCallback,
|
||||||
gpointer ,
|
gpointer ,
|
||||||
gpointer *);
|
gpointer *);
|
||||||
static void color_select_notebook_free (gpointer );
|
static void color_select_notebook_free (gpointer );
|
||||||
static void color_select_notebook_set_color (gpointer ,
|
static void color_select_notebook_set_color (gpointer ,
|
||||||
gint ,
|
const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb);
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint );
|
|
||||||
static void color_select_notebook_set_channel (gpointer ,
|
static void color_select_notebook_set_channel (gpointer ,
|
||||||
GimpColorSelectorChannelType channel);
|
GimpColorSelectorChannelType channel);
|
||||||
static void color_select_notebook_update_callback (gint ,
|
static void color_select_notebook_update_callback (const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb,
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gpointer );
|
gpointer );
|
||||||
|
|
||||||
/* Static variables */
|
/* Static variables */
|
||||||
|
@ -252,10 +235,7 @@ color_select_init (void)
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
color_select_widget_new (ColorSelect *csp,
|
color_select_widget_new (ColorSelect *csp,
|
||||||
gint r,
|
const GimpRGB *color)
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
GtkWidget *main_vbox;
|
GtkWidget *main_vbox;
|
||||||
GtkWidget *main_hbox;
|
GtkWidget *main_hbox;
|
||||||
|
@ -330,16 +310,10 @@ color_select_drop_color (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorSelect *csp;
|
ColorSelect *csp;
|
||||||
guchar r, g, b, a;
|
|
||||||
|
|
||||||
csp = (ColorSelect *) data;
|
csp = (ColorSelect *) data;
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &r, &g, &b, &a);
|
csp->rgb = *color;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_RED] = (gint) r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = (gint) g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = (gint) b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = (gint) a;
|
|
||||||
|
|
||||||
color_select_update_hsv_values (csp);
|
color_select_update_hsv_values (csp);
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
@ -352,24 +326,14 @@ color_select_drop_color (GtkWidget *widget,
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_set_color (ColorSelect *csp,
|
color_select_set_color (ColorSelect *csp,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
csp->hsv = *hsv;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s;
|
csp->rgb = *rgb;
|
||||||
csp->values[COLOR_SELECT_VALUE] = v;
|
|
||||||
csp->values[COLOR_SELECT_RED] = r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = a;
|
|
||||||
|
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
|
||||||
|
@ -394,13 +358,15 @@ color_select_update (ColorSelect *csp,
|
||||||
|
|
||||||
if (update & UPDATE_XY_COLOR)
|
if (update & UPDATE_XY_COLOR)
|
||||||
{
|
{
|
||||||
color_select_image_fill (csp->xy_color, csp->xy_color_fill, csp->values);
|
color_select_image_fill (csp->xy_color, csp->xy_color_fill,
|
||||||
|
&csp->hsv, &csp->rgb);
|
||||||
gtk_widget_draw (csp->xy_color, NULL);
|
gtk_widget_draw (csp->xy_color, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (update & UPDATE_Z_COLOR)
|
if (update & UPDATE_Z_COLOR)
|
||||||
{
|
{
|
||||||
color_select_image_fill (csp->z_color, csp->z_color_fill, csp->values);
|
color_select_image_fill (csp->z_color, csp->z_color_fill,
|
||||||
|
&csp->hsv, &csp->rgb);
|
||||||
gtk_widget_draw (csp->z_color, NULL);
|
gtk_widget_draw (csp->z_color, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -413,13 +379,8 @@ color_select_update_caller (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
if (csp && csp->callback)
|
if (csp && csp->callback)
|
||||||
{
|
{
|
||||||
(* csp->callback) (csp->values[COLOR_SELECT_HUE],
|
(* csp->callback) (&csp->hsv,
|
||||||
csp->values[COLOR_SELECT_SATURATION],
|
&csp->rgb,
|
||||||
csp->values[COLOR_SELECT_VALUE],
|
|
||||||
csp->values[COLOR_SELECT_RED],
|
|
||||||
csp->values[COLOR_SELECT_GREEN],
|
|
||||||
csp->values[COLOR_SELECT_BLUE],
|
|
||||||
csp->values[COLOR_SELECT_ALPHA],
|
|
||||||
csp->client_data);
|
csp->client_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -433,34 +394,35 @@ color_select_update_values (ColorSelect *csp)
|
||||||
switch (csp->z_color_fill)
|
switch (csp->z_color_fill)
|
||||||
{
|
{
|
||||||
case COLOR_SELECT_RED:
|
case COLOR_SELECT_RED:
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[0];
|
csp->rgb.b = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[1];
|
csp->rgb.g = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[2];
|
csp->rgb.r = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_GREEN:
|
case COLOR_SELECT_GREEN:
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[0];
|
csp->rgb.b = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[1];
|
csp->rgb.r = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[2];
|
csp->rgb.g = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[0];
|
csp->rgb.g = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[1];
|
csp->rgb.r = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[2];
|
csp->rgb.b = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[0] * 100 / 255;
|
csp->hsv.v = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[1] * 100 / 255;
|
csp->hsv.s = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[2] * 360 / 255;
|
csp->hsv.h = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[0] * 100 / 255;
|
csp->hsv.v = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[1] * 360 / 255;
|
csp->hsv.h = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[2] * 100 / 255;
|
csp->hsv.s = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[0] * 100 / 255;
|
csp->hsv.s = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[1] * 360 / 255;
|
csp->hsv.h = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[2] * 100 / 255;
|
csp->hsv.v = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -471,6 +433,7 @@ color_select_update_values (ColorSelect *csp)
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
color_select_update_hsv_values (csp);
|
color_select_update_hsv_values (csp);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
|
@ -482,139 +445,19 @@ color_select_update_values (ColorSelect *csp)
|
||||||
static void
|
static void
|
||||||
color_select_update_rgb_values (ColorSelect *csp)
|
color_select_update_rgb_values (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
gfloat h, s, v;
|
|
||||||
gfloat f, p, q, t;
|
|
||||||
|
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
h = csp->values[COLOR_SELECT_HUE];
|
gimp_hsv_to_rgb (&csp->hsv, &csp->rgb);
|
||||||
s = csp->values[COLOR_SELECT_SATURATION] / 100.0;
|
|
||||||
v = csp->values[COLOR_SELECT_VALUE] / 100.0;
|
|
||||||
|
|
||||||
if (s == 0)
|
|
||||||
{
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (h == 360)
|
|
||||||
h = 0;
|
|
||||||
|
|
||||||
h /= 60;
|
|
||||||
f = h - (int) h;
|
|
||||||
p = v * (1 - s);
|
|
||||||
q = v * (1 - (s * f));
|
|
||||||
t = v * (1 - (s * (1 - f)));
|
|
||||||
|
|
||||||
switch ((gint) h)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = t * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = p * 255;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
csp->values[COLOR_SELECT_RED] = q * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = p * 255;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
csp->values[COLOR_SELECT_RED] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = t * 255;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
csp->values[COLOR_SELECT_RED] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = q * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
csp->values[COLOR_SELECT_RED] = t * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = q * 255;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_update_hsv_values (ColorSelect *csp)
|
color_select_update_hsv_values (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
gint r, g, b;
|
|
||||||
gfloat h, s, v;
|
|
||||||
gint min, max;
|
|
||||||
gint delta;
|
|
||||||
|
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = csp->values[COLOR_SELECT_RED];
|
gimp_rgb_to_hsv (&csp->rgb, &csp->hsv);
|
||||||
g = csp->values[COLOR_SELECT_GREEN];
|
|
||||||
b = csp->values[COLOR_SELECT_BLUE];
|
|
||||||
|
|
||||||
if (r > g)
|
|
||||||
{
|
|
||||||
if (r > b)
|
|
||||||
max = r;
|
|
||||||
else
|
|
||||||
max = b;
|
|
||||||
|
|
||||||
if (g < b)
|
|
||||||
min = g;
|
|
||||||
else
|
|
||||||
min = b;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (g > b)
|
|
||||||
max = g;
|
|
||||||
else
|
|
||||||
max = b;
|
|
||||||
|
|
||||||
if (r < b)
|
|
||||||
min = r;
|
|
||||||
else
|
|
||||||
min = b;
|
|
||||||
}
|
|
||||||
|
|
||||||
v = max;
|
|
||||||
|
|
||||||
if (max != 0)
|
|
||||||
s = (max - min) / (float) max;
|
|
||||||
else
|
|
||||||
s = 0;
|
|
||||||
|
|
||||||
if (s == 0)
|
|
||||||
{
|
|
||||||
h = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
h = 0;
|
|
||||||
delta = max - min;
|
|
||||||
if (r == max)
|
|
||||||
h = (g - b) / (float) delta;
|
|
||||||
else if (g == max)
|
|
||||||
h = 2 + (b - r) / (float) delta;
|
|
||||||
else if (b == max)
|
|
||||||
h = 4 + (r - g) / (float) delta;
|
|
||||||
h *= 60;
|
|
||||||
|
|
||||||
if (h < 0)
|
|
||||||
h += 360;
|
|
||||||
}
|
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s * 100;
|
|
||||||
csp->values[COLOR_SELECT_VALUE] = v * 100 / 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -626,34 +469,35 @@ color_select_update_pos (ColorSelect *csp)
|
||||||
switch (csp->z_color_fill)
|
switch (csp->z_color_fill)
|
||||||
{
|
{
|
||||||
case COLOR_SELECT_RED:
|
case COLOR_SELECT_RED:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[0] = (gint) (csp->rgb.b * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[1] = (gint) (csp->rgb.g * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_RED];
|
csp->pos[2] = (gint) (csp->rgb.r * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_GREEN:
|
case COLOR_SELECT_GREEN:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[0] = (gint) (csp->rgb.b * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_RED];
|
csp->pos[1] = (gint) (csp->rgb.r * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[2] = (gint) (csp->rgb.g * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[0] = (gint) (csp->rgb.g * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_RED];
|
csp->pos[1] = (gint) (csp->rgb.r * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[2] = (gint) (csp->rgb.b * 255.999);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.v * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[1] = (gint) (csp->hsv.s * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[2] = (gint) (csp->hsv.h * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.v * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[1] = (gint) (csp->hsv.h * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[2] = (gint) (csp->hsv.s * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.s * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[1] = (gint) (csp->hsv.h * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[2] = (gint) (csp->hsv.v * 255.999);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -795,10 +639,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
gdk_pointer_grab (csp->z_color->window, FALSE,
|
gdk_pointer_grab (csp->z_color->window, FALSE,
|
||||||
GDK_POINTER_MOTION_HINT_MASK |
|
GDK_POINTER_MOTION_HINT_MASK |
|
||||||
|
@ -815,10 +657,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
gdk_pointer_ungrab (bevent->time);
|
gdk_pointer_ungrab (bevent->time);
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
@ -837,10 +677,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (mevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (mevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
color_select_update (csp, UPDATE_VALUES | UPDATE_CALLER);
|
color_select_update (csp, UPDATE_VALUES | UPDATE_CALLER);
|
||||||
|
@ -897,7 +735,8 @@ color_select_set_channel (ColorSelect *csp,
|
||||||
static void
|
static void
|
||||||
color_select_image_fill (GtkWidget *preview,
|
color_select_image_fill (GtkWidget *preview,
|
||||||
ColorSelectFillType type,
|
ColorSelectFillType type,
|
||||||
gint *values)
|
const GimpHSV *hsv,
|
||||||
|
const GimpRGB *rgb)
|
||||||
{
|
{
|
||||||
ColorSelectFill csf;
|
ColorSelectFill csf;
|
||||||
gint height;
|
gint height;
|
||||||
|
@ -909,7 +748,8 @@ color_select_image_fill (GtkWidget *preview,
|
||||||
csf.y = -1;
|
csf.y = -1;
|
||||||
csf.width = preview->requisition.width;
|
csf.width = preview->requisition.width;
|
||||||
csf.height = preview->requisition.height;
|
csf.height = preview->requisition.height;
|
||||||
csf.values = values;
|
csf.hsv = *hsv;
|
||||||
|
csf.rgb = *rgb;
|
||||||
|
|
||||||
height = csf.height;
|
height = csf.height;
|
||||||
if (height > 0)
|
if (height > 0)
|
||||||
|
@ -1085,14 +925,9 @@ color_select_update_hue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
h = csf->y * 360 / csf->height;
|
h = csf->y * 360.0 / csf->height;
|
||||||
|
|
||||||
h = 360 - h;
|
h = CLAMP (360 - h, 0, 360);
|
||||||
|
|
||||||
if (h < 0)
|
|
||||||
h = 0;
|
|
||||||
if (h >= 360)
|
|
||||||
h = 0;
|
|
||||||
|
|
||||||
h /= 60;
|
h /= 60;
|
||||||
f = (h - (int) h) * 255;
|
f = (h - (int) h) * 255;
|
||||||
|
@ -1205,7 +1040,7 @@ color_select_update_red_green (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
b = csf->values[COLOR_SELECT_BLUE];
|
b = (gint) (csf->rgb.b * 255.999);
|
||||||
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
|
@ -1236,7 +1071,7 @@ color_select_update_red_blue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
g = csf->values[COLOR_SELECT_GREEN];
|
g = (gint) (csf->rgb.g * 255.999);
|
||||||
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
|
@ -1267,7 +1102,7 @@ color_select_update_green_blue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
r = csf->values[COLOR_SELECT_RED];
|
r = (gint) (csf->rgb.r * 255.999);
|
||||||
g = (csf->height - csf->y + 1) * 255 / csf->height;
|
g = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (g < 0)
|
if (g < 0)
|
||||||
|
@ -1312,7 +1147,7 @@ color_select_update_hue_saturation (ColorSelectFill *csf)
|
||||||
s = 0;
|
s = 0;
|
||||||
ds = 1.0 / csf->width;
|
ds = 1.0 / csf->width;
|
||||||
|
|
||||||
v = csf->values[COLOR_SELECT_VALUE] / 100.0;
|
v = csf->hsv.v;
|
||||||
|
|
||||||
switch ((int) h)
|
switch ((int) h)
|
||||||
{
|
{
|
||||||
|
@ -1403,7 +1238,7 @@ color_select_update_hue_value (ColorSelectFill *csf)
|
||||||
v = 0;
|
v = 0;
|
||||||
dv = 1.0 / csf->width;
|
dv = 1.0 / csf->width;
|
||||||
|
|
||||||
s = csf->values[COLOR_SELECT_SATURATION] / 100.0;
|
s = csf->hsv.s;
|
||||||
|
|
||||||
switch ((int) h)
|
switch ((int) h)
|
||||||
{
|
{
|
||||||
|
@ -1490,7 +1325,7 @@ color_select_update_saturation_value (ColorSelectFill *csf)
|
||||||
|
|
||||||
s = 1 - s;
|
s = 1 - s;
|
||||||
|
|
||||||
h = (gfloat) csf->values[COLOR_SELECT_HUE];
|
h = (gfloat) csf->hsv.h * 360.0;
|
||||||
if (h >= 360)
|
if (h >= 360)
|
||||||
h -= 360;
|
h -= 360;
|
||||||
h /= 60;
|
h /= 60;
|
||||||
|
@ -1577,13 +1412,8 @@ typedef struct
|
||||||
} notebook_glue;
|
} notebook_glue;
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
color_select_notebook_new (gint h,
|
color_select_notebook_new (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
@ -1607,20 +1437,14 @@ color_select_notebook_new (gint h,
|
||||||
csp->xy_color_fill = COLOR_SELECT_SATURATION_VALUE;
|
csp->xy_color_fill = COLOR_SELECT_SATURATION_VALUE;
|
||||||
csp->gc = NULL;
|
csp->gc = NULL;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
csp->hsv = *hsv;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s;
|
csp->rgb = *rgb;
|
||||||
csp->values[COLOR_SELECT_VALUE] = v;
|
|
||||||
csp->values[COLOR_SELECT_RED] = r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = a;
|
|
||||||
|
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
|
||||||
glue->main_vbox = color_select_widget_new (csp, r, g, b, a);
|
glue->main_vbox = color_select_widget_new (csp, rgb);
|
||||||
|
|
||||||
color_select_image_fill (csp->z_color, csp->z_color_fill, csp->values);
|
color_select_update (csp, UPDATE_XY_COLOR | UPDATE_Z_COLOR);
|
||||||
color_select_image_fill (csp->xy_color, csp->xy_color_fill, csp->values);
|
|
||||||
|
|
||||||
*selector_data = glue;
|
*selector_data = glue;
|
||||||
|
|
||||||
|
@ -1642,20 +1466,14 @@ color_select_notebook_free (gpointer data)
|
||||||
g_free (glue);
|
g_free (glue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_notebook_set_color (gpointer data,
|
color_select_notebook_set_color (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
notebook_glue *glue = data;
|
notebook_glue *glue = data;
|
||||||
|
|
||||||
color_select_set_color (glue->csp, h, s, v, r, g, b, a);
|
color_select_set_color (glue->csp, hsv, rgb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1668,16 +1486,11 @@ color_select_notebook_set_channel (gpointer data,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_notebook_update_callback (gint h,
|
color_select_notebook_update_callback (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
notebook_glue *glue = data;
|
notebook_glue *glue = data;
|
||||||
|
|
||||||
glue->callback (glue->client_data, h, s, v, r, g, b, a);
|
glue->callback (glue->client_data, hsv, rgb);
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,9 +72,10 @@ struct _ColorNotebook
|
||||||
|
|
||||||
GdkGC *gc;
|
GdkGC *gc;
|
||||||
|
|
||||||
gint values[7];
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gint orig_values[4];
|
GimpRGB orig_rgb;
|
||||||
|
|
||||||
GimpColorSelectorChannelType active_channel;
|
GimpColorSelectorChannelType active_channel;
|
||||||
|
|
||||||
|
@ -121,13 +122,8 @@ static void color_notebook_ok_callback (GtkWidget *widget,
|
||||||
static void color_notebook_cancel_callback (GtkWidget *widget,
|
static void color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
static void color_notebook_update_callback (gpointer data,
|
static void color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb);
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha);
|
|
||||||
static void color_notebook_page_switch (GtkWidget *widget,
|
static void color_notebook_page_switch (GtkWidget *widget,
|
||||||
GtkNotebookPage *page,
|
GtkNotebookPage *page,
|
||||||
guint page_num,
|
guint page_num,
|
||||||
|
@ -203,8 +199,6 @@ color_notebook_new (GimpRGB *color,
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
static gchar *toggle_titles[] =
|
static gchar *toggle_titles[] =
|
||||||
{
|
{
|
||||||
N_("H"),
|
N_("H"),
|
||||||
|
@ -225,14 +219,13 @@ color_notebook_new (GimpRGB *color,
|
||||||
N_("Blue"),
|
N_("Blue"),
|
||||||
N_("Alpha")
|
N_("Alpha")
|
||||||
};
|
};
|
||||||
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 255 };
|
static gdouble slider_initial_vals[] = { 0, 0, 0, 0, 0, 0, 0 };
|
||||||
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 16 };
|
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 100 };
|
||||||
|
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 10 };
|
||||||
|
|
||||||
g_return_val_if_fail (selector_info != NULL, NULL);
|
g_return_val_if_fail (selector_info != NULL, NULL);
|
||||||
g_return_val_if_fail (color != NULL, NULL);
|
g_return_val_if_fail (color != NULL, NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
|
||||||
|
|
||||||
cnp = g_new0 (ColorNotebook, 1);
|
cnp = g_new0 (ColorNotebook, 1);
|
||||||
|
|
||||||
cnp->gc = NULL;
|
cnp->gc = NULL;
|
||||||
|
@ -244,10 +237,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->selectors = NULL;
|
cnp->selectors = NULL;
|
||||||
cnp->cur_page = NULL;
|
cnp->cur_page = NULL;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
cnp->rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
|
||||||
|
@ -295,13 +286,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
csel->info = info;
|
csel->info = info;
|
||||||
info->refs++;
|
info->refs++;
|
||||||
csel->frame =
|
csel->frame =
|
||||||
info->methods.new (cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
info->methods.new (&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA],
|
|
||||||
show_alpha,
|
show_alpha,
|
||||||
color_notebook_update_callback, csel,
|
color_notebook_update_callback, csel,
|
||||||
&csel->selector_data);
|
&csel->selector_data);
|
||||||
|
@ -418,6 +404,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
||||||
gtk_table_attach (GTK_TABLE (table), label,
|
gtk_table_attach (GTK_TABLE (table), label,
|
||||||
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
||||||
|
gtk_widget_show (label);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -438,7 +425,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
||||||
NULL,
|
NULL,
|
||||||
80, 55,
|
80, 55,
|
||||||
cnp->values[i],
|
slider_initial_vals[i],
|
||||||
0.0, slider_max_vals[i],
|
0.0, slider_max_vals[i],
|
||||||
1.0, slider_incs[i],
|
1.0, slider_incs[i],
|
||||||
0, TRUE, 0.0, 0.0,
|
0, TRUE, 0.0, 0.0,
|
||||||
|
@ -455,7 +442,10 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_widget_show (hbox);
|
gtk_widget_show (hbox);
|
||||||
|
|
||||||
cnp->hex_entry = gtk_entry_new ();
|
cnp->hex_entry = gtk_entry_new ();
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x", red, green, blue);
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
|
(gint) (color->r * 255.999),
|
||||||
|
(gint) (color->g * 255.999),
|
||||||
|
(gint) (color->b * 255.999));
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
||||||
|
@ -471,6 +461,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
||||||
gtk_widget_show (label);
|
gtk_widget_show (label);
|
||||||
|
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
gtk_widget_show (cnp->shell);
|
gtk_widget_show (cnp->shell);
|
||||||
|
|
||||||
/* this must come after showing the widget, otherwise we get a
|
/* this must come after showing the widget, otherwise we get a
|
||||||
|
@ -537,19 +529,14 @@ void
|
||||||
color_notebook_set_color (ColorNotebook *cnp,
|
color_notebook_set_color (ColorNotebook *cnp,
|
||||||
GimpRGB *color)
|
GimpRGB *color)
|
||||||
{
|
{
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
g_return_if_fail (cnp != NULL);
|
g_return_if_fail (cnp != NULL);
|
||||||
g_return_if_fail (color != NULL);
|
g_return_if_fail (color != NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
cnp->rgb = *color;
|
||||||
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
color_notebook_update (cnp,
|
color_notebook_update (cnp,
|
||||||
UPDATE_NOTEBOOK |
|
UPDATE_NOTEBOOK |
|
||||||
|
@ -562,29 +549,21 @@ color_notebook_set_color (ColorNotebook *cnp,
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
color_notebook_update_callback (gpointer data,
|
color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb)
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha)
|
|
||||||
{
|
{
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
|
|
||||||
g_return_if_fail (data != NULL);
|
g_return_if_fail (data != NULL);
|
||||||
|
g_return_if_fail (hsv != NULL);
|
||||||
|
g_return_if_fail (rgb != NULL);
|
||||||
|
|
||||||
csel = (ColorSelectorInstance *) data;
|
csel = (ColorSelectorInstance *) data;
|
||||||
cnp = csel->color_notebook;
|
cnp = csel->color_notebook;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = hue;
|
cnp->hsv = *hsv;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = saturation;
|
cnp->rgb = *rgb;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = value;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
|
@ -598,19 +577,12 @@ color_notebook_ok_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_OK,
|
COLOR_NOTEBOOK_OK,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -621,19 +593,12 @@ color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->orig_rgb,
|
||||||
COLOR_NOTEBOOK_CANCEL,
|
COLOR_NOTEBOOK_CANCEL,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -800,13 +765,8 @@ color_notebook_update_notebook (ColorNotebook *cnp)
|
||||||
|
|
||||||
csel = cnp->cur_page;
|
csel = cnp->cur_page;
|
||||||
csel->info->methods.set_color (csel->selector_data,
|
csel->info->methods.set_color (csel->selector_data,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb);
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -824,17 +784,9 @@ color_notebook_update_channel (ColorNotebook *cnp)
|
||||||
static void
|
static void
|
||||||
color_notebook_update_caller (ColorNotebook *cnp)
|
color_notebook_update_caller (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
gimp_rgba_set (&color,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] / 255.0);
|
|
||||||
|
|
||||||
if (cnp && cnp->callback)
|
if (cnp && cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_UPDATE,
|
COLOR_NOTEBOOK_UPDATE,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -846,7 +798,7 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
{
|
{
|
||||||
GdkWindow *window;
|
GdkWindow *window;
|
||||||
GdkColor color;
|
GdkColor color;
|
||||||
gint red, green, blue;
|
guchar red, green, blue;
|
||||||
gint width, height;
|
gint width, height;
|
||||||
|
|
||||||
if (!cnp)
|
if (!cnp)
|
||||||
|
@ -855,16 +807,14 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
if (which == UPDATE_ORIG_COLOR)
|
if (which == UPDATE_ORIG_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->orig_color->window;
|
window = cnp->orig_color->window;
|
||||||
red = cnp->orig_values[0];
|
|
||||||
green = cnp->orig_values[1];
|
gimp_rgb_get_uchar (&cnp->orig_rgb, &red, &green, &blue);
|
||||||
blue = cnp->orig_values[2];
|
|
||||||
}
|
}
|
||||||
else if (which == UPDATE_NEW_COLOR)
|
else if (which == UPDATE_NEW_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->new_color->window;
|
window = cnp->new_color->window;
|
||||||
red = cnp->values[GIMP_COLOR_SELECTOR_RED];
|
|
||||||
green = cnp->values[GIMP_COLOR_SELECTOR_GREEN];
|
gimp_rgb_get_uchar (&cnp->rgb, &red, &green, &blue);
|
||||||
blue = cnp->values[GIMP_COLOR_SELECTOR_BLUE];
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -892,64 +842,55 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
static void
|
static void
|
||||||
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble h, s, v;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
h = cnp->values[GIMP_COLOR_SELECTOR_HUE] / 360.0;
|
gimp_hsv_to_rgb (&cnp->hsv, &cnp->rgb);
|
||||||
s = cnp->values[GIMP_COLOR_SELECTOR_SATURATION] / 100.0;
|
|
||||||
v = cnp->values[GIMP_COLOR_SELECTOR_VALUE] / 100.0;
|
|
||||||
|
|
||||||
gimp_hsv_to_rgb_double (&h, &s, &v);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = h * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = s * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = v * 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble r, g, b;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0;
|
gimp_rgb_to_hsv (&cnp->rgb, &cnp->hsv);
|
||||||
g = cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0;
|
|
||||||
b = cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0;
|
|
||||||
|
|
||||||
gimp_rgb_to_hsv_double (&r, &g, &b);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = r * 360.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = g * 100.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = b * 100.0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_scales (ColorNotebook *cnp,
|
color_notebook_update_scales (ColorNotebook *cnp,
|
||||||
gint skip)
|
gint skip)
|
||||||
{
|
{
|
||||||
|
gint values[7];
|
||||||
gchar buffer[16];
|
gchar buffer[16];
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
values[GIMP_COLOR_SELECTOR_HUE] = (gint) (cnp->hsv.h * 360.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_SATURATION] = (gint) (cnp->hsv.s * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_VALUE] = (gint) (cnp->hsv.v * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_RED] = (gint) (cnp->rgb.r * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_GREEN] = (gint) (cnp->rgb.g * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_BLUE] = (gint) (cnp->rgb.b * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) (cnp->rgb.a * 100.999);
|
||||||
|
|
||||||
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
||||||
if (i != skip)
|
if (i != skip)
|
||||||
{
|
{
|
||||||
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
||||||
cnp->values[i]);
|
values[i]);
|
||||||
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
}
|
}
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
values[GIMP_COLOR_SELECTOR_RED],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
values[GIMP_COLOR_SELECTOR_GREEN],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
values[GIMP_COLOR_SELECTOR_BLUE]);
|
||||||
|
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
}
|
}
|
||||||
|
@ -1024,7 +965,36 @@ color_notebook_scale_update (GtkAdjustment *adjustment,
|
||||||
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
cnp->values[i] = (gint) (GTK_ADJUSTMENT (adjustment)->value);
|
switch (i)
|
||||||
|
{
|
||||||
|
case GIMP_COLOR_SELECTOR_HUE:
|
||||||
|
cnp->hsv.h = GTK_ADJUSTMENT (adjustment)->value / 360.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_SATURATION:
|
||||||
|
cnp->hsv.s = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_VALUE:
|
||||||
|
cnp->hsv.v = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_RED:
|
||||||
|
cnp->rgb.r = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_GREEN:
|
||||||
|
cnp->rgb.g = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_BLUE:
|
||||||
|
cnp->rgb.b = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_ALPHA:
|
||||||
|
cnp->hsv.a = cnp->rgb.a = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
||||||
{
|
{
|
||||||
|
@ -1069,9 +1039,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
(gint) (cnp->rgb.r * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
(gint) (cnp->rgb.g * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
(gint) (cnp->rgb.b * 255.999));
|
||||||
|
|
||||||
if ((strlen (hex_color) == 7) &&
|
if ((strlen (hex_color) == 7) &&
|
||||||
(g_strcasecmp (buffer, hex_color) != 0))
|
(g_strcasecmp (buffer, hex_color) != 0))
|
||||||
|
@ -1079,9 +1049,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
||||||
(hex_rgb < (1 << 24)))
|
(hex_rgb < (1 << 24)))
|
||||||
{
|
{
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (hex_rgb & 0xff0000) >> 16;
|
cnp->rgb.r = ((hex_rgb & 0xff0000) >> 16) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (hex_rgb & 0x00ff00) >> 8;
|
cnp->rgb.g = ((hex_rgb & 0x00ff00) >> 8) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (hex_rgb & 0x0000ff);
|
cnp->rgb.b = ((hex_rgb & 0x0000ff)) / 255.0;
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1114,11 +1084,7 @@ color_notebook_drag_new_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->rgb;
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1127,16 +1093,10 @@ color_notebook_drop_new_color (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
guchar r, g, b, a;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &r, &g, &b, &a);
|
cnp->rgb = *color;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (gint) r;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (gint) g;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (gint) b;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) a;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1156,9 +1116,5 @@ color_notebook_drag_old_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->orig_rgb;
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,6 +33,7 @@ typedef void (* ColorNotebookCallback) (GimpRGB *color,
|
||||||
|
|
||||||
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
||||||
|
|
||||||
|
|
||||||
ColorNotebook * color_notebook_new (GimpRGB *color,
|
ColorNotebook * color_notebook_new (GimpRGB *color,
|
||||||
ColorNotebookCallback callback,
|
ColorNotebookCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
|
|
@ -72,9 +72,10 @@ struct _ColorNotebook
|
||||||
|
|
||||||
GdkGC *gc;
|
GdkGC *gc;
|
||||||
|
|
||||||
gint values[7];
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gint orig_values[4];
|
GimpRGB orig_rgb;
|
||||||
|
|
||||||
GimpColorSelectorChannelType active_channel;
|
GimpColorSelectorChannelType active_channel;
|
||||||
|
|
||||||
|
@ -121,13 +122,8 @@ static void color_notebook_ok_callback (GtkWidget *widget,
|
||||||
static void color_notebook_cancel_callback (GtkWidget *widget,
|
static void color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
static void color_notebook_update_callback (gpointer data,
|
static void color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb);
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha);
|
|
||||||
static void color_notebook_page_switch (GtkWidget *widget,
|
static void color_notebook_page_switch (GtkWidget *widget,
|
||||||
GtkNotebookPage *page,
|
GtkNotebookPage *page,
|
||||||
guint page_num,
|
guint page_num,
|
||||||
|
@ -203,8 +199,6 @@ color_notebook_new (GimpRGB *color,
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
static gchar *toggle_titles[] =
|
static gchar *toggle_titles[] =
|
||||||
{
|
{
|
||||||
N_("H"),
|
N_("H"),
|
||||||
|
@ -225,14 +219,13 @@ color_notebook_new (GimpRGB *color,
|
||||||
N_("Blue"),
|
N_("Blue"),
|
||||||
N_("Alpha")
|
N_("Alpha")
|
||||||
};
|
};
|
||||||
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 255 };
|
static gdouble slider_initial_vals[] = { 0, 0, 0, 0, 0, 0, 0 };
|
||||||
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 16 };
|
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 100 };
|
||||||
|
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 10 };
|
||||||
|
|
||||||
g_return_val_if_fail (selector_info != NULL, NULL);
|
g_return_val_if_fail (selector_info != NULL, NULL);
|
||||||
g_return_val_if_fail (color != NULL, NULL);
|
g_return_val_if_fail (color != NULL, NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
|
||||||
|
|
||||||
cnp = g_new0 (ColorNotebook, 1);
|
cnp = g_new0 (ColorNotebook, 1);
|
||||||
|
|
||||||
cnp->gc = NULL;
|
cnp->gc = NULL;
|
||||||
|
@ -244,10 +237,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->selectors = NULL;
|
cnp->selectors = NULL;
|
||||||
cnp->cur_page = NULL;
|
cnp->cur_page = NULL;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
cnp->rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
|
||||||
|
@ -295,13 +286,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
csel->info = info;
|
csel->info = info;
|
||||||
info->refs++;
|
info->refs++;
|
||||||
csel->frame =
|
csel->frame =
|
||||||
info->methods.new (cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
info->methods.new (&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA],
|
|
||||||
show_alpha,
|
show_alpha,
|
||||||
color_notebook_update_callback, csel,
|
color_notebook_update_callback, csel,
|
||||||
&csel->selector_data);
|
&csel->selector_data);
|
||||||
|
@ -418,6 +404,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
||||||
gtk_table_attach (GTK_TABLE (table), label,
|
gtk_table_attach (GTK_TABLE (table), label,
|
||||||
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
||||||
|
gtk_widget_show (label);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -438,7 +425,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
||||||
NULL,
|
NULL,
|
||||||
80, 55,
|
80, 55,
|
||||||
cnp->values[i],
|
slider_initial_vals[i],
|
||||||
0.0, slider_max_vals[i],
|
0.0, slider_max_vals[i],
|
||||||
1.0, slider_incs[i],
|
1.0, slider_incs[i],
|
||||||
0, TRUE, 0.0, 0.0,
|
0, TRUE, 0.0, 0.0,
|
||||||
|
@ -455,7 +442,10 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_widget_show (hbox);
|
gtk_widget_show (hbox);
|
||||||
|
|
||||||
cnp->hex_entry = gtk_entry_new ();
|
cnp->hex_entry = gtk_entry_new ();
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x", red, green, blue);
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
|
(gint) (color->r * 255.999),
|
||||||
|
(gint) (color->g * 255.999),
|
||||||
|
(gint) (color->b * 255.999));
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
||||||
|
@ -471,6 +461,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
||||||
gtk_widget_show (label);
|
gtk_widget_show (label);
|
||||||
|
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
gtk_widget_show (cnp->shell);
|
gtk_widget_show (cnp->shell);
|
||||||
|
|
||||||
/* this must come after showing the widget, otherwise we get a
|
/* this must come after showing the widget, otherwise we get a
|
||||||
|
@ -537,19 +529,14 @@ void
|
||||||
color_notebook_set_color (ColorNotebook *cnp,
|
color_notebook_set_color (ColorNotebook *cnp,
|
||||||
GimpRGB *color)
|
GimpRGB *color)
|
||||||
{
|
{
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
g_return_if_fail (cnp != NULL);
|
g_return_if_fail (cnp != NULL);
|
||||||
g_return_if_fail (color != NULL);
|
g_return_if_fail (color != NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
cnp->rgb = *color;
|
||||||
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
color_notebook_update (cnp,
|
color_notebook_update (cnp,
|
||||||
UPDATE_NOTEBOOK |
|
UPDATE_NOTEBOOK |
|
||||||
|
@ -562,29 +549,21 @@ color_notebook_set_color (ColorNotebook *cnp,
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
color_notebook_update_callback (gpointer data,
|
color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb)
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha)
|
|
||||||
{
|
{
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
|
|
||||||
g_return_if_fail (data != NULL);
|
g_return_if_fail (data != NULL);
|
||||||
|
g_return_if_fail (hsv != NULL);
|
||||||
|
g_return_if_fail (rgb != NULL);
|
||||||
|
|
||||||
csel = (ColorSelectorInstance *) data;
|
csel = (ColorSelectorInstance *) data;
|
||||||
cnp = csel->color_notebook;
|
cnp = csel->color_notebook;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = hue;
|
cnp->hsv = *hsv;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = saturation;
|
cnp->rgb = *rgb;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = value;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
|
@ -598,19 +577,12 @@ color_notebook_ok_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_OK,
|
COLOR_NOTEBOOK_OK,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -621,19 +593,12 @@ color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->orig_rgb,
|
||||||
COLOR_NOTEBOOK_CANCEL,
|
COLOR_NOTEBOOK_CANCEL,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -800,13 +765,8 @@ color_notebook_update_notebook (ColorNotebook *cnp)
|
||||||
|
|
||||||
csel = cnp->cur_page;
|
csel = cnp->cur_page;
|
||||||
csel->info->methods.set_color (csel->selector_data,
|
csel->info->methods.set_color (csel->selector_data,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb);
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -824,17 +784,9 @@ color_notebook_update_channel (ColorNotebook *cnp)
|
||||||
static void
|
static void
|
||||||
color_notebook_update_caller (ColorNotebook *cnp)
|
color_notebook_update_caller (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
gimp_rgba_set (&color,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] / 255.0);
|
|
||||||
|
|
||||||
if (cnp && cnp->callback)
|
if (cnp && cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_UPDATE,
|
COLOR_NOTEBOOK_UPDATE,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -846,7 +798,7 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
{
|
{
|
||||||
GdkWindow *window;
|
GdkWindow *window;
|
||||||
GdkColor color;
|
GdkColor color;
|
||||||
gint red, green, blue;
|
guchar red, green, blue;
|
||||||
gint width, height;
|
gint width, height;
|
||||||
|
|
||||||
if (!cnp)
|
if (!cnp)
|
||||||
|
@ -855,16 +807,14 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
if (which == UPDATE_ORIG_COLOR)
|
if (which == UPDATE_ORIG_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->orig_color->window;
|
window = cnp->orig_color->window;
|
||||||
red = cnp->orig_values[0];
|
|
||||||
green = cnp->orig_values[1];
|
gimp_rgb_get_uchar (&cnp->orig_rgb, &red, &green, &blue);
|
||||||
blue = cnp->orig_values[2];
|
|
||||||
}
|
}
|
||||||
else if (which == UPDATE_NEW_COLOR)
|
else if (which == UPDATE_NEW_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->new_color->window;
|
window = cnp->new_color->window;
|
||||||
red = cnp->values[GIMP_COLOR_SELECTOR_RED];
|
|
||||||
green = cnp->values[GIMP_COLOR_SELECTOR_GREEN];
|
gimp_rgb_get_uchar (&cnp->rgb, &red, &green, &blue);
|
||||||
blue = cnp->values[GIMP_COLOR_SELECTOR_BLUE];
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -892,64 +842,55 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
static void
|
static void
|
||||||
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble h, s, v;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
h = cnp->values[GIMP_COLOR_SELECTOR_HUE] / 360.0;
|
gimp_hsv_to_rgb (&cnp->hsv, &cnp->rgb);
|
||||||
s = cnp->values[GIMP_COLOR_SELECTOR_SATURATION] / 100.0;
|
|
||||||
v = cnp->values[GIMP_COLOR_SELECTOR_VALUE] / 100.0;
|
|
||||||
|
|
||||||
gimp_hsv_to_rgb_double (&h, &s, &v);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = h * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = s * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = v * 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble r, g, b;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0;
|
gimp_rgb_to_hsv (&cnp->rgb, &cnp->hsv);
|
||||||
g = cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0;
|
|
||||||
b = cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0;
|
|
||||||
|
|
||||||
gimp_rgb_to_hsv_double (&r, &g, &b);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = r * 360.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = g * 100.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = b * 100.0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_scales (ColorNotebook *cnp,
|
color_notebook_update_scales (ColorNotebook *cnp,
|
||||||
gint skip)
|
gint skip)
|
||||||
{
|
{
|
||||||
|
gint values[7];
|
||||||
gchar buffer[16];
|
gchar buffer[16];
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
values[GIMP_COLOR_SELECTOR_HUE] = (gint) (cnp->hsv.h * 360.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_SATURATION] = (gint) (cnp->hsv.s * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_VALUE] = (gint) (cnp->hsv.v * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_RED] = (gint) (cnp->rgb.r * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_GREEN] = (gint) (cnp->rgb.g * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_BLUE] = (gint) (cnp->rgb.b * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) (cnp->rgb.a * 100.999);
|
||||||
|
|
||||||
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
||||||
if (i != skip)
|
if (i != skip)
|
||||||
{
|
{
|
||||||
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
||||||
cnp->values[i]);
|
values[i]);
|
||||||
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
}
|
}
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
values[GIMP_COLOR_SELECTOR_RED],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
values[GIMP_COLOR_SELECTOR_GREEN],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
values[GIMP_COLOR_SELECTOR_BLUE]);
|
||||||
|
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
}
|
}
|
||||||
|
@ -1024,7 +965,36 @@ color_notebook_scale_update (GtkAdjustment *adjustment,
|
||||||
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
cnp->values[i] = (gint) (GTK_ADJUSTMENT (adjustment)->value);
|
switch (i)
|
||||||
|
{
|
||||||
|
case GIMP_COLOR_SELECTOR_HUE:
|
||||||
|
cnp->hsv.h = GTK_ADJUSTMENT (adjustment)->value / 360.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_SATURATION:
|
||||||
|
cnp->hsv.s = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_VALUE:
|
||||||
|
cnp->hsv.v = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_RED:
|
||||||
|
cnp->rgb.r = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_GREEN:
|
||||||
|
cnp->rgb.g = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_BLUE:
|
||||||
|
cnp->rgb.b = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_ALPHA:
|
||||||
|
cnp->hsv.a = cnp->rgb.a = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
||||||
{
|
{
|
||||||
|
@ -1069,9 +1039,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
(gint) (cnp->rgb.r * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
(gint) (cnp->rgb.g * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
(gint) (cnp->rgb.b * 255.999));
|
||||||
|
|
||||||
if ((strlen (hex_color) == 7) &&
|
if ((strlen (hex_color) == 7) &&
|
||||||
(g_strcasecmp (buffer, hex_color) != 0))
|
(g_strcasecmp (buffer, hex_color) != 0))
|
||||||
|
@ -1079,9 +1049,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
||||||
(hex_rgb < (1 << 24)))
|
(hex_rgb < (1 << 24)))
|
||||||
{
|
{
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (hex_rgb & 0xff0000) >> 16;
|
cnp->rgb.r = ((hex_rgb & 0xff0000) >> 16) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (hex_rgb & 0x00ff00) >> 8;
|
cnp->rgb.g = ((hex_rgb & 0x00ff00) >> 8) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (hex_rgb & 0x0000ff);
|
cnp->rgb.b = ((hex_rgb & 0x0000ff)) / 255.0;
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1114,11 +1084,7 @@ color_notebook_drag_new_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->rgb;
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1127,16 +1093,10 @@ color_notebook_drop_new_color (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
guchar r, g, b, a;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &r, &g, &b, &a);
|
cnp->rgb = *color;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (gint) r;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (gint) g;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (gint) b;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) a;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1156,9 +1116,5 @@ color_notebook_drag_old_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->orig_rgb;
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,6 +33,7 @@ typedef void (* ColorNotebookCallback) (GimpRGB *color,
|
||||||
|
|
||||||
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
||||||
|
|
||||||
|
|
||||||
ColorNotebook * color_notebook_new (GimpRGB *color,
|
ColorNotebook * color_notebook_new (GimpRGB *color,
|
||||||
ColorNotebookCallback callback,
|
ColorNotebookCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "session.h"
|
#include "session.h"
|
||||||
#include "color_area.h"
|
#include "color_area.h"
|
||||||
|
|
||||||
|
#include "libgimp/gimpcolorspace.h"
|
||||||
#include "libgimp/gimpcolorselector.h"
|
#include "libgimp/gimpcolorselector.h"
|
||||||
#include "libgimp/gimphelpui.h"
|
#include "libgimp/gimphelpui.h"
|
||||||
|
|
||||||
|
@ -82,13 +83,8 @@ typedef enum
|
||||||
UPDATE_CALLER = 1 << 6
|
UPDATE_CALLER = 1 << 6
|
||||||
} ColorSelectUpdateType;
|
} ColorSelectUpdateType;
|
||||||
|
|
||||||
typedef void (* ColorSelectCallback) (gint h,
|
typedef void (* ColorSelectCallback) (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gpointer data);
|
gpointer data);
|
||||||
|
|
||||||
typedef struct _ColorSelect ColorSelect;
|
typedef struct _ColorSelect ColorSelect;
|
||||||
|
@ -99,7 +95,10 @@ struct _ColorSelect
|
||||||
GtkWidget *z_color;
|
GtkWidget *z_color;
|
||||||
|
|
||||||
gint pos[3];
|
gint pos[3];
|
||||||
gint values[7];
|
|
||||||
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gint z_color_fill;
|
gint z_color_fill;
|
||||||
gint xy_color_fill;
|
gint xy_color_fill;
|
||||||
GdkGC *gc;
|
GdkGC *gc;
|
||||||
|
@ -118,28 +117,26 @@ struct _ColorSelectFill
|
||||||
gint y;
|
gint y;
|
||||||
gint width;
|
gint width;
|
||||||
gint height;
|
gint height;
|
||||||
gint *values;
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
ColorSelectFillUpdateProc update;
|
ColorSelectFillUpdateProc update;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static GtkWidget * color_select_widget_new (ColorSelect *,
|
static GtkWidget * color_select_widget_new (ColorSelect *csp,
|
||||||
gint ,
|
const GimpRGB *color);
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint );
|
|
||||||
|
|
||||||
static void color_select_drop_color (GtkWidget *widget,
|
static void color_select_drop_color (GtkWidget *widget,
|
||||||
GimpRGB *color,
|
GimpRGB *color,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
static void color_select_update (ColorSelect *,
|
static void color_select_update (ColorSelect *csp,
|
||||||
ColorSelectUpdateType);
|
ColorSelectUpdateType);
|
||||||
static void color_select_update_caller (ColorSelect *);
|
static void color_select_update_caller (ColorSelect *csp);
|
||||||
static void color_select_update_values (ColorSelect *);
|
static void color_select_update_values (ColorSelect *csp);
|
||||||
static void color_select_update_rgb_values (ColorSelect *);
|
static void color_select_update_rgb_values (ColorSelect *csp);
|
||||||
static void color_select_update_hsv_values (ColorSelect *);
|
static void color_select_update_hsv_values (ColorSelect *csp);
|
||||||
static void color_select_update_pos (ColorSelect *);
|
static void color_select_update_pos (ColorSelect *csp);
|
||||||
|
|
||||||
static gint color_select_xy_expose (GtkWidget *widget,
|
static gint color_select_xy_expose (GtkWidget *widget,
|
||||||
GdkEventExpose *eevent,
|
GdkEventExpose *eevent,
|
||||||
|
@ -156,55 +153,41 @@ static gint color_select_z_events (GtkWidget *widet,
|
||||||
|
|
||||||
static void color_select_image_fill (GtkWidget *,
|
static void color_select_image_fill (GtkWidget *,
|
||||||
ColorSelectFillType,
|
ColorSelectFillType,
|
||||||
gint *);
|
const GimpHSV *hsv,
|
||||||
|
const GimpRGB *rgb);
|
||||||
|
|
||||||
static void color_select_draw_z_marker (ColorSelect *,
|
static void color_select_draw_z_marker (ColorSelect *csp,
|
||||||
GdkRectangle *);
|
GdkRectangle *);
|
||||||
static void color_select_draw_xy_marker (ColorSelect *,
|
static void color_select_draw_xy_marker (ColorSelect *csp,
|
||||||
GdkRectangle *);
|
GdkRectangle *);
|
||||||
|
|
||||||
static void color_select_update_red (ColorSelectFill *);
|
static void color_select_update_red (ColorSelectFill *csf);
|
||||||
static void color_select_update_green (ColorSelectFill *);
|
static void color_select_update_green (ColorSelectFill *csf);
|
||||||
static void color_select_update_blue (ColorSelectFill *);
|
static void color_select_update_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue (ColorSelectFill *);
|
static void color_select_update_hue (ColorSelectFill *csf);
|
||||||
static void color_select_update_saturation (ColorSelectFill *);
|
static void color_select_update_saturation (ColorSelectFill *csf);
|
||||||
static void color_select_update_value (ColorSelectFill *);
|
static void color_select_update_value (ColorSelectFill *csf);
|
||||||
static void color_select_update_red_green (ColorSelectFill *);
|
static void color_select_update_red_green (ColorSelectFill *csf);
|
||||||
static void color_select_update_red_blue (ColorSelectFill *);
|
static void color_select_update_red_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_green_blue (ColorSelectFill *);
|
static void color_select_update_green_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue_saturation (ColorSelectFill *);
|
static void color_select_update_hue_saturation (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue_value (ColorSelectFill *);
|
static void color_select_update_hue_value (ColorSelectFill *csf);
|
||||||
static void color_select_update_saturation_value (ColorSelectFill *);
|
static void color_select_update_saturation_value (ColorSelectFill *csf);
|
||||||
|
|
||||||
static GtkWidget * color_select_notebook_new (gint ,
|
static GtkWidget * color_select_notebook_new (const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb,
|
||||||
gint ,
|
gboolean show_alpha,
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gboolean ,
|
|
||||||
GimpColorSelectorCallback,
|
GimpColorSelectorCallback,
|
||||||
gpointer ,
|
gpointer ,
|
||||||
gpointer *);
|
gpointer *);
|
||||||
static void color_select_notebook_free (gpointer );
|
static void color_select_notebook_free (gpointer );
|
||||||
static void color_select_notebook_set_color (gpointer ,
|
static void color_select_notebook_set_color (gpointer ,
|
||||||
gint ,
|
const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb);
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint );
|
|
||||||
static void color_select_notebook_set_channel (gpointer ,
|
static void color_select_notebook_set_channel (gpointer ,
|
||||||
GimpColorSelectorChannelType channel);
|
GimpColorSelectorChannelType channel);
|
||||||
static void color_select_notebook_update_callback (gint ,
|
static void color_select_notebook_update_callback (const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb,
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gpointer );
|
gpointer );
|
||||||
|
|
||||||
/* Static variables */
|
/* Static variables */
|
||||||
|
@ -252,10 +235,7 @@ color_select_init (void)
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
color_select_widget_new (ColorSelect *csp,
|
color_select_widget_new (ColorSelect *csp,
|
||||||
gint r,
|
const GimpRGB *color)
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
GtkWidget *main_vbox;
|
GtkWidget *main_vbox;
|
||||||
GtkWidget *main_hbox;
|
GtkWidget *main_hbox;
|
||||||
|
@ -330,16 +310,10 @@ color_select_drop_color (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorSelect *csp;
|
ColorSelect *csp;
|
||||||
guchar r, g, b, a;
|
|
||||||
|
|
||||||
csp = (ColorSelect *) data;
|
csp = (ColorSelect *) data;
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &r, &g, &b, &a);
|
csp->rgb = *color;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_RED] = (gint) r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = (gint) g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = (gint) b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = (gint) a;
|
|
||||||
|
|
||||||
color_select_update_hsv_values (csp);
|
color_select_update_hsv_values (csp);
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
@ -352,24 +326,14 @@ color_select_drop_color (GtkWidget *widget,
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_set_color (ColorSelect *csp,
|
color_select_set_color (ColorSelect *csp,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
csp->hsv = *hsv;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s;
|
csp->rgb = *rgb;
|
||||||
csp->values[COLOR_SELECT_VALUE] = v;
|
|
||||||
csp->values[COLOR_SELECT_RED] = r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = a;
|
|
||||||
|
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
|
||||||
|
@ -394,13 +358,15 @@ color_select_update (ColorSelect *csp,
|
||||||
|
|
||||||
if (update & UPDATE_XY_COLOR)
|
if (update & UPDATE_XY_COLOR)
|
||||||
{
|
{
|
||||||
color_select_image_fill (csp->xy_color, csp->xy_color_fill, csp->values);
|
color_select_image_fill (csp->xy_color, csp->xy_color_fill,
|
||||||
|
&csp->hsv, &csp->rgb);
|
||||||
gtk_widget_draw (csp->xy_color, NULL);
|
gtk_widget_draw (csp->xy_color, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (update & UPDATE_Z_COLOR)
|
if (update & UPDATE_Z_COLOR)
|
||||||
{
|
{
|
||||||
color_select_image_fill (csp->z_color, csp->z_color_fill, csp->values);
|
color_select_image_fill (csp->z_color, csp->z_color_fill,
|
||||||
|
&csp->hsv, &csp->rgb);
|
||||||
gtk_widget_draw (csp->z_color, NULL);
|
gtk_widget_draw (csp->z_color, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -413,13 +379,8 @@ color_select_update_caller (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
if (csp && csp->callback)
|
if (csp && csp->callback)
|
||||||
{
|
{
|
||||||
(* csp->callback) (csp->values[COLOR_SELECT_HUE],
|
(* csp->callback) (&csp->hsv,
|
||||||
csp->values[COLOR_SELECT_SATURATION],
|
&csp->rgb,
|
||||||
csp->values[COLOR_SELECT_VALUE],
|
|
||||||
csp->values[COLOR_SELECT_RED],
|
|
||||||
csp->values[COLOR_SELECT_GREEN],
|
|
||||||
csp->values[COLOR_SELECT_BLUE],
|
|
||||||
csp->values[COLOR_SELECT_ALPHA],
|
|
||||||
csp->client_data);
|
csp->client_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -433,34 +394,35 @@ color_select_update_values (ColorSelect *csp)
|
||||||
switch (csp->z_color_fill)
|
switch (csp->z_color_fill)
|
||||||
{
|
{
|
||||||
case COLOR_SELECT_RED:
|
case COLOR_SELECT_RED:
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[0];
|
csp->rgb.b = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[1];
|
csp->rgb.g = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[2];
|
csp->rgb.r = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_GREEN:
|
case COLOR_SELECT_GREEN:
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[0];
|
csp->rgb.b = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[1];
|
csp->rgb.r = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[2];
|
csp->rgb.g = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[0];
|
csp->rgb.g = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[1];
|
csp->rgb.r = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[2];
|
csp->rgb.b = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[0] * 100 / 255;
|
csp->hsv.v = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[1] * 100 / 255;
|
csp->hsv.s = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[2] * 360 / 255;
|
csp->hsv.h = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[0] * 100 / 255;
|
csp->hsv.v = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[1] * 360 / 255;
|
csp->hsv.h = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[2] * 100 / 255;
|
csp->hsv.s = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[0] * 100 / 255;
|
csp->hsv.s = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[1] * 360 / 255;
|
csp->hsv.h = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[2] * 100 / 255;
|
csp->hsv.v = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -471,6 +433,7 @@ color_select_update_values (ColorSelect *csp)
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
color_select_update_hsv_values (csp);
|
color_select_update_hsv_values (csp);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
|
@ -482,139 +445,19 @@ color_select_update_values (ColorSelect *csp)
|
||||||
static void
|
static void
|
||||||
color_select_update_rgb_values (ColorSelect *csp)
|
color_select_update_rgb_values (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
gfloat h, s, v;
|
|
||||||
gfloat f, p, q, t;
|
|
||||||
|
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
h = csp->values[COLOR_SELECT_HUE];
|
gimp_hsv_to_rgb (&csp->hsv, &csp->rgb);
|
||||||
s = csp->values[COLOR_SELECT_SATURATION] / 100.0;
|
|
||||||
v = csp->values[COLOR_SELECT_VALUE] / 100.0;
|
|
||||||
|
|
||||||
if (s == 0)
|
|
||||||
{
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (h == 360)
|
|
||||||
h = 0;
|
|
||||||
|
|
||||||
h /= 60;
|
|
||||||
f = h - (int) h;
|
|
||||||
p = v * (1 - s);
|
|
||||||
q = v * (1 - (s * f));
|
|
||||||
t = v * (1 - (s * (1 - f)));
|
|
||||||
|
|
||||||
switch ((gint) h)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = t * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = p * 255;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
csp->values[COLOR_SELECT_RED] = q * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = p * 255;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
csp->values[COLOR_SELECT_RED] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = t * 255;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
csp->values[COLOR_SELECT_RED] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = q * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
csp->values[COLOR_SELECT_RED] = t * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = q * 255;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_update_hsv_values (ColorSelect *csp)
|
color_select_update_hsv_values (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
gint r, g, b;
|
|
||||||
gfloat h, s, v;
|
|
||||||
gint min, max;
|
|
||||||
gint delta;
|
|
||||||
|
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = csp->values[COLOR_SELECT_RED];
|
gimp_rgb_to_hsv (&csp->rgb, &csp->hsv);
|
||||||
g = csp->values[COLOR_SELECT_GREEN];
|
|
||||||
b = csp->values[COLOR_SELECT_BLUE];
|
|
||||||
|
|
||||||
if (r > g)
|
|
||||||
{
|
|
||||||
if (r > b)
|
|
||||||
max = r;
|
|
||||||
else
|
|
||||||
max = b;
|
|
||||||
|
|
||||||
if (g < b)
|
|
||||||
min = g;
|
|
||||||
else
|
|
||||||
min = b;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (g > b)
|
|
||||||
max = g;
|
|
||||||
else
|
|
||||||
max = b;
|
|
||||||
|
|
||||||
if (r < b)
|
|
||||||
min = r;
|
|
||||||
else
|
|
||||||
min = b;
|
|
||||||
}
|
|
||||||
|
|
||||||
v = max;
|
|
||||||
|
|
||||||
if (max != 0)
|
|
||||||
s = (max - min) / (float) max;
|
|
||||||
else
|
|
||||||
s = 0;
|
|
||||||
|
|
||||||
if (s == 0)
|
|
||||||
{
|
|
||||||
h = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
h = 0;
|
|
||||||
delta = max - min;
|
|
||||||
if (r == max)
|
|
||||||
h = (g - b) / (float) delta;
|
|
||||||
else if (g == max)
|
|
||||||
h = 2 + (b - r) / (float) delta;
|
|
||||||
else if (b == max)
|
|
||||||
h = 4 + (r - g) / (float) delta;
|
|
||||||
h *= 60;
|
|
||||||
|
|
||||||
if (h < 0)
|
|
||||||
h += 360;
|
|
||||||
}
|
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s * 100;
|
|
||||||
csp->values[COLOR_SELECT_VALUE] = v * 100 / 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -626,34 +469,35 @@ color_select_update_pos (ColorSelect *csp)
|
||||||
switch (csp->z_color_fill)
|
switch (csp->z_color_fill)
|
||||||
{
|
{
|
||||||
case COLOR_SELECT_RED:
|
case COLOR_SELECT_RED:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[0] = (gint) (csp->rgb.b * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[1] = (gint) (csp->rgb.g * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_RED];
|
csp->pos[2] = (gint) (csp->rgb.r * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_GREEN:
|
case COLOR_SELECT_GREEN:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[0] = (gint) (csp->rgb.b * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_RED];
|
csp->pos[1] = (gint) (csp->rgb.r * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[2] = (gint) (csp->rgb.g * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[0] = (gint) (csp->rgb.g * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_RED];
|
csp->pos[1] = (gint) (csp->rgb.r * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[2] = (gint) (csp->rgb.b * 255.999);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.v * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[1] = (gint) (csp->hsv.s * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[2] = (gint) (csp->hsv.h * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.v * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[1] = (gint) (csp->hsv.h * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[2] = (gint) (csp->hsv.s * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.s * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[1] = (gint) (csp->hsv.h * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[2] = (gint) (csp->hsv.v * 255.999);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -795,10 +639,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
gdk_pointer_grab (csp->z_color->window, FALSE,
|
gdk_pointer_grab (csp->z_color->window, FALSE,
|
||||||
GDK_POINTER_MOTION_HINT_MASK |
|
GDK_POINTER_MOTION_HINT_MASK |
|
||||||
|
@ -815,10 +657,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
gdk_pointer_ungrab (bevent->time);
|
gdk_pointer_ungrab (bevent->time);
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
@ -837,10 +677,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (mevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (mevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
color_select_update (csp, UPDATE_VALUES | UPDATE_CALLER);
|
color_select_update (csp, UPDATE_VALUES | UPDATE_CALLER);
|
||||||
|
@ -897,7 +735,8 @@ color_select_set_channel (ColorSelect *csp,
|
||||||
static void
|
static void
|
||||||
color_select_image_fill (GtkWidget *preview,
|
color_select_image_fill (GtkWidget *preview,
|
||||||
ColorSelectFillType type,
|
ColorSelectFillType type,
|
||||||
gint *values)
|
const GimpHSV *hsv,
|
||||||
|
const GimpRGB *rgb)
|
||||||
{
|
{
|
||||||
ColorSelectFill csf;
|
ColorSelectFill csf;
|
||||||
gint height;
|
gint height;
|
||||||
|
@ -909,7 +748,8 @@ color_select_image_fill (GtkWidget *preview,
|
||||||
csf.y = -1;
|
csf.y = -1;
|
||||||
csf.width = preview->requisition.width;
|
csf.width = preview->requisition.width;
|
||||||
csf.height = preview->requisition.height;
|
csf.height = preview->requisition.height;
|
||||||
csf.values = values;
|
csf.hsv = *hsv;
|
||||||
|
csf.rgb = *rgb;
|
||||||
|
|
||||||
height = csf.height;
|
height = csf.height;
|
||||||
if (height > 0)
|
if (height > 0)
|
||||||
|
@ -1085,14 +925,9 @@ color_select_update_hue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
h = csf->y * 360 / csf->height;
|
h = csf->y * 360.0 / csf->height;
|
||||||
|
|
||||||
h = 360 - h;
|
h = CLAMP (360 - h, 0, 360);
|
||||||
|
|
||||||
if (h < 0)
|
|
||||||
h = 0;
|
|
||||||
if (h >= 360)
|
|
||||||
h = 0;
|
|
||||||
|
|
||||||
h /= 60;
|
h /= 60;
|
||||||
f = (h - (int) h) * 255;
|
f = (h - (int) h) * 255;
|
||||||
|
@ -1205,7 +1040,7 @@ color_select_update_red_green (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
b = csf->values[COLOR_SELECT_BLUE];
|
b = (gint) (csf->rgb.b * 255.999);
|
||||||
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
|
@ -1236,7 +1071,7 @@ color_select_update_red_blue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
g = csf->values[COLOR_SELECT_GREEN];
|
g = (gint) (csf->rgb.g * 255.999);
|
||||||
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
|
@ -1267,7 +1102,7 @@ color_select_update_green_blue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
r = csf->values[COLOR_SELECT_RED];
|
r = (gint) (csf->rgb.r * 255.999);
|
||||||
g = (csf->height - csf->y + 1) * 255 / csf->height;
|
g = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (g < 0)
|
if (g < 0)
|
||||||
|
@ -1312,7 +1147,7 @@ color_select_update_hue_saturation (ColorSelectFill *csf)
|
||||||
s = 0;
|
s = 0;
|
||||||
ds = 1.0 / csf->width;
|
ds = 1.0 / csf->width;
|
||||||
|
|
||||||
v = csf->values[COLOR_SELECT_VALUE] / 100.0;
|
v = csf->hsv.v;
|
||||||
|
|
||||||
switch ((int) h)
|
switch ((int) h)
|
||||||
{
|
{
|
||||||
|
@ -1403,7 +1238,7 @@ color_select_update_hue_value (ColorSelectFill *csf)
|
||||||
v = 0;
|
v = 0;
|
||||||
dv = 1.0 / csf->width;
|
dv = 1.0 / csf->width;
|
||||||
|
|
||||||
s = csf->values[COLOR_SELECT_SATURATION] / 100.0;
|
s = csf->hsv.s;
|
||||||
|
|
||||||
switch ((int) h)
|
switch ((int) h)
|
||||||
{
|
{
|
||||||
|
@ -1490,7 +1325,7 @@ color_select_update_saturation_value (ColorSelectFill *csf)
|
||||||
|
|
||||||
s = 1 - s;
|
s = 1 - s;
|
||||||
|
|
||||||
h = (gfloat) csf->values[COLOR_SELECT_HUE];
|
h = (gfloat) csf->hsv.h * 360.0;
|
||||||
if (h >= 360)
|
if (h >= 360)
|
||||||
h -= 360;
|
h -= 360;
|
||||||
h /= 60;
|
h /= 60;
|
||||||
|
@ -1577,13 +1412,8 @@ typedef struct
|
||||||
} notebook_glue;
|
} notebook_glue;
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
color_select_notebook_new (gint h,
|
color_select_notebook_new (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
@ -1607,20 +1437,14 @@ color_select_notebook_new (gint h,
|
||||||
csp->xy_color_fill = COLOR_SELECT_SATURATION_VALUE;
|
csp->xy_color_fill = COLOR_SELECT_SATURATION_VALUE;
|
||||||
csp->gc = NULL;
|
csp->gc = NULL;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
csp->hsv = *hsv;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s;
|
csp->rgb = *rgb;
|
||||||
csp->values[COLOR_SELECT_VALUE] = v;
|
|
||||||
csp->values[COLOR_SELECT_RED] = r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = a;
|
|
||||||
|
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
|
||||||
glue->main_vbox = color_select_widget_new (csp, r, g, b, a);
|
glue->main_vbox = color_select_widget_new (csp, rgb);
|
||||||
|
|
||||||
color_select_image_fill (csp->z_color, csp->z_color_fill, csp->values);
|
color_select_update (csp, UPDATE_XY_COLOR | UPDATE_Z_COLOR);
|
||||||
color_select_image_fill (csp->xy_color, csp->xy_color_fill, csp->values);
|
|
||||||
|
|
||||||
*selector_data = glue;
|
*selector_data = glue;
|
||||||
|
|
||||||
|
@ -1642,20 +1466,14 @@ color_select_notebook_free (gpointer data)
|
||||||
g_free (glue);
|
g_free (glue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_notebook_set_color (gpointer data,
|
color_select_notebook_set_color (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
notebook_glue *glue = data;
|
notebook_glue *glue = data;
|
||||||
|
|
||||||
color_select_set_color (glue->csp, h, s, v, r, g, b, a);
|
color_select_set_color (glue->csp, hsv, rgb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1668,16 +1486,11 @@ color_select_notebook_set_channel (gpointer data,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_notebook_update_callback (gint h,
|
color_select_notebook_update_callback (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
notebook_glue *glue = data;
|
notebook_glue *glue = data;
|
||||||
|
|
||||||
glue->callback (glue->client_data, h, s, v, r, g, b, a);
|
glue->callback (glue->client_data, hsv, rgb);
|
||||||
}
|
}
|
||||||
|
|
|
@ -72,9 +72,10 @@ struct _ColorNotebook
|
||||||
|
|
||||||
GdkGC *gc;
|
GdkGC *gc;
|
||||||
|
|
||||||
gint values[7];
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gint orig_values[4];
|
GimpRGB orig_rgb;
|
||||||
|
|
||||||
GimpColorSelectorChannelType active_channel;
|
GimpColorSelectorChannelType active_channel;
|
||||||
|
|
||||||
|
@ -121,13 +122,8 @@ static void color_notebook_ok_callback (GtkWidget *widget,
|
||||||
static void color_notebook_cancel_callback (GtkWidget *widget,
|
static void color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
static void color_notebook_update_callback (gpointer data,
|
static void color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb);
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha);
|
|
||||||
static void color_notebook_page_switch (GtkWidget *widget,
|
static void color_notebook_page_switch (GtkWidget *widget,
|
||||||
GtkNotebookPage *page,
|
GtkNotebookPage *page,
|
||||||
guint page_num,
|
guint page_num,
|
||||||
|
@ -203,8 +199,6 @@ color_notebook_new (GimpRGB *color,
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
static gchar *toggle_titles[] =
|
static gchar *toggle_titles[] =
|
||||||
{
|
{
|
||||||
N_("H"),
|
N_("H"),
|
||||||
|
@ -225,14 +219,13 @@ color_notebook_new (GimpRGB *color,
|
||||||
N_("Blue"),
|
N_("Blue"),
|
||||||
N_("Alpha")
|
N_("Alpha")
|
||||||
};
|
};
|
||||||
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 255 };
|
static gdouble slider_initial_vals[] = { 0, 0, 0, 0, 0, 0, 0 };
|
||||||
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 16 };
|
static gdouble slider_max_vals[] = { 360, 100, 100, 255, 255, 255, 100 };
|
||||||
|
static gdouble slider_incs[] = { 30, 10, 10, 16, 16, 16, 10 };
|
||||||
|
|
||||||
g_return_val_if_fail (selector_info != NULL, NULL);
|
g_return_val_if_fail (selector_info != NULL, NULL);
|
||||||
g_return_val_if_fail (color != NULL, NULL);
|
g_return_val_if_fail (color != NULL, NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
|
||||||
|
|
||||||
cnp = g_new0 (ColorNotebook, 1);
|
cnp = g_new0 (ColorNotebook, 1);
|
||||||
|
|
||||||
cnp->gc = NULL;
|
cnp->gc = NULL;
|
||||||
|
@ -244,10 +237,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->selectors = NULL;
|
cnp->selectors = NULL;
|
||||||
cnp->cur_page = NULL;
|
cnp->cur_page = NULL;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
cnp->rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
|
||||||
|
@ -295,13 +286,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
csel->info = info;
|
csel->info = info;
|
||||||
info->refs++;
|
info->refs++;
|
||||||
csel->frame =
|
csel->frame =
|
||||||
info->methods.new (cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
info->methods.new (&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA],
|
|
||||||
show_alpha,
|
show_alpha,
|
||||||
color_notebook_update_callback, csel,
|
color_notebook_update_callback, csel,
|
||||||
&csel->selector_data);
|
&csel->selector_data);
|
||||||
|
@ -418,6 +404,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
gtk_misc_set_alignment (GTK_MISC (label), 1.0, 0.5);
|
||||||
gtk_table_attach (GTK_TABLE (table), label,
|
gtk_table_attach (GTK_TABLE (table), label,
|
||||||
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
0, 1, i, i + 1, GTK_FILL, GTK_EXPAND, 0, 0);
|
||||||
|
gtk_widget_show (label);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -438,7 +425,7 @@ color_notebook_new (GimpRGB *color,
|
||||||
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
cnp->slider_data[i] = gimp_scale_entry_new (GTK_TABLE (table), 0, i,
|
||||||
NULL,
|
NULL,
|
||||||
80, 55,
|
80, 55,
|
||||||
cnp->values[i],
|
slider_initial_vals[i],
|
||||||
0.0, slider_max_vals[i],
|
0.0, slider_max_vals[i],
|
||||||
1.0, slider_incs[i],
|
1.0, slider_incs[i],
|
||||||
0, TRUE, 0.0, 0.0,
|
0, TRUE, 0.0, 0.0,
|
||||||
|
@ -455,7 +442,10 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_widget_show (hbox);
|
gtk_widget_show (hbox);
|
||||||
|
|
||||||
cnp->hex_entry = gtk_entry_new ();
|
cnp->hex_entry = gtk_entry_new ();
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x", red, green, blue);
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
|
(gint) (color->r * 255.999),
|
||||||
|
(gint) (color->g * 255.999),
|
||||||
|
(gint) (color->b * 255.999));
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
gtk_widget_set_usize (GTK_WIDGET (cnp->hex_entry), 75, 0);
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
gtk_box_pack_end (GTK_BOX (hbox), cnp->hex_entry, FALSE, FALSE, 2);
|
||||||
|
@ -471,6 +461,8 @@ color_notebook_new (GimpRGB *color,
|
||||||
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
gtk_box_pack_end (GTK_BOX (hbox), label, FALSE, FALSE, 0);
|
||||||
gtk_widget_show (label);
|
gtk_widget_show (label);
|
||||||
|
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
gtk_widget_show (cnp->shell);
|
gtk_widget_show (cnp->shell);
|
||||||
|
|
||||||
/* this must come after showing the widget, otherwise we get a
|
/* this must come after showing the widget, otherwise we get a
|
||||||
|
@ -537,19 +529,14 @@ void
|
||||||
color_notebook_set_color (ColorNotebook *cnp,
|
color_notebook_set_color (ColorNotebook *cnp,
|
||||||
GimpRGB *color)
|
GimpRGB *color)
|
||||||
{
|
{
|
||||||
guchar red, green, blue, alpha;
|
|
||||||
|
|
||||||
g_return_if_fail (cnp != NULL);
|
g_return_if_fail (cnp != NULL);
|
||||||
g_return_if_fail (color != NULL);
|
g_return_if_fail (color != NULL);
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &red, &green, &blue, &alpha);
|
cnp->rgb = *color;
|
||||||
|
cnp->orig_rgb = *color;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = cnp->orig_values[0] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = cnp->orig_values[1] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = cnp->orig_values[2] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = cnp->orig_values[3] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
color_notebook_update (cnp,
|
color_notebook_update (cnp,
|
||||||
UPDATE_NOTEBOOK |
|
UPDATE_NOTEBOOK |
|
||||||
|
@ -562,29 +549,21 @@ color_notebook_set_color (ColorNotebook *cnp,
|
||||||
*/
|
*/
|
||||||
static void
|
static void
|
||||||
color_notebook_update_callback (gpointer data,
|
color_notebook_update_callback (gpointer data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb)
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha)
|
|
||||||
{
|
{
|
||||||
ColorSelectorInstance *csel;
|
ColorSelectorInstance *csel;
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
|
|
||||||
g_return_if_fail (data != NULL);
|
g_return_if_fail (data != NULL);
|
||||||
|
g_return_if_fail (hsv != NULL);
|
||||||
|
g_return_if_fail (rgb != NULL);
|
||||||
|
|
||||||
csel = (ColorSelectorInstance *) data;
|
csel = (ColorSelectorInstance *) data;
|
||||||
cnp = csel->color_notebook;
|
cnp = csel->color_notebook;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = hue;
|
cnp->hsv = *hsv;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = saturation;
|
cnp->rgb = *rgb;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = value;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = red;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = green;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = blue;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = alpha;
|
|
||||||
|
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
|
||||||
|
@ -598,19 +577,12 @@ color_notebook_ok_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_OK,
|
COLOR_NOTEBOOK_OK,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -621,19 +593,12 @@ color_notebook_cancel_callback (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (&color,
|
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
|
|
||||||
if (cnp->callback)
|
if (cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->orig_rgb,
|
||||||
COLOR_NOTEBOOK_CANCEL,
|
COLOR_NOTEBOOK_CANCEL,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -800,13 +765,8 @@ color_notebook_update_notebook (ColorNotebook *cnp)
|
||||||
|
|
||||||
csel = cnp->cur_page;
|
csel = cnp->cur_page;
|
||||||
csel->info->methods.set_color (csel->selector_data,
|
csel->info->methods.set_color (csel->selector_data,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE],
|
&cnp->hsv,
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION],
|
&cnp->rgb);
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -824,17 +784,9 @@ color_notebook_update_channel (ColorNotebook *cnp)
|
||||||
static void
|
static void
|
||||||
color_notebook_update_caller (ColorNotebook *cnp)
|
color_notebook_update_caller (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
GimpRGB color;
|
|
||||||
|
|
||||||
gimp_rgba_set (&color,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0,
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] / 255.0);
|
|
||||||
|
|
||||||
if (cnp && cnp->callback)
|
if (cnp && cnp->callback)
|
||||||
{
|
{
|
||||||
(* cnp->callback) (&color,
|
(* cnp->callback) (&cnp->rgb,
|
||||||
COLOR_NOTEBOOK_UPDATE,
|
COLOR_NOTEBOOK_UPDATE,
|
||||||
cnp->client_data);
|
cnp->client_data);
|
||||||
}
|
}
|
||||||
|
@ -846,7 +798,7 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
{
|
{
|
||||||
GdkWindow *window;
|
GdkWindow *window;
|
||||||
GdkColor color;
|
GdkColor color;
|
||||||
gint red, green, blue;
|
guchar red, green, blue;
|
||||||
gint width, height;
|
gint width, height;
|
||||||
|
|
||||||
if (!cnp)
|
if (!cnp)
|
||||||
|
@ -855,16 +807,14 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
if (which == UPDATE_ORIG_COLOR)
|
if (which == UPDATE_ORIG_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->orig_color->window;
|
window = cnp->orig_color->window;
|
||||||
red = cnp->orig_values[0];
|
|
||||||
green = cnp->orig_values[1];
|
gimp_rgb_get_uchar (&cnp->orig_rgb, &red, &green, &blue);
|
||||||
blue = cnp->orig_values[2];
|
|
||||||
}
|
}
|
||||||
else if (which == UPDATE_NEW_COLOR)
|
else if (which == UPDATE_NEW_COLOR)
|
||||||
{
|
{
|
||||||
window = cnp->new_color->window;
|
window = cnp->new_color->window;
|
||||||
red = cnp->values[GIMP_COLOR_SELECTOR_RED];
|
|
||||||
green = cnp->values[GIMP_COLOR_SELECTOR_GREEN];
|
gimp_rgb_get_uchar (&cnp->rgb, &red, &green, &blue);
|
||||||
blue = cnp->values[GIMP_COLOR_SELECTOR_BLUE];
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -892,64 +842,55 @@ color_notebook_update_colors (ColorNotebook *cnp,
|
||||||
static void
|
static void
|
||||||
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
color_notebook_update_rgb_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble h, s, v;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
h = cnp->values[GIMP_COLOR_SELECTOR_HUE] / 360.0;
|
gimp_hsv_to_rgb (&cnp->hsv, &cnp->rgb);
|
||||||
s = cnp->values[GIMP_COLOR_SELECTOR_SATURATION] / 100.0;
|
|
||||||
v = cnp->values[GIMP_COLOR_SELECTOR_VALUE] / 100.0;
|
|
||||||
|
|
||||||
gimp_hsv_to_rgb_double (&h, &s, &v);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = h * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = s * 255;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = v * 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
color_notebook_update_hsv_values (ColorNotebook *cnp)
|
||||||
{
|
{
|
||||||
gdouble r, g, b;
|
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = cnp->values[GIMP_COLOR_SELECTOR_RED] / 255.0;
|
gimp_rgb_to_hsv (&cnp->rgb, &cnp->hsv);
|
||||||
g = cnp->values[GIMP_COLOR_SELECTOR_GREEN] / 255.0;
|
|
||||||
b = cnp->values[GIMP_COLOR_SELECTOR_BLUE] / 255.0;
|
|
||||||
|
|
||||||
gimp_rgb_to_hsv_double (&r, &g, &b);
|
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_HUE] = r * 360.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_SATURATION] = g * 100.0;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_VALUE] = b * 100.0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_notebook_update_scales (ColorNotebook *cnp,
|
color_notebook_update_scales (ColorNotebook *cnp,
|
||||||
gint skip)
|
gint skip)
|
||||||
{
|
{
|
||||||
|
gint values[7];
|
||||||
gchar buffer[16];
|
gchar buffer[16];
|
||||||
gint i;
|
gint i;
|
||||||
|
|
||||||
if (! cnp)
|
if (! cnp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
values[GIMP_COLOR_SELECTOR_HUE] = (gint) (cnp->hsv.h * 360.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_SATURATION] = (gint) (cnp->hsv.s * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_VALUE] = (gint) (cnp->hsv.v * 100.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_RED] = (gint) (cnp->rgb.r * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_GREEN] = (gint) (cnp->rgb.g * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_BLUE] = (gint) (cnp->rgb.b * 255.999);
|
||||||
|
values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) (cnp->rgb.a * 100.999);
|
||||||
|
|
||||||
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
for (i = 0; i < (cnp->show_alpha ? 7 : 6); i++)
|
||||||
if (i != skip)
|
if (i != skip)
|
||||||
{
|
{
|
||||||
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_block_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
gtk_adjustment_set_value (GTK_ADJUSTMENT (cnp->slider_data[i]),
|
||||||
cnp->values[i]);
|
values[i]);
|
||||||
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]), cnp);
|
gtk_signal_handler_unblock_by_data (GTK_OBJECT (cnp->slider_data[i]),
|
||||||
|
cnp);
|
||||||
}
|
}
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
values[GIMP_COLOR_SELECTOR_RED],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
values[GIMP_COLOR_SELECTOR_GREEN],
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
values[GIMP_COLOR_SELECTOR_BLUE]);
|
||||||
|
|
||||||
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
gtk_entry_set_text (GTK_ENTRY (cnp->hex_entry), buffer);
|
||||||
}
|
}
|
||||||
|
@ -1024,7 +965,36 @@ color_notebook_scale_update (GtkAdjustment *adjustment,
|
||||||
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
if (cnp->slider_data[i] == GTK_OBJECT (adjustment))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
cnp->values[i] = (gint) (GTK_ADJUSTMENT (adjustment)->value);
|
switch (i)
|
||||||
|
{
|
||||||
|
case GIMP_COLOR_SELECTOR_HUE:
|
||||||
|
cnp->hsv.h = GTK_ADJUSTMENT (adjustment)->value / 360.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_SATURATION:
|
||||||
|
cnp->hsv.s = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_VALUE:
|
||||||
|
cnp->hsv.v = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_RED:
|
||||||
|
cnp->rgb.r = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_GREEN:
|
||||||
|
cnp->rgb.g = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_BLUE:
|
||||||
|
cnp->rgb.b = GTK_ADJUSTMENT (adjustment)->value / 255.0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GIMP_COLOR_SELECTOR_ALPHA:
|
||||||
|
cnp->hsv.a = cnp->rgb.a = GTK_ADJUSTMENT (adjustment)->value / 100.0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
if ((i >= GIMP_COLOR_SELECTOR_HUE) && (i <= GIMP_COLOR_SELECTOR_VALUE))
|
||||||
{
|
{
|
||||||
|
@ -1069,9 +1039,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
hex_color = g_strdup (gtk_entry_get_text (GTK_ENTRY (cnp->hex_entry)));
|
||||||
|
|
||||||
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
g_snprintf (buffer, sizeof (buffer), "#%.2x%.2x%.2x",
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED],
|
(gint) (cnp->rgb.r * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
(gint) (cnp->rgb.g * 255.999),
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE]);
|
(gint) (cnp->rgb.b * 255.999));
|
||||||
|
|
||||||
if ((strlen (hex_color) == 7) &&
|
if ((strlen (hex_color) == 7) &&
|
||||||
(g_strcasecmp (buffer, hex_color) != 0))
|
(g_strcasecmp (buffer, hex_color) != 0))
|
||||||
|
@ -1079,9 +1049,9 @@ color_notebook_hex_entry_events (GtkWidget *widget,
|
||||||
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
if ((sscanf (hex_color, "#%x", &hex_rgb) == 1) &&
|
||||||
(hex_rgb < (1 << 24)))
|
(hex_rgb < (1 << 24)))
|
||||||
{
|
{
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (hex_rgb & 0xff0000) >> 16;
|
cnp->rgb.r = ((hex_rgb & 0xff0000) >> 16) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (hex_rgb & 0x00ff00) >> 8;
|
cnp->rgb.g = ((hex_rgb & 0x00ff00) >> 8) / 255.0;
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (hex_rgb & 0x0000ff);
|
cnp->rgb.b = ((hex_rgb & 0x0000ff)) / 255.0;
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1114,11 +1084,7 @@ color_notebook_drag_new_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->rgb;
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_RED],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_GREEN],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_BLUE],
|
|
||||||
(guchar) cnp->values[GIMP_COLOR_SELECTOR_ALPHA]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1127,16 +1093,10 @@ color_notebook_drop_new_color (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorNotebook *cnp;
|
ColorNotebook *cnp;
|
||||||
guchar r, g, b, a;
|
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &r, &g, &b, &a);
|
cnp->rgb = *color;
|
||||||
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_RED] = (gint) r;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_GREEN] = (gint) g;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_BLUE] = (gint) b;
|
|
||||||
cnp->values[GIMP_COLOR_SELECTOR_ALPHA] = (gint) a;
|
|
||||||
|
|
||||||
color_notebook_update_hsv_values (cnp);
|
color_notebook_update_hsv_values (cnp);
|
||||||
color_notebook_update_scales (cnp, -1);
|
color_notebook_update_scales (cnp, -1);
|
||||||
|
@ -1156,9 +1116,5 @@ color_notebook_drag_old_color (GtkWidget *widget,
|
||||||
|
|
||||||
cnp = (ColorNotebook *) data;
|
cnp = (ColorNotebook *) data;
|
||||||
|
|
||||||
gimp_rgba_set_uchar (color,
|
*color = cnp->orig_rgb;
|
||||||
(guchar) cnp->orig_values[0],
|
|
||||||
(guchar) cnp->orig_values[1],
|
|
||||||
(guchar) cnp->orig_values[2],
|
|
||||||
(guchar) cnp->orig_values[3]);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,6 +33,7 @@ typedef void (* ColorNotebookCallback) (GimpRGB *color,
|
||||||
|
|
||||||
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
typedef struct _ColorSelectorInstance ColorSelectorInstance;
|
||||||
|
|
||||||
|
|
||||||
ColorNotebook * color_notebook_new (GimpRGB *color,
|
ColorNotebook * color_notebook_new (GimpRGB *color,
|
||||||
ColorNotebookCallback callback,
|
ColorNotebookCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
|
|
@ -343,11 +343,11 @@ gimp_hsv_clamp (GimpHSV *hsv)
|
||||||
{
|
{
|
||||||
g_return_if_fail (hsv != NULL);
|
g_return_if_fail (hsv != NULL);
|
||||||
|
|
||||||
if (hsv->h < 0.0)
|
|
||||||
hsv->h = GIMP_HSV_UNDEFINED;
|
|
||||||
|
|
||||||
hsv->h -= (gint) hsv->h;
|
hsv->h -= (gint) hsv->h;
|
||||||
|
|
||||||
|
if (hsv->h < 0)
|
||||||
|
hsv->h += 1.0;
|
||||||
|
|
||||||
hsv->s = CLAMP (hsv->s, 0.0, 1.0);
|
hsv->s = CLAMP (hsv->s, 0.0, 1.0);
|
||||||
hsv->v = CLAMP (hsv->v, 0.0, 1.0);
|
hsv->v = CLAMP (hsv->v, 0.0, 1.0);
|
||||||
hsv->a = CLAMP (hsv->a, 0.0, 1.0);
|
hsv->a = CLAMP (hsv->a, 0.0, 1.0);
|
||||||
|
|
|
@ -41,21 +41,11 @@ typedef enum
|
||||||
|
|
||||||
|
|
||||||
typedef void (* GimpColorSelectorCallback) (gpointer data,
|
typedef void (* GimpColorSelectorCallback) (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb);
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a);
|
|
||||||
|
|
||||||
typedef GtkWidget * (* GimpColorSelectorNewFunc) (gint h,
|
typedef GtkWidget * (* GimpColorSelectorNewFunc) (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback cb,
|
GimpColorSelectorCallback cb,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
@ -65,13 +55,8 @@ typedef void (* GimpColorSelectorFreeFunc) (gpointer selector_data);
|
||||||
|
|
||||||
|
|
||||||
typedef void (* GimpColorSelectorSetColorFunc) (gpointer selector_data,
|
typedef void (* GimpColorSelectorSetColorFunc) (gpointer selector_data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb);
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a);
|
|
||||||
|
|
||||||
typedef void (* GimpColorSelectorSetChannelFunc) (gpointer selector_data,
|
typedef void (* GimpColorSelectorSetChannelFunc) (gpointer selector_data,
|
||||||
GimpColorSelectorChannelType type);
|
GimpColorSelectorChannelType type);
|
||||||
|
|
|
@ -24,6 +24,9 @@
|
||||||
#include "gimpmath.h"
|
#include "gimpmath.h"
|
||||||
|
|
||||||
|
|
||||||
|
#define GIMP_HSV_UNDEFINED -1.0
|
||||||
|
#define GIMP_HSL_UNDEFINED -1.0
|
||||||
|
|
||||||
/*********************************
|
/*********************************
|
||||||
* color conversion routines *
|
* color conversion routines *
|
||||||
*********************************/
|
*********************************/
|
||||||
|
@ -32,7 +35,7 @@
|
||||||
/* GimpRGB functions */
|
/* GimpRGB functions */
|
||||||
|
|
||||||
void
|
void
|
||||||
gimp_rgb_to_hsv (GimpRGB *rgb,
|
gimp_rgb_to_hsv (const GimpRGB *rgb,
|
||||||
GimpHSV *hsv)
|
GimpHSV *hsv)
|
||||||
{
|
{
|
||||||
gdouble max, min, delta;
|
gdouble max, min, delta;
|
||||||
|
@ -51,6 +54,9 @@ gimp_rgb_to_hsv (GimpRGB *rgb,
|
||||||
|
|
||||||
hsv->s = delta / max;
|
hsv->s = delta / max;
|
||||||
|
|
||||||
|
if (delta == 0.0)
|
||||||
|
delta = 1.0;
|
||||||
|
|
||||||
if (rgb->r == max)
|
if (rgb->r == max)
|
||||||
{
|
{
|
||||||
hsv->h = (rgb->g - rgb->b) / delta;
|
hsv->h = (rgb->g - rgb->b) / delta;
|
||||||
|
@ -74,23 +80,25 @@ gimp_rgb_to_hsv (GimpRGB *rgb,
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
hsv->s = 0.0;
|
hsv->s = 0.0;
|
||||||
hsv->h = GIMP_HSV_UNDEFINED;
|
hsv->h = 0.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
hsv->a = rgb->a;
|
hsv->a = rgb->a;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gimp_hsv_to_rgb (GimpHSV *hsv,
|
gimp_hsv_to_rgb (const GimpHSV *hsv,
|
||||||
GimpRGB *rgb)
|
GimpRGB *rgb)
|
||||||
{
|
{
|
||||||
gint i;
|
gint i;
|
||||||
gdouble f, w, q, t;
|
gdouble f, w, q, t;
|
||||||
|
|
||||||
|
gdouble hue;
|
||||||
|
|
||||||
g_return_if_fail (rgb != NULL);
|
g_return_if_fail (rgb != NULL);
|
||||||
g_return_if_fail (hsv != NULL);
|
g_return_if_fail (hsv != NULL);
|
||||||
|
|
||||||
if (hsv->s == 0.0 || hsv->h == GIMP_HSV_UNDEFINED)
|
if (hsv->s == 0.0)
|
||||||
{
|
{
|
||||||
rgb->r = hsv->v;
|
rgb->r = hsv->v;
|
||||||
rgb->g = hsv->v;
|
rgb->g = hsv->v;
|
||||||
|
@ -98,13 +106,15 @@ gimp_hsv_to_rgb (GimpHSV *hsv,
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (hsv->h == 1.0)
|
hue = hsv->h;
|
||||||
hsv->h = 0.0;
|
|
||||||
|
|
||||||
hsv->h *= 6.0;
|
if (hue == 1.0)
|
||||||
|
hue = 0.0;
|
||||||
|
|
||||||
i = (gint) hsv->h;
|
hue *= 6.0;
|
||||||
f = hsv->h - i;
|
|
||||||
|
i = (gint) hue;
|
||||||
|
f = hue - i;
|
||||||
w = hsv->v * (1.0 - hsv->s);
|
w = hsv->v * (1.0 - hsv->s);
|
||||||
q = hsv->v * (1.0 - (hsv->s * f));
|
q = hsv->v * (1.0 - (hsv->s * f));
|
||||||
t = hsv->v * (1.0 - (hsv->s * (1.0 - f)));
|
t = hsv->v * (1.0 - (hsv->s * (1.0 - f)));
|
||||||
|
@ -148,7 +158,7 @@ gimp_hsv_to_rgb (GimpHSV *hsv,
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
gimp_rgb_to_hsl (GimpRGB *rgb,
|
gimp_rgb_to_hsl (const GimpRGB *rgb,
|
||||||
gdouble *hue,
|
gdouble *hue,
|
||||||
gdouble *saturation,
|
gdouble *saturation,
|
||||||
gdouble *lightness)
|
gdouble *lightness)
|
||||||
|
@ -179,6 +189,9 @@ gimp_rgb_to_hsl (GimpRGB *rgb,
|
||||||
|
|
||||||
delta = max - min;
|
delta = max - min;
|
||||||
|
|
||||||
|
if (delta == 0.0)
|
||||||
|
delta = 1.0;
|
||||||
|
|
||||||
if (rgb->r == max)
|
if (rgb->r == max)
|
||||||
{
|
{
|
||||||
*hue = (rgb->g - rgb->b) / delta;
|
*hue = (rgb->g - rgb->b) / delta;
|
||||||
|
@ -260,7 +273,7 @@ gimp_hsl_to_rgb (gdouble hue,
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
|
|
||||||
void
|
void
|
||||||
gimp_rgb_to_hwb (GimpRGB *rgb,
|
gimp_rgb_to_hwb (const GimpRGB *rgb,
|
||||||
gdouble *hue,
|
gdouble *hue,
|
||||||
gdouble *whiteness,
|
gdouble *whiteness,
|
||||||
gdouble *blackness)
|
gdouble *blackness)
|
||||||
|
@ -655,6 +668,9 @@ gimp_rgb_to_hsv_double (gdouble *red,
|
||||||
{
|
{
|
||||||
delta = max - min;
|
delta = max - min;
|
||||||
|
|
||||||
|
if (delta == 0.0)
|
||||||
|
delta = 1.0;
|
||||||
|
|
||||||
if (r == max)
|
if (r == max)
|
||||||
h = (g - b) / delta;
|
h = (g - b) / delta;
|
||||||
else if (g == max)
|
else if (g == max)
|
||||||
|
@ -785,6 +801,9 @@ gimp_rgb_to_hsv4 (guchar *rgb,
|
||||||
{
|
{
|
||||||
delta = max - min;
|
delta = max - min;
|
||||||
|
|
||||||
|
if (delta == 0.0)
|
||||||
|
delta = 1.0;
|
||||||
|
|
||||||
if (red == max)
|
if (red == max)
|
||||||
h = (green - blue) / delta;
|
h = (green - blue) / delta;
|
||||||
else if (green == max)
|
else if (green == max)
|
||||||
|
|
|
@ -32,18 +32,15 @@ extern "C" {
|
||||||
|
|
||||||
/* GimpRGB function */
|
/* GimpRGB function */
|
||||||
|
|
||||||
#define GIMP_HSV_UNDEFINED -1.0
|
void gimp_rgb_to_hsv (const GimpRGB *rgb,
|
||||||
#define GIMP_HSL_UNDEFINED -1.0
|
|
||||||
|
|
||||||
void gimp_rgb_to_hsv (GimpRGB *rgb,
|
|
||||||
GimpHSV *hsv);
|
GimpHSV *hsv);
|
||||||
|
|
||||||
void gimp_rgb_to_hsl (GimpRGB *rgb,
|
void gimp_rgb_to_hsl (const GimpRGB *rgb,
|
||||||
gdouble *hue,
|
gdouble *hue,
|
||||||
gdouble *saturation,
|
gdouble *saturation,
|
||||||
gdouble *lightness);
|
gdouble *lightness);
|
||||||
|
|
||||||
void gimp_hsv_to_rgb (GimpHSV *hsv,
|
void gimp_hsv_to_rgb (const GimpHSV *hsv,
|
||||||
GimpRGB *rgb);
|
GimpRGB *rgb);
|
||||||
|
|
||||||
void gimp_hsl_to_rgb (gdouble hue,
|
void gimp_hsl_to_rgb (gdouble hue,
|
||||||
|
@ -51,7 +48,7 @@ void gimp_hsl_to_rgb (gdouble hue,
|
||||||
gdouble lightness,
|
gdouble lightness,
|
||||||
GimpRGB *rgb);
|
GimpRGB *rgb);
|
||||||
|
|
||||||
void gimp_rgb_to_hwb (GimpRGB *rgb,
|
void gimp_rgb_to_hwb (const GimpRGB *rgb,
|
||||||
gdouble *hue,
|
gdouble *hue,
|
||||||
gdouble *whiteness,
|
gdouble *whiteness,
|
||||||
gdouble *blackness);
|
gdouble *blackness);
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "session.h"
|
#include "session.h"
|
||||||
#include "color_area.h"
|
#include "color_area.h"
|
||||||
|
|
||||||
|
#include "libgimp/gimpcolorspace.h"
|
||||||
#include "libgimp/gimpcolorselector.h"
|
#include "libgimp/gimpcolorselector.h"
|
||||||
#include "libgimp/gimphelpui.h"
|
#include "libgimp/gimphelpui.h"
|
||||||
|
|
||||||
|
@ -82,13 +83,8 @@ typedef enum
|
||||||
UPDATE_CALLER = 1 << 6
|
UPDATE_CALLER = 1 << 6
|
||||||
} ColorSelectUpdateType;
|
} ColorSelectUpdateType;
|
||||||
|
|
||||||
typedef void (* ColorSelectCallback) (gint h,
|
typedef void (* ColorSelectCallback) (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gpointer data);
|
gpointer data);
|
||||||
|
|
||||||
typedef struct _ColorSelect ColorSelect;
|
typedef struct _ColorSelect ColorSelect;
|
||||||
|
@ -99,7 +95,10 @@ struct _ColorSelect
|
||||||
GtkWidget *z_color;
|
GtkWidget *z_color;
|
||||||
|
|
||||||
gint pos[3];
|
gint pos[3];
|
||||||
gint values[7];
|
|
||||||
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gint z_color_fill;
|
gint z_color_fill;
|
||||||
gint xy_color_fill;
|
gint xy_color_fill;
|
||||||
GdkGC *gc;
|
GdkGC *gc;
|
||||||
|
@ -118,28 +117,26 @@ struct _ColorSelectFill
|
||||||
gint y;
|
gint y;
|
||||||
gint width;
|
gint width;
|
||||||
gint height;
|
gint height;
|
||||||
gint *values;
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
ColorSelectFillUpdateProc update;
|
ColorSelectFillUpdateProc update;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static GtkWidget * color_select_widget_new (ColorSelect *,
|
static GtkWidget * color_select_widget_new (ColorSelect *csp,
|
||||||
gint ,
|
const GimpRGB *color);
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint );
|
|
||||||
|
|
||||||
static void color_select_drop_color (GtkWidget *widget,
|
static void color_select_drop_color (GtkWidget *widget,
|
||||||
GimpRGB *color,
|
GimpRGB *color,
|
||||||
gpointer data);
|
gpointer data);
|
||||||
static void color_select_update (ColorSelect *,
|
static void color_select_update (ColorSelect *csp,
|
||||||
ColorSelectUpdateType);
|
ColorSelectUpdateType);
|
||||||
static void color_select_update_caller (ColorSelect *);
|
static void color_select_update_caller (ColorSelect *csp);
|
||||||
static void color_select_update_values (ColorSelect *);
|
static void color_select_update_values (ColorSelect *csp);
|
||||||
static void color_select_update_rgb_values (ColorSelect *);
|
static void color_select_update_rgb_values (ColorSelect *csp);
|
||||||
static void color_select_update_hsv_values (ColorSelect *);
|
static void color_select_update_hsv_values (ColorSelect *csp);
|
||||||
static void color_select_update_pos (ColorSelect *);
|
static void color_select_update_pos (ColorSelect *csp);
|
||||||
|
|
||||||
static gint color_select_xy_expose (GtkWidget *widget,
|
static gint color_select_xy_expose (GtkWidget *widget,
|
||||||
GdkEventExpose *eevent,
|
GdkEventExpose *eevent,
|
||||||
|
@ -156,55 +153,41 @@ static gint color_select_z_events (GtkWidget *widet,
|
||||||
|
|
||||||
static void color_select_image_fill (GtkWidget *,
|
static void color_select_image_fill (GtkWidget *,
|
||||||
ColorSelectFillType,
|
ColorSelectFillType,
|
||||||
gint *);
|
const GimpHSV *hsv,
|
||||||
|
const GimpRGB *rgb);
|
||||||
|
|
||||||
static void color_select_draw_z_marker (ColorSelect *,
|
static void color_select_draw_z_marker (ColorSelect *csp,
|
||||||
GdkRectangle *);
|
GdkRectangle *);
|
||||||
static void color_select_draw_xy_marker (ColorSelect *,
|
static void color_select_draw_xy_marker (ColorSelect *csp,
|
||||||
GdkRectangle *);
|
GdkRectangle *);
|
||||||
|
|
||||||
static void color_select_update_red (ColorSelectFill *);
|
static void color_select_update_red (ColorSelectFill *csf);
|
||||||
static void color_select_update_green (ColorSelectFill *);
|
static void color_select_update_green (ColorSelectFill *csf);
|
||||||
static void color_select_update_blue (ColorSelectFill *);
|
static void color_select_update_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue (ColorSelectFill *);
|
static void color_select_update_hue (ColorSelectFill *csf);
|
||||||
static void color_select_update_saturation (ColorSelectFill *);
|
static void color_select_update_saturation (ColorSelectFill *csf);
|
||||||
static void color_select_update_value (ColorSelectFill *);
|
static void color_select_update_value (ColorSelectFill *csf);
|
||||||
static void color_select_update_red_green (ColorSelectFill *);
|
static void color_select_update_red_green (ColorSelectFill *csf);
|
||||||
static void color_select_update_red_blue (ColorSelectFill *);
|
static void color_select_update_red_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_green_blue (ColorSelectFill *);
|
static void color_select_update_green_blue (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue_saturation (ColorSelectFill *);
|
static void color_select_update_hue_saturation (ColorSelectFill *csf);
|
||||||
static void color_select_update_hue_value (ColorSelectFill *);
|
static void color_select_update_hue_value (ColorSelectFill *csf);
|
||||||
static void color_select_update_saturation_value (ColorSelectFill *);
|
static void color_select_update_saturation_value (ColorSelectFill *csf);
|
||||||
|
|
||||||
static GtkWidget * color_select_notebook_new (gint ,
|
static GtkWidget * color_select_notebook_new (const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb,
|
||||||
gint ,
|
gboolean show_alpha,
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gboolean ,
|
|
||||||
GimpColorSelectorCallback,
|
GimpColorSelectorCallback,
|
||||||
gpointer ,
|
gpointer ,
|
||||||
gpointer *);
|
gpointer *);
|
||||||
static void color_select_notebook_free (gpointer );
|
static void color_select_notebook_free (gpointer );
|
||||||
static void color_select_notebook_set_color (gpointer ,
|
static void color_select_notebook_set_color (gpointer ,
|
||||||
gint ,
|
const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb);
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint );
|
|
||||||
static void color_select_notebook_set_channel (gpointer ,
|
static void color_select_notebook_set_channel (gpointer ,
|
||||||
GimpColorSelectorChannelType channel);
|
GimpColorSelectorChannelType channel);
|
||||||
static void color_select_notebook_update_callback (gint ,
|
static void color_select_notebook_update_callback (const GimpHSV *hsv,
|
||||||
gint ,
|
const GimpRGB *rgb,
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gint ,
|
|
||||||
gpointer );
|
gpointer );
|
||||||
|
|
||||||
/* Static variables */
|
/* Static variables */
|
||||||
|
@ -252,10 +235,7 @@ color_select_init (void)
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
color_select_widget_new (ColorSelect *csp,
|
color_select_widget_new (ColorSelect *csp,
|
||||||
gint r,
|
const GimpRGB *color)
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
GtkWidget *main_vbox;
|
GtkWidget *main_vbox;
|
||||||
GtkWidget *main_hbox;
|
GtkWidget *main_hbox;
|
||||||
|
@ -330,16 +310,10 @@ color_select_drop_color (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorSelect *csp;
|
ColorSelect *csp;
|
||||||
guchar r, g, b, a;
|
|
||||||
|
|
||||||
csp = (ColorSelect *) data;
|
csp = (ColorSelect *) data;
|
||||||
|
|
||||||
gimp_rgba_get_uchar (color, &r, &g, &b, &a);
|
csp->rgb = *color;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_RED] = (gint) r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = (gint) g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = (gint) b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = (gint) a;
|
|
||||||
|
|
||||||
color_select_update_hsv_values (csp);
|
color_select_update_hsv_values (csp);
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
@ -352,24 +326,14 @@ color_select_drop_color (GtkWidget *widget,
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_set_color (ColorSelect *csp,
|
color_select_set_color (ColorSelect *csp,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
csp->hsv = *hsv;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s;
|
csp->rgb = *rgb;
|
||||||
csp->values[COLOR_SELECT_VALUE] = v;
|
|
||||||
csp->values[COLOR_SELECT_RED] = r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = a;
|
|
||||||
|
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
|
||||||
|
@ -394,13 +358,15 @@ color_select_update (ColorSelect *csp,
|
||||||
|
|
||||||
if (update & UPDATE_XY_COLOR)
|
if (update & UPDATE_XY_COLOR)
|
||||||
{
|
{
|
||||||
color_select_image_fill (csp->xy_color, csp->xy_color_fill, csp->values);
|
color_select_image_fill (csp->xy_color, csp->xy_color_fill,
|
||||||
|
&csp->hsv, &csp->rgb);
|
||||||
gtk_widget_draw (csp->xy_color, NULL);
|
gtk_widget_draw (csp->xy_color, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (update & UPDATE_Z_COLOR)
|
if (update & UPDATE_Z_COLOR)
|
||||||
{
|
{
|
||||||
color_select_image_fill (csp->z_color, csp->z_color_fill, csp->values);
|
color_select_image_fill (csp->z_color, csp->z_color_fill,
|
||||||
|
&csp->hsv, &csp->rgb);
|
||||||
gtk_widget_draw (csp->z_color, NULL);
|
gtk_widget_draw (csp->z_color, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -413,13 +379,8 @@ color_select_update_caller (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
if (csp && csp->callback)
|
if (csp && csp->callback)
|
||||||
{
|
{
|
||||||
(* csp->callback) (csp->values[COLOR_SELECT_HUE],
|
(* csp->callback) (&csp->hsv,
|
||||||
csp->values[COLOR_SELECT_SATURATION],
|
&csp->rgb,
|
||||||
csp->values[COLOR_SELECT_VALUE],
|
|
||||||
csp->values[COLOR_SELECT_RED],
|
|
||||||
csp->values[COLOR_SELECT_GREEN],
|
|
||||||
csp->values[COLOR_SELECT_BLUE],
|
|
||||||
csp->values[COLOR_SELECT_ALPHA],
|
|
||||||
csp->client_data);
|
csp->client_data);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -433,34 +394,35 @@ color_select_update_values (ColorSelect *csp)
|
||||||
switch (csp->z_color_fill)
|
switch (csp->z_color_fill)
|
||||||
{
|
{
|
||||||
case COLOR_SELECT_RED:
|
case COLOR_SELECT_RED:
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[0];
|
csp->rgb.b = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[1];
|
csp->rgb.g = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[2];
|
csp->rgb.r = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_GREEN:
|
case COLOR_SELECT_GREEN:
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[0];
|
csp->rgb.b = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[1];
|
csp->rgb.r = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[2];
|
csp->rgb.g = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
csp->values[COLOR_SELECT_GREEN] = csp->pos[0];
|
csp->rgb.g = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_RED] = csp->pos[1];
|
csp->rgb.r = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_BLUE] = csp->pos[2];
|
csp->rgb.b = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[0] * 100 / 255;
|
csp->hsv.v = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[1] * 100 / 255;
|
csp->hsv.s = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[2] * 360 / 255;
|
csp->hsv.h = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[0] * 100 / 255;
|
csp->hsv.v = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[1] * 360 / 255;
|
csp->hsv.h = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[2] * 100 / 255;
|
csp->hsv.s = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
csp->values[COLOR_SELECT_SATURATION] = csp->pos[0] * 100 / 255;
|
csp->hsv.s = csp->pos[0] / 255.0;
|
||||||
csp->values[COLOR_SELECT_HUE] = csp->pos[1] * 360 / 255;
|
csp->hsv.h = csp->pos[1] / 255.0;
|
||||||
csp->values[COLOR_SELECT_VALUE] = csp->pos[2] * 100 / 255;
|
csp->hsv.v = csp->pos[2] / 255.0;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -471,6 +433,7 @@ color_select_update_values (ColorSelect *csp)
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
color_select_update_hsv_values (csp);
|
color_select_update_hsv_values (csp);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
|
@ -482,139 +445,19 @@ color_select_update_values (ColorSelect *csp)
|
||||||
static void
|
static void
|
||||||
color_select_update_rgb_values (ColorSelect *csp)
|
color_select_update_rgb_values (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
gfloat h, s, v;
|
|
||||||
gfloat f, p, q, t;
|
|
||||||
|
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
h = csp->values[COLOR_SELECT_HUE];
|
gimp_hsv_to_rgb (&csp->hsv, &csp->rgb);
|
||||||
s = csp->values[COLOR_SELECT_SATURATION] / 100.0;
|
|
||||||
v = csp->values[COLOR_SELECT_VALUE] / 100.0;
|
|
||||||
|
|
||||||
if (s == 0)
|
|
||||||
{
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (h == 360)
|
|
||||||
h = 0;
|
|
||||||
|
|
||||||
h /= 60;
|
|
||||||
f = h - (int) h;
|
|
||||||
p = v * (1 - s);
|
|
||||||
q = v * (1 - (s * f));
|
|
||||||
t = v * (1 - (s * (1 - f)));
|
|
||||||
|
|
||||||
switch ((gint) h)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = t * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = p * 255;
|
|
||||||
break;
|
|
||||||
case 1:
|
|
||||||
csp->values[COLOR_SELECT_RED] = q * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = p * 255;
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
csp->values[COLOR_SELECT_RED] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = t * 255;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
csp->values[COLOR_SELECT_RED] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = q * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
csp->values[COLOR_SELECT_RED] = t * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = v * 255;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
csp->values[COLOR_SELECT_RED] = v * 255;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = p * 255;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = q * 255;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_update_hsv_values (ColorSelect *csp)
|
color_select_update_hsv_values (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
gint r, g, b;
|
|
||||||
gfloat h, s, v;
|
|
||||||
gint min, max;
|
|
||||||
gint delta;
|
|
||||||
|
|
||||||
if (! csp)
|
if (! csp)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
r = csp->values[COLOR_SELECT_RED];
|
gimp_rgb_to_hsv (&csp->rgb, &csp->hsv);
|
||||||
g = csp->values[COLOR_SELECT_GREEN];
|
|
||||||
b = csp->values[COLOR_SELECT_BLUE];
|
|
||||||
|
|
||||||
if (r > g)
|
|
||||||
{
|
|
||||||
if (r > b)
|
|
||||||
max = r;
|
|
||||||
else
|
|
||||||
max = b;
|
|
||||||
|
|
||||||
if (g < b)
|
|
||||||
min = g;
|
|
||||||
else
|
|
||||||
min = b;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (g > b)
|
|
||||||
max = g;
|
|
||||||
else
|
|
||||||
max = b;
|
|
||||||
|
|
||||||
if (r < b)
|
|
||||||
min = r;
|
|
||||||
else
|
|
||||||
min = b;
|
|
||||||
}
|
|
||||||
|
|
||||||
v = max;
|
|
||||||
|
|
||||||
if (max != 0)
|
|
||||||
s = (max - min) / (float) max;
|
|
||||||
else
|
|
||||||
s = 0;
|
|
||||||
|
|
||||||
if (s == 0)
|
|
||||||
{
|
|
||||||
h = 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
h = 0;
|
|
||||||
delta = max - min;
|
|
||||||
if (r == max)
|
|
||||||
h = (g - b) / (float) delta;
|
|
||||||
else if (g == max)
|
|
||||||
h = 2 + (b - r) / (float) delta;
|
|
||||||
else if (b == max)
|
|
||||||
h = 4 + (r - g) / (float) delta;
|
|
||||||
h *= 60;
|
|
||||||
|
|
||||||
if (h < 0)
|
|
||||||
h += 360;
|
|
||||||
}
|
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s * 100;
|
|
||||||
csp->values[COLOR_SELECT_VALUE] = v * 100 / 255;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -626,34 +469,35 @@ color_select_update_pos (ColorSelect *csp)
|
||||||
switch (csp->z_color_fill)
|
switch (csp->z_color_fill)
|
||||||
{
|
{
|
||||||
case COLOR_SELECT_RED:
|
case COLOR_SELECT_RED:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[0] = (gint) (csp->rgb.b * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[1] = (gint) (csp->rgb.g * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_RED];
|
csp->pos[2] = (gint) (csp->rgb.r * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_GREEN:
|
case COLOR_SELECT_GREEN:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[0] = (gint) (csp->rgb.b * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_RED];
|
csp->pos[1] = (gint) (csp->rgb.r * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[2] = (gint) (csp->rgb.g * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_BLUE:
|
case COLOR_SELECT_BLUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_GREEN];
|
csp->pos[0] = (gint) (csp->rgb.g * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_RED];
|
csp->pos[1] = (gint) (csp->rgb.r * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_BLUE];
|
csp->pos[2] = (gint) (csp->rgb.b * 255.999);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case COLOR_SELECT_HUE:
|
case COLOR_SELECT_HUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.v * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[1] = (gint) (csp->hsv.s * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[2] = (gint) (csp->hsv.h * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_SATURATION:
|
case COLOR_SELECT_SATURATION:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.v * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[1] = (gint) (csp->hsv.h * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[2] = (gint) (csp->hsv.s * 255.999);
|
||||||
break;
|
break;
|
||||||
case COLOR_SELECT_VALUE:
|
case COLOR_SELECT_VALUE:
|
||||||
csp->pos[0] = csp->values[COLOR_SELECT_SATURATION] * 255 / 100;
|
csp->pos[0] = (gint) (csp->hsv.s * 255.999);
|
||||||
csp->pos[1] = csp->values[COLOR_SELECT_HUE] * 255 / 360;
|
csp->pos[1] = (gint) (csp->hsv.h * 255.999);
|
||||||
csp->pos[2] = csp->values[COLOR_SELECT_VALUE] * 255 / 100;
|
csp->pos[2] = (gint) (csp->hsv.v * 255.999);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -795,10 +639,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
gdk_pointer_grab (csp->z_color->window, FALSE,
|
gdk_pointer_grab (csp->z_color->window, FALSE,
|
||||||
GDK_POINTER_MOTION_HINT_MASK |
|
GDK_POINTER_MOTION_HINT_MASK |
|
||||||
|
@ -815,10 +657,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (bevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
gdk_pointer_ungrab (bevent->time);
|
gdk_pointer_ungrab (bevent->time);
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
@ -837,10 +677,8 @@ color_select_z_events (GtkWidget *widget,
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
|
|
||||||
csp->pos[2] = 255 - (mevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
csp->pos[2] = 255 - (mevent->y * 255) / (Z_DEF_HEIGHT - 1);
|
||||||
if (csp->pos[2] < 0)
|
|
||||||
csp->pos[2] = 0;
|
csp->pos[2] = CLAMP (csp->pos[2], 0, 255);
|
||||||
if (csp->pos[2] > 255)
|
|
||||||
csp->pos[2] = 255;
|
|
||||||
|
|
||||||
color_select_draw_z_marker (csp, NULL);
|
color_select_draw_z_marker (csp, NULL);
|
||||||
color_select_update (csp, UPDATE_VALUES | UPDATE_CALLER);
|
color_select_update (csp, UPDATE_VALUES | UPDATE_CALLER);
|
||||||
|
@ -897,7 +735,8 @@ color_select_set_channel (ColorSelect *csp,
|
||||||
static void
|
static void
|
||||||
color_select_image_fill (GtkWidget *preview,
|
color_select_image_fill (GtkWidget *preview,
|
||||||
ColorSelectFillType type,
|
ColorSelectFillType type,
|
||||||
gint *values)
|
const GimpHSV *hsv,
|
||||||
|
const GimpRGB *rgb)
|
||||||
{
|
{
|
||||||
ColorSelectFill csf;
|
ColorSelectFill csf;
|
||||||
gint height;
|
gint height;
|
||||||
|
@ -909,7 +748,8 @@ color_select_image_fill (GtkWidget *preview,
|
||||||
csf.y = -1;
|
csf.y = -1;
|
||||||
csf.width = preview->requisition.width;
|
csf.width = preview->requisition.width;
|
||||||
csf.height = preview->requisition.height;
|
csf.height = preview->requisition.height;
|
||||||
csf.values = values;
|
csf.hsv = *hsv;
|
||||||
|
csf.rgb = *rgb;
|
||||||
|
|
||||||
height = csf.height;
|
height = csf.height;
|
||||||
if (height > 0)
|
if (height > 0)
|
||||||
|
@ -1085,14 +925,9 @@ color_select_update_hue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
h = csf->y * 360 / csf->height;
|
h = csf->y * 360.0 / csf->height;
|
||||||
|
|
||||||
h = 360 - h;
|
h = CLAMP (360 - h, 0, 360);
|
||||||
|
|
||||||
if (h < 0)
|
|
||||||
h = 0;
|
|
||||||
if (h >= 360)
|
|
||||||
h = 0;
|
|
||||||
|
|
||||||
h /= 60;
|
h /= 60;
|
||||||
f = (h - (int) h) * 255;
|
f = (h - (int) h) * 255;
|
||||||
|
@ -1205,7 +1040,7 @@ color_select_update_red_green (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
b = csf->values[COLOR_SELECT_BLUE];
|
b = (gint) (csf->rgb.b * 255.999);
|
||||||
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
|
@ -1236,7 +1071,7 @@ color_select_update_red_blue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
g = csf->values[COLOR_SELECT_GREEN];
|
g = (gint) (csf->rgb.g * 255.999);
|
||||||
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
r = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
|
@ -1267,7 +1102,7 @@ color_select_update_green_blue (ColorSelectFill *csf)
|
||||||
p = csf->buffer;
|
p = csf->buffer;
|
||||||
|
|
||||||
csf->y += 1;
|
csf->y += 1;
|
||||||
r = csf->values[COLOR_SELECT_RED];
|
r = (gint) (csf->rgb.r * 255.999);
|
||||||
g = (csf->height - csf->y + 1) * 255 / csf->height;
|
g = (csf->height - csf->y + 1) * 255 / csf->height;
|
||||||
|
|
||||||
if (g < 0)
|
if (g < 0)
|
||||||
|
@ -1312,7 +1147,7 @@ color_select_update_hue_saturation (ColorSelectFill *csf)
|
||||||
s = 0;
|
s = 0;
|
||||||
ds = 1.0 / csf->width;
|
ds = 1.0 / csf->width;
|
||||||
|
|
||||||
v = csf->values[COLOR_SELECT_VALUE] / 100.0;
|
v = csf->hsv.v;
|
||||||
|
|
||||||
switch ((int) h)
|
switch ((int) h)
|
||||||
{
|
{
|
||||||
|
@ -1403,7 +1238,7 @@ color_select_update_hue_value (ColorSelectFill *csf)
|
||||||
v = 0;
|
v = 0;
|
||||||
dv = 1.0 / csf->width;
|
dv = 1.0 / csf->width;
|
||||||
|
|
||||||
s = csf->values[COLOR_SELECT_SATURATION] / 100.0;
|
s = csf->hsv.s;
|
||||||
|
|
||||||
switch ((int) h)
|
switch ((int) h)
|
||||||
{
|
{
|
||||||
|
@ -1490,7 +1325,7 @@ color_select_update_saturation_value (ColorSelectFill *csf)
|
||||||
|
|
||||||
s = 1 - s;
|
s = 1 - s;
|
||||||
|
|
||||||
h = (gfloat) csf->values[COLOR_SELECT_HUE];
|
h = (gfloat) csf->hsv.h * 360.0;
|
||||||
if (h >= 360)
|
if (h >= 360)
|
||||||
h -= 360;
|
h -= 360;
|
||||||
h /= 60;
|
h /= 60;
|
||||||
|
@ -1577,13 +1412,8 @@ typedef struct
|
||||||
} notebook_glue;
|
} notebook_glue;
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
color_select_notebook_new (gint h,
|
color_select_notebook_new (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
@ -1607,20 +1437,14 @@ color_select_notebook_new (gint h,
|
||||||
csp->xy_color_fill = COLOR_SELECT_SATURATION_VALUE;
|
csp->xy_color_fill = COLOR_SELECT_SATURATION_VALUE;
|
||||||
csp->gc = NULL;
|
csp->gc = NULL;
|
||||||
|
|
||||||
csp->values[COLOR_SELECT_HUE] = h;
|
csp->hsv = *hsv;
|
||||||
csp->values[COLOR_SELECT_SATURATION] = s;
|
csp->rgb = *rgb;
|
||||||
csp->values[COLOR_SELECT_VALUE] = v;
|
|
||||||
csp->values[COLOR_SELECT_RED] = r;
|
|
||||||
csp->values[COLOR_SELECT_GREEN] = g;
|
|
||||||
csp->values[COLOR_SELECT_BLUE] = b;
|
|
||||||
csp->values[COLOR_SELECT_ALPHA] = a;
|
|
||||||
|
|
||||||
color_select_update_pos (csp);
|
color_select_update_pos (csp);
|
||||||
|
|
||||||
glue->main_vbox = color_select_widget_new (csp, r, g, b, a);
|
glue->main_vbox = color_select_widget_new (csp, rgb);
|
||||||
|
|
||||||
color_select_image_fill (csp->z_color, csp->z_color_fill, csp->values);
|
color_select_update (csp, UPDATE_XY_COLOR | UPDATE_Z_COLOR);
|
||||||
color_select_image_fill (csp->xy_color, csp->xy_color_fill, csp->values);
|
|
||||||
|
|
||||||
*selector_data = glue;
|
*selector_data = glue;
|
||||||
|
|
||||||
|
@ -1642,20 +1466,14 @@ color_select_notebook_free (gpointer data)
|
||||||
g_free (glue);
|
g_free (glue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_notebook_set_color (gpointer data,
|
color_select_notebook_set_color (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
notebook_glue *glue = data;
|
notebook_glue *glue = data;
|
||||||
|
|
||||||
color_select_set_color (glue->csp, h, s, v, r, g, b, a);
|
color_select_set_color (glue->csp, hsv, rgb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -1668,16 +1486,11 @@ color_select_notebook_set_channel (gpointer data,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
color_select_notebook_update_callback (gint h,
|
color_select_notebook_update_callback (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
notebook_glue *glue = data;
|
notebook_glue *glue = data;
|
||||||
|
|
||||||
glue->callback (glue->client_data, h, s, v, r, g, b, a);
|
glue->callback (glue->client_data, hsv, rgb);
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,35 +26,25 @@
|
||||||
|
|
||||||
#include "gimpmodregister.h"
|
#include "gimpmodregister.h"
|
||||||
|
|
||||||
#include "libgimp/gimpcolorselector.h"
|
|
||||||
#include "libgimp/gimpcolor.h"
|
#include "libgimp/gimpcolor.h"
|
||||||
#include "libgimp/gimpcolorspace.h"
|
#include "libgimp/gimpcolorspace.h"
|
||||||
|
#include "libgimp/gimpcolorselector.h"
|
||||||
#include "libgimp/gimpmodule.h"
|
#include "libgimp/gimpmodule.h"
|
||||||
|
|
||||||
#include "libgimp/gimpintl.h"
|
#include "libgimp/gimpintl.h"
|
||||||
|
|
||||||
|
|
||||||
/* prototypes */
|
/* prototypes */
|
||||||
static GtkWidget * colorsel_gtk_new (gint h,
|
static GtkWidget * colorsel_gtk_new (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
gpointer *selector_data);
|
gpointer *selector_data);
|
||||||
static void colorsel_gtk_free (gpointer data);
|
static void colorsel_gtk_free (gpointer data);
|
||||||
static void colorsel_gtk_set_color (gpointer data,
|
static void colorsel_gtk_set_color (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb);
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a);
|
|
||||||
static void colorsel_gtk_set_channel (gpointer data,
|
static void colorsel_gtk_set_channel (gpointer data,
|
||||||
GimpColorSelectorChannelType channel);
|
GimpColorSelectorChannelType channel);
|
||||||
static void colorsel_gtk_update (GtkWidget *widget,
|
static void colorsel_gtk_update (GtkWidget *widget,
|
||||||
|
@ -136,13 +126,8 @@ typedef struct
|
||||||
|
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
colorsel_gtk_new (gint h,
|
colorsel_gtk_new (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer data,
|
gpointer data,
|
||||||
|
@ -164,7 +149,7 @@ colorsel_gtk_new (gint h,
|
||||||
|
|
||||||
gtk_widget_hide (GTK_COLOR_SELECTION (p->selector)->scales[0]->parent);
|
gtk_widget_hide (GTK_COLOR_SELECTION (p->selector)->scales[0]->parent);
|
||||||
|
|
||||||
colorsel_gtk_set_color (p, h, s, v, r, g, b, a);
|
colorsel_gtk_set_color (p, hsv, rgb);
|
||||||
|
|
||||||
/* EEK: to be removed */
|
/* EEK: to be removed */
|
||||||
gtk_signal_connect_object_after
|
gtk_signal_connect_object_after
|
||||||
|
@ -203,22 +188,17 @@ colorsel_gtk_free (gpointer data)
|
||||||
|
|
||||||
static void
|
static void
|
||||||
colorsel_gtk_set_color (gpointer data,
|
colorsel_gtk_set_color (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
ColorselGtk *p = data;
|
ColorselGtk *p = data;
|
||||||
|
|
||||||
gdouble color[4];
|
gdouble color[4];
|
||||||
|
|
||||||
color[0] = ((gdouble) r) / 255.999;
|
color[0] = rgb->r;
|
||||||
color[1] = ((gdouble) g) / 255.999;
|
color[1] = rgb->g;
|
||||||
color[2] = ((gdouble) b) / 255.999;
|
color[2] = rgb->b;
|
||||||
color[3] = ((gdouble) a) / 255.999;
|
color[3] = rgb->a;
|
||||||
|
|
||||||
gtk_color_selection_set_color (GTK_COLOR_SELECTION (p->selector), color);
|
gtk_color_selection_set_color (GTK_COLOR_SELECTION (p->selector), color);
|
||||||
}
|
}
|
||||||
|
@ -234,29 +214,20 @@ colorsel_gtk_update (GtkWidget *widget,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
ColorselGtk *p = data;
|
ColorselGtk *p = data;
|
||||||
gint h;
|
GimpHSV hsv;
|
||||||
gint s;
|
GimpRGB rgb;
|
||||||
gint v;
|
|
||||||
gint r;
|
|
||||||
gint g;
|
|
||||||
gint b;
|
|
||||||
gint a;
|
|
||||||
gdouble color[4];
|
gdouble color[4];
|
||||||
|
|
||||||
gtk_color_selection_get_color (GTK_COLOR_SELECTION (p->selector), color);
|
gtk_color_selection_get_color (GTK_COLOR_SELECTION (p->selector), color);
|
||||||
|
|
||||||
r = (gint) (color[0] * 255.999);
|
rgb.r = color[0];
|
||||||
g = (gint) (color[1] * 255.999);
|
rgb.g = color[1];
|
||||||
b = (gint) (color[2] * 255.999);
|
rgb.b = color[2];
|
||||||
a = (gint) (color[3] * 255.999);
|
rgb.a = color[3];
|
||||||
|
|
||||||
gimp_rgb_to_hsv_double (&color[0], &color[1], &color[2]);
|
gimp_rgb_to_hsv (&rgb, &hsv);
|
||||||
|
|
||||||
h = (gint) (color[0] * 360.999);
|
p->callback (p->client_data, &hsv, &rgb);
|
||||||
s = (gint) (color[1] * 255.999);
|
|
||||||
v = (gint) (color[2] * 255.999);
|
|
||||||
|
|
||||||
p->callback (p->client_data, h, v, s, r, g, b, a);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* EEK */
|
/* EEK */
|
||||||
|
|
|
@ -27,23 +27,18 @@
|
||||||
|
|
||||||
#include "gimpmodregister.h"
|
#include "gimpmodregister.h"
|
||||||
|
|
||||||
#include <libgimp/gimpcolorselector.h>
|
#include "libgimp/gimpcolor.h"
|
||||||
#include <libgimp/gimpcolor.h>
|
#include "libgimp/gimpcolorspace.h"
|
||||||
#include <libgimp/gimpcolorspace.h>
|
#include "libgimp/gimpcolorselector.h"
|
||||||
#include <libgimp/gimpmodule.h>
|
#include "libgimp/gimpmodule.h"
|
||||||
#include <libgimp/gimpmath.h>
|
#include "libgimp/gimpmath.h"
|
||||||
|
|
||||||
#include "libgimp/gimpintl.h"
|
#include "libgimp/gimpintl.h"
|
||||||
|
|
||||||
|
|
||||||
/* prototypes */
|
/* prototypes */
|
||||||
static GtkWidget * colorsel_triangle_new (gint hue,
|
static GtkWidget * colorsel_triangle_new (const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb,
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer callback_data,
|
gpointer callback_data,
|
||||||
|
@ -52,13 +47,8 @@ static GtkWidget * colorsel_triangle_new (gint hue,
|
||||||
static void colorsel_triangle_free (gpointer selector_data);
|
static void colorsel_triangle_free (gpointer selector_data);
|
||||||
|
|
||||||
static void colorsel_triangle_set_color (gpointer selector_data,
|
static void colorsel_triangle_set_color (gpointer selector_data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb);
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha);
|
|
||||||
static void colorsel_triangle_set_channel (gpointer selector_data,
|
static void colorsel_triangle_set_channel (gpointer selector_data,
|
||||||
GimpColorSelectorChannelType channel);
|
GimpColorSelectorChannelType channel);
|
||||||
|
|
||||||
|
@ -113,7 +103,9 @@ typedef enum
|
||||||
|
|
||||||
struct _ColorSelect
|
struct _ColorSelect
|
||||||
{
|
{
|
||||||
gint values[7];
|
GimpHSV hsv;
|
||||||
|
GimpRGB rgb;
|
||||||
|
|
||||||
gdouble oldsat;
|
gdouble oldsat;
|
||||||
gdouble oldval;
|
gdouble oldval;
|
||||||
gint mode;
|
gint mode;
|
||||||
|
@ -132,10 +124,6 @@ static void color_select_update_rgb_values (ColorSelect *coldata);
|
||||||
static void update_previews (ColorSelect *coldata,
|
static void update_previews (ColorSelect *coldata,
|
||||||
gboolean hue_changed);
|
gboolean hue_changed);
|
||||||
|
|
||||||
/*
|
|
||||||
static void color_select_update_hsv_values (ColorSelect *coldata);
|
|
||||||
*/
|
|
||||||
|
|
||||||
|
|
||||||
/*************************************************************/
|
/*************************************************************/
|
||||||
|
|
||||||
|
@ -179,13 +167,8 @@ module_unload (gpointer shutdown_data,
|
||||||
/* methods */
|
/* methods */
|
||||||
|
|
||||||
static GtkWidget *
|
static GtkWidget *
|
||||||
colorsel_triangle_new (gint hue,
|
colorsel_triangle_new (const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb,
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer callback_data,
|
gpointer callback_data,
|
||||||
|
@ -199,13 +182,9 @@ colorsel_triangle_new (gint hue,
|
||||||
GtkWidget *vbox;
|
GtkWidget *vbox;
|
||||||
|
|
||||||
coldata = g_new (ColorSelect, 1);
|
coldata = g_new (ColorSelect, 1);
|
||||||
coldata->values[HUE] = hue;
|
|
||||||
coldata->values[SATURATION] = saturation;
|
coldata->hsv = *hsv;
|
||||||
coldata->values[VALUE] = value;
|
coldata->rgb = *rgb;
|
||||||
coldata->values[RED] = red;
|
|
||||||
coldata->values[GREEN] = green;
|
|
||||||
coldata->values[BLUE] = blue;
|
|
||||||
coldata->values[ALPHA] = alpha;
|
|
||||||
|
|
||||||
coldata->oldsat = 0;
|
coldata->oldsat = 0;
|
||||||
coldata->oldval = 0;
|
coldata->oldval = 0;
|
||||||
|
@ -243,25 +222,15 @@ colorsel_triangle_free (gpointer selector_data)
|
||||||
|
|
||||||
static void
|
static void
|
||||||
colorsel_triangle_set_color (gpointer selector_data,
|
colorsel_triangle_set_color (gpointer selector_data,
|
||||||
gint hue,
|
const GimpHSV *hsv,
|
||||||
gint saturation,
|
const GimpRGB *rgb)
|
||||||
gint value,
|
|
||||||
gint red,
|
|
||||||
gint green,
|
|
||||||
gint blue,
|
|
||||||
gint alpha)
|
|
||||||
{
|
{
|
||||||
ColorSelect *coldata;
|
ColorSelect *coldata;
|
||||||
|
|
||||||
coldata = selector_data;
|
coldata = selector_data;
|
||||||
|
|
||||||
coldata->values[HUE] = hue;
|
coldata->hsv = *hsv;
|
||||||
coldata->values[SATURATION] = saturation;
|
coldata->rgb = *rgb;
|
||||||
coldata->values[VALUE] = value;
|
|
||||||
coldata->values[RED] = red;
|
|
||||||
coldata->values[GREEN] = green;
|
|
||||||
coldata->values[BLUE] = blue;
|
|
||||||
coldata->values[ALPHA] = alpha;
|
|
||||||
|
|
||||||
update_previews (coldata, TRUE);
|
update_previews (coldata, TRUE);
|
||||||
}
|
}
|
||||||
|
@ -278,33 +247,9 @@ colorsel_triangle_set_channel (gpointer selector_data,
|
||||||
static void
|
static void
|
||||||
color_select_update_rgb_values (ColorSelect *csp)
|
color_select_update_rgb_values (ColorSelect *csp)
|
||||||
{
|
{
|
||||||
csp->values[RED] = RINT (((gdouble) csp->values[HUE]) / 360.0 * 255);
|
gimp_hsv_to_rgb (&csp->hsv, &csp->rgb);
|
||||||
csp->values[GREEN] = RINT (((gdouble) csp->values[SATURATION]) / 100.0 * 255);
|
|
||||||
csp->values[BLUE] = RINT (((gdouble) csp->values[VALUE]) / 100.0 * 255);
|
|
||||||
|
|
||||||
gimp_hsv_to_rgb_int (&(csp->values[RED]),
|
|
||||||
&(csp->values[GREEN]),
|
|
||||||
&(csp->values[BLUE]));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
static void
|
|
||||||
color_select_update_hsv_values (ColorSelect *csp)
|
|
||||||
{
|
|
||||||
gdouble hue, sat, val;
|
|
||||||
|
|
||||||
hue = (gdouble) csp->values[RED] / 255;
|
|
||||||
sat = (gdouble) csp->values[GREEN] / 255;
|
|
||||||
val = (gdouble) csp->values[BLUE] / 255;
|
|
||||||
|
|
||||||
gimp_rgb_to_hsv_double (&hue, &sat, &val);
|
|
||||||
|
|
||||||
csp->values[HUE] = RINT (hue * 360);
|
|
||||||
csp->values[SATURATION] = RINT (sat * 100);
|
|
||||||
csp->values[VALUE] = RINT (val * 100);
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
update_previews (ColorSelect *coldata,
|
update_previews (ColorSelect *coldata,
|
||||||
gint hue_changed)
|
gint hue_changed)
|
||||||
|
@ -316,7 +261,7 @@ update_previews (ColorSelect *coldata,
|
||||||
gdouble hue, sat, val, s, v, atn;
|
gdouble hue, sat, val, s, v, atn;
|
||||||
gint hx,hy, sx,sy, vx,vy;
|
gint hx,hy, sx,sy, vx,vy;
|
||||||
|
|
||||||
hue = (gdouble) coldata->values[HUE] * G_PI / 180;
|
hue = (gdouble) coldata->hsv.h * 2 * G_PI;
|
||||||
|
|
||||||
hx = sin (hue) * COLORTRIANGLERADIUS;
|
hx = sin (hue) * COLORTRIANGLERADIUS;
|
||||||
hy = cos (hue) * COLORTRIANGLERADIUS;
|
hy = cos (hue) * COLORTRIANGLERADIUS;
|
||||||
|
@ -327,37 +272,54 @@ update_previews (ColorSelect *coldata,
|
||||||
vx = sin (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
vx = sin (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
||||||
vy = cos (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
vy = cos (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
||||||
|
|
||||||
hue = (gdouble) coldata->values[HUE];
|
hue = coldata->hsv.h * 360.0;
|
||||||
preview = coldata->preview;
|
preview = coldata->preview;
|
||||||
|
|
||||||
if (hue_changed) {
|
if (hue_changed)
|
||||||
for (y = COLORWHEELRADIUS; y > -COLORWHEELRADIUS; y--) {
|
{
|
||||||
|
for (y = COLORWHEELRADIUS; y > -COLORWHEELRADIUS; y--)
|
||||||
|
{
|
||||||
dx = RINT (sqrt (fabs ((COLORWHEELRADIUS) * (COLORWHEELRADIUS) - y * y)));
|
dx = RINT (sqrt (fabs ((COLORWHEELRADIUS) * (COLORWHEELRADIUS) - y * y)));
|
||||||
for (x = -dx, k = 0; x <= dx; x++) {
|
for (x = -dx, k = 0; x <= dx; x++)
|
||||||
|
{
|
||||||
buf[k] = buf[k+1] = buf[k+2] = BGCOLOR;
|
buf[k] = buf[k+1] = buf[k+2] = BGCOLOR;
|
||||||
r2 = (x * x) + (y * y);
|
r2 = (x * x) + (y * y);
|
||||||
if ( r2 <= COLORWHEELRADIUS * COLORWHEELRADIUS) {
|
|
||||||
if (r2 > COLORTRIANGLERADIUS * COLORTRIANGLERADIUS) {
|
if ( r2 <= COLORWHEELRADIUS * COLORWHEELRADIUS)
|
||||||
|
{
|
||||||
|
if (r2 > COLORTRIANGLERADIUS * COLORTRIANGLERADIUS)
|
||||||
|
{
|
||||||
atn = atan2 (x, y);
|
atn = atan2 (x, y);
|
||||||
if (atn < 0)
|
if (atn < 0)
|
||||||
atn = atn + 2 * G_PI;
|
atn = atn + 2 * G_PI;
|
||||||
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
||||||
} else {
|
}
|
||||||
val = (gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx)) /
|
else
|
||||||
|
{
|
||||||
|
val =
|
||||||
|
(gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx)) /
|
||||||
(gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
(gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
||||||
|
|
||||||
if (val >= 0 && val<= 1) { /* normally val>=0, but this results in
|
if (val >= 0 && val<= 1)
|
||||||
|
{
|
||||||
|
/* normally val>=0, but this results in
|
||||||
graphics errors... */
|
graphics errors... */
|
||||||
sat = (val == 0 ? 0: ((gdouble) (y - sy - val * (vy - sy)) /
|
|
||||||
|
sat =
|
||||||
|
(val == 0 ? 0: ((gdouble) (y - sy - val * (vy - sy)) /
|
||||||
(val * (gdouble) (hy - vy))));
|
(val * (gdouble) (hy - vy))));
|
||||||
|
|
||||||
if (sat >= 0 && sat <= 1)
|
if (sat >= 0 && sat <= 1)
|
||||||
gimp_hsv_to_rgb4 (buf + k, hue / 360, sat, val);
|
gimp_hsv_to_rgb4 (buf + k, hue / 360, sat, val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
k += 3;
|
k += 3;
|
||||||
}
|
}
|
||||||
gtk_preview_draw_row (GTK_PREVIEW (preview), buf, COLORWHEELRADIUS - dx,
|
|
||||||
|
gtk_preview_draw_row (GTK_PREVIEW (preview), buf,
|
||||||
|
COLORWHEELRADIUS - dx,
|
||||||
COLORWHEELRADIUS - y - 1, 2 * dx + 1);
|
COLORWHEELRADIUS - y - 1, 2 * dx + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -377,102 +339,148 @@ update_previews (ColorSelect *coldata,
|
||||||
|
|
||||||
col = INTENSITY (buf[0], buf[1], buf[2]) > 127 ? 0 : 255;
|
col = INTENSITY (buf[0], buf[1], buf[2]) > 127 ? 0 : 255;
|
||||||
|
|
||||||
for (y = y0 - 4 ; y <= y0 + 4 ; y++) {
|
for (y = y0 - 4 ; y <= y0 + 4 ; y++)
|
||||||
for (x = x0 - 4, k=0 ; x <= x0 + 4 ; x++) {
|
{
|
||||||
|
for (x = x0 - 4, k=0 ; x <= x0 + 4 ; x++)
|
||||||
|
{
|
||||||
r2 = (x - x0) * (x - x0) + (y - y0) * (y - y0);
|
r2 = (x - x0) * (x - x0) + (y - y0) * (y - y0);
|
||||||
if (r2 <= 20 && r2 >= 6) {
|
|
||||||
|
if (r2 <= 20 && r2 >= 6)
|
||||||
|
{
|
||||||
buf[k] = buf[k+1] = buf[k+2] = col;
|
buf[k] = buf[k+1] = buf[k+2] = col;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
atn = atan2 (x, y);
|
atn = atan2 (x, y);
|
||||||
if (atn < 0)
|
if (atn < 0)
|
||||||
atn = atn + 2 * G_PI;
|
atn = atn + 2 * G_PI;
|
||||||
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
k += 3;
|
k += 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_preview_draw_row (GTK_PREVIEW (preview), buf,
|
gtk_preview_draw_row (GTK_PREVIEW (preview), buf,
|
||||||
COLORWHEELRADIUS + x0-4,
|
COLORWHEELRADIUS + x0-4,
|
||||||
COLORWHEELRADIUS - 1 - y, 9);
|
COLORWHEELRADIUS - 1 - y, 9);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
} else {
|
{
|
||||||
/* delete marker in triangle */
|
/* delete marker in triangle */
|
||||||
|
|
||||||
s = coldata->oldsat;
|
s = coldata->oldsat;
|
||||||
v = coldata->oldval;
|
v = coldata->oldval;
|
||||||
x0 = RINT (sx + (vx - sx) * v + (hx - vx) * s * v);
|
x0 = RINT (sx + (vx - sx) * v + (hx - vx) * s * v);
|
||||||
y0 = RINT (sy + (vy - sy) * v + (hy - vy) * s * v);
|
y0 = RINT (sy + (vy - sy) * v + (hy - vy) * s * v);
|
||||||
for (y = y0 - 4 ; y <= y0 + 4 ; y++) {
|
|
||||||
for (x = x0 - 4, k=0 ; x <= x0 + 4 ; x++) {
|
for (y = y0 - 4 ; y <= y0 + 4 ; y++)
|
||||||
|
{
|
||||||
|
for (x = x0 - 4, k=0 ; x <= x0 + 4 ; x++)
|
||||||
|
{
|
||||||
buf[k] = buf[k+1] = buf[k+2] = BGCOLOR;
|
buf[k] = buf[k+1] = buf[k+2] = BGCOLOR;
|
||||||
r2 = (x - x0) * (x - x0) + (y - y0) * (y - y0);
|
r2 = (x - x0) * (x - x0) + (y - y0) * (y - y0);
|
||||||
if (x * x + y * y > COLORTRIANGLERADIUS * COLORTRIANGLERADIUS) {
|
|
||||||
|
if (x * x + y * y > COLORTRIANGLERADIUS * COLORTRIANGLERADIUS)
|
||||||
|
{
|
||||||
atn = atan2 (x, y);
|
atn = atan2 (x, y);
|
||||||
if (atn < 0)
|
if (atn < 0)
|
||||||
atn = atn + 2 * G_PI;
|
atn = atn + 2 * G_PI;
|
||||||
|
|
||||||
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
||||||
} else {
|
}
|
||||||
val = (gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx)) /
|
else
|
||||||
|
{
|
||||||
|
val =
|
||||||
|
(gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx)) /
|
||||||
(gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
(gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
||||||
if (val > 0 && val <= 1) { /* eigentlich val>=0, aber dann Grafikfehler... */
|
|
||||||
sat = (val == 0 ? 0 : ((gdouble) (y - sy - val * (vy - sy)) /
|
if (val > 0 && val <= 1)
|
||||||
|
{
|
||||||
|
/* eigentlich val>=0, aber dann Grafikfehler... */
|
||||||
|
|
||||||
|
sat =
|
||||||
|
(val == 0 ? 0 : ((gdouble) (y - sy - val * (vy - sy)) /
|
||||||
(val * (gdouble) (hy - vy))));
|
(val * (gdouble) (hy - vy))));
|
||||||
|
|
||||||
if (sat >= 0 && sat <= 1)
|
if (sat >= 0 && sat <= 1)
|
||||||
gimp_hsv_to_rgb4 (buf + k, hue / 360, sat, val);
|
gimp_hsv_to_rgb4 (buf + k, hue / 360, sat, val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
k += 3;
|
k += 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_preview_draw_row (GTK_PREVIEW (preview), buf,
|
gtk_preview_draw_row (GTK_PREVIEW (preview), buf,
|
||||||
COLORWHEELRADIUS + x0 - 4,
|
COLORWHEELRADIUS + x0 - 4,
|
||||||
COLORWHEELRADIUS - 1 - y, 9);
|
COLORWHEELRADIUS - 1 - y, 9);
|
||||||
}
|
}
|
||||||
|
|
||||||
coldata->oldsat = coldata->values[SATURATION] / 100.0;
|
coldata->oldsat = coldata->hsv.s;
|
||||||
coldata->oldval = coldata->values[VALUE] / 100.0;
|
coldata->oldval = coldata->hsv.v;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* marker in triangle */
|
/* marker in triangle */
|
||||||
|
|
||||||
col = INTENSITY (coldata->values[RED], coldata->values[GREEN],
|
col = gimp_rgb_intensity (&coldata->rgb) > 0.5 ? 0 : 255;
|
||||||
coldata->values[BLUE]) > 127 ? 0 : 255 ;
|
|
||||||
|
|
||||||
s = coldata->values[SATURATION] / 100.0;
|
s = coldata->hsv.s;
|
||||||
v = coldata->values[VALUE] / 100.0;
|
v = coldata->hsv.v;
|
||||||
coldata->oldsat = s;
|
coldata->oldsat = s;
|
||||||
coldata->oldval = v;
|
coldata->oldval = v;
|
||||||
|
|
||||||
x0 = RINT (sx + (vx - sx) * v + (hx - vx) * s * v);
|
x0 = RINT (sx + (vx - sx) * v + (hx - vx) * s * v);
|
||||||
y0 = RINT (sy + (vy - sy) * v + (hy - vy) * s * v);
|
y0 = RINT (sy + (vy - sy) * v + (hy - vy) * s * v);
|
||||||
for (y = y0 - 4 ; y <= y0 + 4 ; y++) {
|
|
||||||
for (x = x0 - 4, k=0 ; x <= x0 + 4 ; x++) {
|
for (y = y0 - 4 ; y <= y0 + 4 ; y++)
|
||||||
|
{
|
||||||
|
for (x = x0 - 4, k=0 ; x <= x0 + 4 ; x++)
|
||||||
|
{
|
||||||
buf[k] = buf[k+1] = buf[k+2] = BGCOLOR;
|
buf[k] = buf[k+1] = buf[k+2] = BGCOLOR;
|
||||||
r2 = (x - x0) * (x - x0) + (y - y0) * (y - y0);
|
r2 = (x - x0) * (x - x0) + (y - y0) * (y - y0);
|
||||||
if (r2 <= 20 && r2 >= 6) {
|
|
||||||
|
if (r2 <= 20 && r2 >= 6)
|
||||||
|
{
|
||||||
buf[k] = buf[k+1] = buf[k+2] = col;
|
buf[k] = buf[k+1] = buf[k+2] = col;
|
||||||
} else {
|
}
|
||||||
if (x * x + y * y > COLORTRIANGLERADIUS * COLORTRIANGLERADIUS) {
|
else
|
||||||
|
{
|
||||||
|
if (x * x + y * y > COLORTRIANGLERADIUS * COLORTRIANGLERADIUS)
|
||||||
|
{
|
||||||
atn = atan2 (x, y);
|
atn = atan2 (x, y);
|
||||||
|
|
||||||
if (atn < 0)
|
if (atn < 0)
|
||||||
atn = atn + 2 * G_PI;
|
atn = atn + 2 * G_PI;
|
||||||
|
|
||||||
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
gimp_hsv_to_rgb4 (buf + k, atn / (2 * G_PI), 1, 1);
|
||||||
} else {
|
}
|
||||||
val = (gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx)) /
|
else
|
||||||
|
{
|
||||||
|
val =
|
||||||
|
(gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx)) /
|
||||||
(gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
(gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
||||||
if (val > 0 && val <= 1) { /* eigentlich val>=0, aber dann Grafikfehler... */
|
if (val > 0 && val <= 1)
|
||||||
sat = (val == 0 ? 0 : ((gdouble) (y - sy - val * (vy - sy)) /
|
{
|
||||||
|
/* eigentlich val>=0, aber dann Grafikfehler... */
|
||||||
|
|
||||||
|
sat =
|
||||||
|
(val == 0 ? 0 : ((gdouble) (y - sy - val * (vy - sy)) /
|
||||||
(val * (gdouble) (hy - vy))));
|
(val * (gdouble) (hy - vy))));
|
||||||
|
|
||||||
if (sat >= 0 && sat <= 1)
|
if (sat >= 0 && sat <= 1)
|
||||||
gimp_hsv_to_rgb4 (buf + k, hue / 360, sat, val);
|
gimp_hsv_to_rgb4 (buf + k, hue / 360, sat, val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
k += 3;
|
k += 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_preview_draw_row (GTK_PREVIEW (preview), buf,
|
gtk_preview_draw_row (GTK_PREVIEW (preview), buf,
|
||||||
COLORWHEELRADIUS + x0 - 4,
|
COLORWHEELRADIUS + x0 - 4,
|
||||||
COLORWHEELRADIUS - 1 - y, 9);
|
COLORWHEELRADIUS - 1 - y, 9);
|
||||||
}
|
}
|
||||||
|
|
||||||
gtk_widget_draw (preview, NULL);
|
gtk_widget_draw (preview, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -493,7 +501,8 @@ color_selection_callback (GtkWidget *widget,
|
||||||
|
|
||||||
coldata = gtk_object_get_user_data (GTK_OBJECT (widget));
|
coldata = gtk_object_get_user_data (GTK_OBJECT (widget));
|
||||||
|
|
||||||
switch (event->type) {
|
switch (event->type)
|
||||||
|
{
|
||||||
case GDK_BUTTON_PRESS:
|
case GDK_BUTTON_PRESS:
|
||||||
gtk_grab_add (widget);
|
gtk_grab_add (widget);
|
||||||
x = event->button.x - COLORWHEELRADIUS - 1;
|
x = event->button.x - COLORWHEELRADIUS - 1;
|
||||||
|
@ -519,13 +528,8 @@ color_selection_callback (GtkWidget *widget,
|
||||||
|
|
||||||
/* callback the user */
|
/* callback the user */
|
||||||
(* coldata->callback) (coldata->data,
|
(* coldata->callback) (coldata->data,
|
||||||
coldata->values[HUE],
|
&coldata->hsv,
|
||||||
coldata->values[SATURATION],
|
&coldata->rgb);
|
||||||
coldata->values[VALUE],
|
|
||||||
coldata->values[RED],
|
|
||||||
coldata->values[GREEN],
|
|
||||||
coldata->values[BLUE],
|
|
||||||
coldata->values[ALPHA]);
|
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
break;
|
break;
|
||||||
|
@ -546,21 +550,26 @@ color_selection_callback (GtkWidget *widget,
|
||||||
|
|
||||||
if (coldata->mode == 1 ||
|
if (coldata->mode == 1 ||
|
||||||
(r > COLORWHEELRADIUS &&
|
(r > COLORWHEELRADIUS &&
|
||||||
(abs (angle - coldata->values[HUE]) < 30 ||
|
(abs (angle - coldata->hsv.h * 260.0) < 30 ||
|
||||||
abs (abs (angle - coldata->values[HUE]) - 360) < 30))) {
|
abs (abs (angle - coldata->hsv.h * 360.0) - 360) < 30)))
|
||||||
coldata->values[HUE] = angle;
|
{
|
||||||
|
coldata->hsv.h = angle / 360.0;
|
||||||
color_select_update_rgb_values (coldata);
|
color_select_update_rgb_values (coldata);
|
||||||
update_previews (coldata, TRUE);
|
update_previews (coldata, TRUE);
|
||||||
} else {
|
}
|
||||||
hue = (gdouble) coldata->values[HUE] * G_PI / 180;
|
else
|
||||||
|
{
|
||||||
|
hue = coldata->hsv.h * 2 * G_PI;
|
||||||
hx = sin (hue) * COLORTRIANGLERADIUS;
|
hx = sin (hue) * COLORTRIANGLERADIUS;
|
||||||
hy = cos (hue) * COLORTRIANGLERADIUS;
|
hy = cos (hue) * COLORTRIANGLERADIUS;
|
||||||
sx = sin (hue - 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
sx = sin (hue - 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
||||||
sy = cos (hue - 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
sy = cos (hue - 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
||||||
vx = sin (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
vx = sin (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
||||||
vy = cos (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
vy = cos (hue + 2 * G_PI / 3) * COLORTRIANGLERADIUS;
|
||||||
hue = (gdouble) coldata->values[HUE];
|
hue = coldata->hsv.h * 360.0;
|
||||||
if ((x - sx) * vx + (y - sy) * vy < 0) {
|
|
||||||
|
if ((x - sx) * vx + (y - sy) * vy < 0)
|
||||||
|
{
|
||||||
sat = 1;
|
sat = 1;
|
||||||
val = ((gdouble) ( (x - sx) * (hx - sx) + (y - sy) * (hy - sy)))
|
val = ((gdouble) ( (x - sx) * (hx - sx) + (y - sy) * (hy - sy)))
|
||||||
/ ((hx - sx) * (hx - sx) + (hy - sy) * (hy - sy));
|
/ ((hx - sx) * (hx - sx) + (hy - sy) * (hy - sy));
|
||||||
|
@ -568,8 +577,9 @@ color_selection_callback (GtkWidget *widget,
|
||||||
val = 0;
|
val = 0;
|
||||||
else if (val > 1)
|
else if (val > 1)
|
||||||
val = 1;
|
val = 1;
|
||||||
} else
|
}
|
||||||
if ((x - sx) * hx + (y - sy) * hy < 0) {
|
else if ((x - sx) * hx + (y - sy) * hy < 0)
|
||||||
|
{
|
||||||
sat = 0;
|
sat = 0;
|
||||||
val = ((gdouble) ( (x - sx) * (vx - sx) + (y - sy) * (vy - sy)))
|
val = ((gdouble) ( (x - sx) * (vx - sx) + (y - sy) * (vy - sy)))
|
||||||
/ ((vx - sx) * (vx - sx) + (vy - sy) * (vy - sy));
|
/ ((vx - sx) * (vx - sx) + (vy - sy) * (vy - sy));
|
||||||
|
@ -577,7 +587,9 @@ color_selection_callback (GtkWidget *widget,
|
||||||
val = 0;
|
val = 0;
|
||||||
else if (val > 1)
|
else if (val > 1)
|
||||||
val = 1;
|
val = 1;
|
||||||
} else if ((x - hx) * sx + (y - hy) * sy < 0) {
|
}
|
||||||
|
else if ((x - hx) * sx + (y - hy) * sy < 0)
|
||||||
|
{
|
||||||
val = 1;
|
val = 1;
|
||||||
sat = ((gdouble) ( (x - vx) * (hx - vx) + (y - vy) * (hy - vy)))
|
sat = ((gdouble) ( (x - vx) * (hx - vx) + (y - vy) * (hy - vy)))
|
||||||
/ ((hx - vx) * (hx - vx) + (hy - vy) * (hy - vy));
|
/ ((hx - vx) * (hx - vx) + (hy - vy) * (hy - vy));
|
||||||
|
@ -585,13 +597,18 @@ color_selection_callback (GtkWidget *widget,
|
||||||
sat = 0;
|
sat = 0;
|
||||||
else if (sat > 1)
|
else if (sat > 1)
|
||||||
sat = 1;
|
sat = 1;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
val = (gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx))
|
val = (gdouble) ( (x - sx) * (hy - vy) - (y - sy) * (hx - vx))
|
||||||
/ (gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
/ (gdouble) ((vx - sx) * (hy - vy) - (vy - sy) * (hx - vx));
|
||||||
if (val <= 0) {
|
if (val <= 0)
|
||||||
|
{
|
||||||
val = 0;
|
val = 0;
|
||||||
sat = 0;
|
sat = 0;
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
if (val > 1)
|
if (val > 1)
|
||||||
val = 1;
|
val = 1;
|
||||||
sat = (gdouble) (y - sy - val * (vy - sy)) / (val * (gdouble) (hy - vy));
|
sat = (gdouble) (y - sy - val * (vy - sy)) / (val * (gdouble) (hy - vy));
|
||||||
|
@ -602,21 +619,16 @@ color_selection_callback (GtkWidget *widget,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
coldata->values[SATURATION] = 100 * sat + 0.5;
|
coldata->hsv.s = sat;
|
||||||
coldata->values[VALUE] = 100 * val + 0.5;
|
coldata->hsv.v = val;
|
||||||
color_select_update_rgb_values (coldata);
|
color_select_update_rgb_values (coldata);
|
||||||
update_previews (coldata, FALSE);
|
update_previews (coldata, FALSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* callback the user */
|
/* callback the user */
|
||||||
(* coldata->callback) (coldata->data,
|
(* coldata->callback) (coldata->data,
|
||||||
coldata->values[HUE],
|
&coldata->hsv,
|
||||||
coldata->values[SATURATION],
|
&coldata->rgb);
|
||||||
coldata->values[VALUE],
|
|
||||||
coldata->values[RED],
|
|
||||||
coldata->values[GREEN],
|
|
||||||
coldata->values[BLUE],
|
|
||||||
coldata->values[ALPHA]);
|
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,9 +25,9 @@
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
|
||||||
#include <libgimp/gimpcolorselector.h>
|
|
||||||
#include <libgimp/gimpcolor.h>
|
#include <libgimp/gimpcolor.h>
|
||||||
#include <libgimp/gimpcolorspace.h>
|
#include <libgimp/gimpcolorspace.h>
|
||||||
|
#include <libgimp/gimpcolorselector.h>
|
||||||
#include <libgimp/gimpmodule.h>
|
#include <libgimp/gimpmodule.h>
|
||||||
#include <libgimp/gimpmath.h>
|
#include <libgimp/gimpmath.h>
|
||||||
|
|
||||||
|
@ -36,26 +36,16 @@
|
||||||
#include <libgimp/gimpintl.h>
|
#include <libgimp/gimpintl.h>
|
||||||
|
|
||||||
/* prototypes */
|
/* prototypes */
|
||||||
static GtkWidget * colorsel_water_new (gint h,
|
static GtkWidget * colorsel_water_new (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback,
|
GimpColorSelectorCallback,
|
||||||
gpointer ,
|
gpointer ,
|
||||||
gpointer *);
|
gpointer *);
|
||||||
static void colorsel_water_free (gpointer data);
|
static void colorsel_water_free (gpointer data);
|
||||||
static void colorsel_water_set_color (gpointer data,
|
static void colorsel_water_set_color (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb);
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a);
|
|
||||||
static void colorsel_water_set_channel (gpointer data,
|
static void colorsel_water_set_channel (gpointer data,
|
||||||
GimpColorSelectorChannelType channel);
|
GimpColorSelectorChannelType channel);
|
||||||
static void colorsel_water_update (void);
|
static void colorsel_water_update (void);
|
||||||
|
@ -412,7 +402,6 @@ draw_brush (GtkWidget *widget,
|
||||||
last_pressure = pressure;
|
last_pressure = pressure;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static gint
|
static gint
|
||||||
button_press_event (GtkWidget *widget,
|
button_press_event (GtkWidget *widget,
|
||||||
GdkEventButton *event)
|
GdkEventButton *event)
|
||||||
|
@ -564,13 +553,8 @@ pressure_adjust_update (GtkAdjustment *adj,
|
||||||
|
|
||||||
|
|
||||||
static GtkWidget*
|
static GtkWidget*
|
||||||
colorsel_water_new (gint h,
|
colorsel_water_new (const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb,
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a,
|
|
||||||
gboolean show_alpha,
|
gboolean show_alpha,
|
||||||
GimpColorSelectorCallback callback,
|
GimpColorSelectorCallback callback,
|
||||||
gpointer callback_data,
|
gpointer callback_data,
|
||||||
|
@ -760,7 +744,7 @@ colorsel_water_new (gint h,
|
||||||
|
|
||||||
gtk_widget_show_all (hbox);
|
gtk_widget_show_all (hbox);
|
||||||
|
|
||||||
colorsel_water_set_color (coldata, h, s, v, r, g, b, a);
|
colorsel_water_set_color (coldata, hsv, rgb);
|
||||||
draw_all_buckets ();
|
draw_all_buckets ();
|
||||||
|
|
||||||
return vbox;
|
return vbox;
|
||||||
|
@ -775,19 +759,14 @@ colorsel_water_free (gpointer selector_data)
|
||||||
|
|
||||||
static void
|
static void
|
||||||
colorsel_water_set_color (gpointer data,
|
colorsel_water_set_color (gpointer data,
|
||||||
gint h,
|
const GimpHSV *hsv,
|
||||||
gint s,
|
const GimpRGB *rgb)
|
||||||
gint v,
|
|
||||||
gint r,
|
|
||||||
gint g,
|
|
||||||
gint b,
|
|
||||||
gint a)
|
|
||||||
{
|
{
|
||||||
set_bucket (0,
|
set_bucket (0,
|
||||||
((gdouble) r) / 255.999,
|
rgb->r,
|
||||||
((gdouble) g) / 255.999,
|
rgb->g,
|
||||||
((gdouble) b) / 255.999,
|
rgb->b,
|
||||||
((gdouble) a) / 255.999);
|
rgb->a);
|
||||||
|
|
||||||
draw_bucket (0);
|
draw_bucket (0);
|
||||||
}
|
}
|
||||||
|
@ -801,36 +780,19 @@ colorsel_water_set_channel (gpointer data,
|
||||||
static void
|
static void
|
||||||
colorsel_water_update (void)
|
colorsel_water_update (void)
|
||||||
{
|
{
|
||||||
gdouble rr;
|
GimpRGB rgb;
|
||||||
gdouble gg;
|
GimpHSV hsv;
|
||||||
gdouble bb;
|
|
||||||
|
|
||||||
gint h;
|
rgb.r = bucket[0][0];
|
||||||
gint s;
|
rgb.g = bucket[0][1];
|
||||||
gint v;
|
rgb.b = bucket[0][2];
|
||||||
gint r;
|
rgb.a = bucket[0][3];
|
||||||
gint g;
|
|
||||||
gint b;
|
|
||||||
gint a;
|
|
||||||
|
|
||||||
r = (gint) (bucket[0][0] * 255.999);
|
gimp_rgb_to_hsv (&rgb, &hsv);
|
||||||
g = (gint) (bucket[0][1] * 255.999);
|
|
||||||
b = (gint) (bucket[0][2] * 255.999);
|
|
||||||
a = (gint) (bucket[0][3] * 255.999);
|
|
||||||
|
|
||||||
rr = bucket[0][0];
|
|
||||||
gg = bucket[0][1];
|
|
||||||
bb = bucket[0][2];
|
|
||||||
|
|
||||||
gimp_rgb_to_hsv_double (&rr, &gg, &bb);
|
|
||||||
|
|
||||||
h = (gint) (rr * 360.99);
|
|
||||||
s = (gint) (gg * 255.99);
|
|
||||||
v = (gint) (bb * 255.99);
|
|
||||||
|
|
||||||
draw_bucket (0);
|
draw_bucket (0);
|
||||||
|
|
||||||
coldata->callback (coldata->data, h, s, v, r, g, b, a);
|
coldata->callback (coldata->data, &hsv, &rgb);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -931,10 +893,3 @@ colorsel_water_drag_handle (GtkWidget *widget,
|
||||||
gdk_atom_intern ("application/x-color", FALSE),
|
gdk_atom_intern ("application/x-color", FALSE),
|
||||||
16, (guchar *)vals, 8);
|
16, (guchar *)vals, 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue