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:
Michael Natterer 2001-01-15 12:20:38 +00:00 committed by Michael Natterer
parent 4c1f53a979
commit 368d0efe9b
19 changed files with 1309 additions and 2088 deletions

View File

@ -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]

View File

@ -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]);
} }

View File

@ -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,

View File

@ -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);
} }

View File

@ -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]);
} }

View File

@ -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,

View File

@ -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]);
} }

View File

@ -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,

View File

@ -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);
} }

View File

@ -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]);
} }

View File

@ -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,

View File

@ -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);

View File

@ -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);

View File

@ -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)

View File

@ -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);

View File

@ -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);
} }

View File

@ -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 */

View File

@ -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;
} }

View File

@ -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);
} }