s/sprintf/g_snprintf

1999-11-20  Michael Natterer  <mitch@gimp.org>

	* app/devices.c: s/sprintf/g_snprintf

	* app/color_balance.[ch]: spinbuttons instead of text entries.
This commit is contained in:
Michael Natterer
1999-11-20 18:08:41 +00:00
committed by Michael Natterer
parent 40606d9461
commit e5aad8b85b
14 changed files with 778 additions and 1141 deletions

View File

@ -1,3 +1,9 @@
1999-11-20 Michael Natterer <mitch@gimp.org>
* app/devices.c: s/sprintf/g_snprintf
* app/color_balance.[ch]: spinbuttons instead of text entries.
1999-11-20 Michael Natterer <mitch@gimp.org> 1999-11-20 Michael Natterer <mitch@gimp.org>
* libgimp/gimpexport.c: changed the packing spacings to match the * libgimp/gimpexport.c: changed the packing spacings to match the

View File

@ -34,22 +34,18 @@
#include "libgimp/gimpintl.h" #include "libgimp/gimpintl.h"
#include "libgimp/gimpmath.h" #include "libgimp/gimpmath.h"
#define TEXT_WIDTH 55 #define CYAN_RED 0x1
#define MAGENTA_GREEN 0x2
#define CR_SLIDER 0x1 #define YELLOW_BLUE 0x4
#define MG_SLIDER 0x2 #define ALL (CYAN_RED | MAGENTA_GREEN | YELLOW_BLUE)
#define YB_SLIDER 0x4
#define CR_TEXT 0x8
#define MG_TEXT 0x10
#define YB_TEXT 0x20
#define ALL 0xFF
/* the color balance structures */ /* the color balance structures */
typedef struct _ColorBalance ColorBalance; typedef struct _ColorBalance ColorBalance;
struct _ColorBalance struct _ColorBalance
{ {
int x, y; /* coords for last mouse click */ gint x, y; /* coords for last mouse click */
}; };
/* the color balance tool options */ /* the color balance tool options */
@ -74,30 +70,26 @@ static void color_balance_midtones_callback (GtkWidget *, gpointer);
static void color_balance_highlights_callback (GtkWidget *, gpointer); static void color_balance_highlights_callback (GtkWidget *, gpointer);
static void color_balance_preserve_update (GtkWidget *, gpointer); static void color_balance_preserve_update (GtkWidget *, gpointer);
static void color_balance_preview_update (GtkWidget *, gpointer); static void color_balance_preview_update (GtkWidget *, gpointer);
static void color_balance_cr_scale_update (GtkAdjustment *, gpointer); static void color_balance_cr_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_mg_scale_update (GtkAdjustment *, gpointer); static void color_balance_mg_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_yb_scale_update (GtkAdjustment *, gpointer); static void color_balance_yb_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_cr_text_update (GtkWidget *, gpointer);
static void color_balance_mg_text_update (GtkWidget *, gpointer);
static void color_balance_yb_text_update (GtkWidget *, gpointer);
/* color balance machinery */ /* color balance machinery */
void void
color_balance (PixelRegion *srcPR, color_balance (PixelRegion *srcPR,
PixelRegion *destPR, PixelRegion *destPR,
void *user_data) void *data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
unsigned char *src, *s; guchar *src, *s;
unsigned char *dest, *d; guchar *dest, *d;
int alpha; gint alpha;
int r, g, b; gint r, g, b;
int r_n, g_n, b_n; gint r_n, g_n, b_n;
int w, h; gint w, h;
cbd = (ColorBalanceDialog *) user_data; cbd = (ColorBalanceDialog *) data;
h = srcPR->h; h = srcPR->h;
src = srcPR->data; src = srcPR->data;
@ -119,7 +111,6 @@ color_balance (PixelRegion *srcPR,
g_n = cbd->g_lookup[g]; g_n = cbd->g_lookup[g];
b_n = cbd->b_lookup[b]; b_n = cbd->b_lookup[b];
if (cbd->preserve_luminosity) if (cbd->preserve_luminosity)
{ {
rgb_to_hls (&r_n, &g_n, &b_n); rgb_to_hls (&r_n, &g_n, &b_n);
@ -143,8 +134,7 @@ color_balance (PixelRegion *srcPR,
} }
} }
/* color balance action functions */
/* by_color select action functions */
static void static void
color_balance_control (Tool *tool, color_balance_control (Tool *tool,
@ -174,7 +164,7 @@ color_balance_control (Tool *tool,
} }
Tool * Tool *
tools_new_color_balance () tools_new_color_balance (void)
{ {
Tool * tool; Tool * tool;
ColorBalance * private; ColorBalance * private;
@ -216,7 +206,7 @@ tools_free_color_balance (Tool *tool)
void void
color_balance_initialize (GDisplay *gdisp) color_balance_initialize (GDisplay *gdisp)
{ {
int i; gint i;
if (! drawable_color (gimage_active_drawable (gdisp->gimage))) if (! drawable_color (gimage_active_drawable (gdisp->gimage)))
{ {
@ -252,7 +242,7 @@ color_balance_initialize (GDisplay *gdisp)
/**************************/ /**************************/
static ColorBalanceDialog * static ColorBalanceDialog *
color_balance_new_dialog () color_balance_new_dialog (void)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
GtkWidget *vbox; GtkWidget *vbox;
@ -261,6 +251,7 @@ color_balance_new_dialog ()
GtkWidget *start_label; GtkWidget *start_label;
GtkWidget *end_label; GtkWidget *end_label;
GtkWidget *label; GtkWidget *label;
GtkWidget *spinbutton;
GtkWidget *slider; GtkWidget *slider;
GtkWidget *toggle; GtkWidget *toggle;
GtkWidget *radio_button; GtkWidget *radio_button;
@ -282,7 +273,7 @@ color_balance_new_dialog ()
color_balance_highlights_callback color_balance_highlights_callback
}; };
cbd = g_malloc (sizeof (ColorBalanceDialog)); cbd = g_new (ColorBalanceDialog, 1);
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
cbd->preview = TRUE; cbd->preview = TRUE;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
@ -301,47 +292,46 @@ color_balance_new_dialog ()
NULL); NULL);
vbox = gtk_vbox_new (FALSE, 2); vbox = gtk_vbox_new (FALSE, 2);
gtk_container_set_border_width (GTK_CONTAINER (vbox), 2); gtk_container_set_border_width (GTK_CONTAINER (vbox), 4);
gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox); gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
label = gtk_label_new (_("Color Levels: ")); label = gtk_label_new (_("Color Levels:"));
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), label, TRUE, FALSE, 0);
gtk_widget_show (label); gtk_widget_show (label);
/* cyan-red text */ /* cyan-red spinbutton */
cbd->cyan_red_text = gtk_entry_new (); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_set_usize (cbd->cyan_red_text, TEXT_WIDTH, 25); cbd->cyan_red_data = GTK_ADJUSTMENT (data);
gtk_box_pack_start (GTK_BOX (hbox), cbd->cyan_red_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_text), "changed",
(GtkSignalFunc) color_balance_cr_text_update,
cbd);
gtk_widget_show (cbd->cyan_red_text);
/* magenta-green text */ spinbutton = gtk_spin_button_new (cbd->cyan_red_data, 1.0, 0);
cbd->magenta_green_text = gtk_entry_new (); gtk_widget_set_usize (spinbutton, 75, -1);
gtk_widget_set_usize (cbd->magenta_green_text, TEXT_WIDTH, 25); gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), cbd->magenta_green_text, TRUE, FALSE, 0); gtk_widget_show (spinbutton);
gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_text), "changed",
(GtkSignalFunc) color_balance_mg_text_update, /* magenta-green spinbutton */
cbd); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_show (cbd->magenta_green_text); cbd->magenta_green_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->magenta_green_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue spinbutton */
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->yellow_blue_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue text */
cbd->yellow_blue_text = gtk_entry_new ();
gtk_widget_set_usize (cbd->yellow_blue_text, TEXT_WIDTH, 25);
gtk_box_pack_start (GTK_BOX (hbox), cbd->yellow_blue_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_text), "changed",
(GtkSignalFunc) color_balance_yb_text_update,
cbd);
gtk_widget_show (cbd->yellow_blue_text);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* The table containing sliders */ /* The table containing sliders */
table = gtk_table_new (3, 3, FALSE); table = gtk_table_new (3, 3, FALSE);
gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0);
@ -351,9 +341,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->cyan_red_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->cyan_red_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -361,9 +350,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_data), "value_changed",
(GtkSignalFunc) color_balance_cr_scale_update, GTK_SIGNAL_FUNC (color_balance_cr_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Red")); end_label = gtk_label_new (_("Red"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1,
@ -378,9 +368,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->magenta_green_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->magenta_green_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -388,9 +377,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_data), "value_changed",
(GtkSignalFunc) color_balance_mg_scale_update, GTK_SIGNAL_FUNC (color_balance_mg_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Green")); end_label = gtk_label_new (_("Green"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2,
@ -405,9 +395,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->yellow_blue_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -415,9 +404,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_data), "value_changed",
(GtkSignalFunc) color_balance_yb_scale_update, GTK_SIGNAL_FUNC (color_balance_yb_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Blue")); end_label = gtk_label_new (_("Blue"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3,
@ -428,40 +418,42 @@ color_balance_new_dialog ()
gtk_widget_show (slider); gtk_widget_show (slider);
/* Horizontal box for preview and preserve luminosity toggle buttons */ /* Horizontal box for preview and preserve luminosity toggle buttons */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* The preview toggle */ /* The preview toggle */
toggle = gtk_check_button_new_with_label (_("Preview")); toggle = gtk_check_button_new_with_label (_("Preview"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview);
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preview_update, GTK_SIGNAL_FUNC (color_balance_preview_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
/* The preserve luminosity toggle */ /* The preserve luminosity toggle */
toggle = gtk_check_button_new_with_label (_("Preserve Luminosity")); toggle = gtk_check_button_new_with_label (_("Preserve Luminosity"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preserve_luminosity); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle),
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); cbd->preserve_luminosity);
gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preserve_update, GTK_SIGNAL_FUNC (color_balance_preserve_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* the radio buttons for application mode */ /* the radio buttons for application mode */
for (i = 0; i < 3; i++) for (i = 0; i < 3; i++)
{ {
radio_button = gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i])); radio_button =
gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i]));
group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button)); group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button));
gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (radio_button), "toggled", gtk_signal_connect (GTK_OBJECT (radio_button), "toggled",
(GtkSignalFunc) appl_mode_callbacks[i], GTK_SIGNAL_FUNC (appl_mode_callbacks[i]),
cbd); cbd);
gtk_widget_show (radio_button); gtk_widget_show (radio_button);
} }
@ -476,50 +468,34 @@ color_balance_new_dialog ()
static void static void
color_balance_update (ColorBalanceDialog *cbd, color_balance_update (ColorBalanceDialog *cbd,
int update) gint update)
{ {
char text[12]; if (update & CYAN_RED)
if (update & CR_SLIDER)
{ {
cbd->cyan_red_data->value = cbd->cyan_red[cbd->application_mode]; gtk_adjustment_set_value (cbd->cyan_red_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->cyan_red_data), "value_changed"); cbd->cyan_red[cbd->application_mode]);
} }
if (update & MG_SLIDER) if (update & MAGENTA_GREEN)
{ {
cbd->magenta_green_data->value = cbd->magenta_green[cbd->application_mode]; gtk_adjustment_set_value (cbd->magenta_green_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->magenta_green_data), "value_changed"); cbd->magenta_green[cbd->application_mode]);
} }
if (update & YB_SLIDER) if (update & YELLOW_BLUE)
{ {
cbd->yellow_blue_data->value = cbd->yellow_blue[cbd->application_mode]; gtk_adjustment_set_value (cbd->yellow_blue_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->yellow_blue_data), "value_changed"); cbd->yellow_blue[cbd->application_mode]);
}
if (update & CR_TEXT)
{
sprintf (text, "%0.0f", cbd->cyan_red[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->cyan_red_text), text);
}
if (update & MG_TEXT)
{
sprintf (text, "%0.0f", cbd->magenta_green[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->magenta_green_text), text);
}
if (update & YB_TEXT)
{
sprintf (text, "%0.0f", cbd->yellow_blue[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->yellow_blue_text), text);
} }
} }
void void
color_balance_create_lookup_tables (ColorBalanceDialog *cbd) color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
{ {
double *cyan_red_transfer[3]; gdouble *cyan_red_transfer[3];
double *magenta_green_transfer[3]; gdouble *magenta_green_transfer[3];
double *yellow_blue_transfer[3]; gdouble *yellow_blue_transfer[3];
int i; gint i;
gint32 r_n, g_n, b_n; gint32 r_n, g_n, b_n;
/* Set the transfer arrays (for speed) */ /* Set the transfer arrays (for speed) */
cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub; cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub;
cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub; cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub;
@ -562,7 +538,6 @@ color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
cbd->g_lookup[i] = g_n; cbd->g_lookup[i] = g_n;
cbd->b_lookup[i] = b_n; cbd->b_lookup[i] = b_n;
} }
} }
static void static void
@ -570,19 +545,20 @@ color_balance_preview (ColorBalanceDialog *cbd)
{ {
if (!cbd->image_map) if (!cbd->image_map)
g_message ("color_balance_preview(): No image map"); g_message ("color_balance_preview(): No image map");
active_tool->preserve = TRUE; active_tool->preserve = TRUE;
color_balance_create_lookup_tables(cbd); color_balance_create_lookup_tables (cbd);
image_map_apply (cbd->image_map, color_balance, (void *) cbd); image_map_apply (cbd->image_map, color_balance, (void *) cbd);
active_tool->preserve = FALSE; active_tool->preserve = FALSE;
} }
static void static void
color_balance_ok_callback (GtkWidget *widget, color_balance_ok_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -605,11 +581,12 @@ color_balance_ok_callback (GtkWidget *widget,
static void static void
color_balance_cancel_callback (GtkWidget *widget, color_balance_cancel_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -629,68 +606,66 @@ color_balance_cancel_callback (GtkWidget *widget,
static void static void
color_balance_shadows_callback (GtkWidget *widget, color_balance_shadows_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_midtones_callback (GtkWidget *widget, color_balance_midtones_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = MIDTONES; cbd->application_mode = MIDTONES;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_highlights_callback (GtkWidget *widget, color_balance_highlights_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = HIGHLIGHTS; cbd->application_mode = HIGHLIGHTS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_preserve_update (GtkWidget *w, color_balance_preserve_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
if (cbd->preview)
color_balance_preview (cbd);
}
else else
{
cbd->preserve_luminosity = FALSE; cbd->preserve_luminosity = FALSE;
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
}
} }
static void static void
color_balance_preview_update (GtkWidget *w, color_balance_preview_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{ {
cbd->preview = TRUE; cbd->preview = TRUE;
color_balance_preview (cbd); color_balance_preview (cbd);
@ -700,7 +675,7 @@ color_balance_preview_update (GtkWidget *w,
} }
static void static void
color_balance_cr_scale_update (GtkAdjustment *adjustment, color_balance_cr_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -710,7 +685,6 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
if (cbd->cyan_red[cbd->application_mode] != adjustment->value) if (cbd->cyan_red[cbd->application_mode] != adjustment->value)
{ {
cbd->cyan_red[cbd->application_mode] = adjustment->value; cbd->cyan_red[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, CR_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -718,7 +692,7 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_mg_scale_update (GtkAdjustment *adjustment, color_balance_mg_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -728,7 +702,6 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
if (cbd->magenta_green[cbd->application_mode] != adjustment->value) if (cbd->magenta_green[cbd->application_mode] != adjustment->value)
{ {
cbd->magenta_green[cbd->application_mode] = adjustment->value; cbd->magenta_green[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, MG_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -736,7 +709,7 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_yb_scale_update (GtkAdjustment *adjustment, color_balance_yb_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -746,73 +719,6 @@ color_balance_yb_scale_update (GtkAdjustment *adjustment,
if (cbd->yellow_blue[cbd->application_mode] != adjustment->value) if (cbd->yellow_blue[cbd->application_mode] != adjustment->value)
{ {
cbd->yellow_blue[cbd->application_mode] = adjustment->value; cbd->yellow_blue[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, YB_TEXT);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_cr_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->cyan_red[cbd->application_mode] != value)
{
cbd->cyan_red[cbd->application_mode] = value;
color_balance_update (cbd, CR_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_mg_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->magenta_green[cbd->application_mode] != value)
{
cbd->magenta_green[cbd->application_mode] = value;
color_balance_update (cbd, MG_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_yb_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->yellow_blue[cbd->application_mode] != value)
{
cbd->yellow_blue[cbd->application_mode] = value;
color_balance_update (cbd, YB_SLIDER);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);

View File

@ -19,6 +19,7 @@
#define __COLOR_BALANCE_H__ #define __COLOR_BALANCE_H__
#include <gtk/gtk.h> #include <gtk/gtk.h>
#include "gimpdrawableF.h" #include "gimpdrawableF.h"
#include "image_map.h" #include "image_map.h"
#include "tools.h" #include "tools.h"
@ -31,12 +32,11 @@ typedef enum
} TransferMode; } TransferMode;
typedef struct _ColorBalanceDialog ColorBalanceDialog; typedef struct _ColorBalanceDialog ColorBalanceDialog;
struct _ColorBalanceDialog struct _ColorBalanceDialog
{ {
GtkWidget *shell; GtkWidget *shell;
GtkWidget *cyan_red_text;
GtkWidget *magenta_green_text;
GtkWidget *yellow_blue_text;
GtkAdjustment *cyan_red_data; GtkAdjustment *cyan_red_data;
GtkAdjustment *magenta_green_data; GtkAdjustment *magenta_green_data;
GtkAdjustment *yellow_blue_data; GtkAdjustment *yellow_blue_data;
@ -44,26 +44,29 @@ struct _ColorBalanceDialog
GimpDrawable *drawable; GimpDrawable *drawable;
ImageMap image_map; ImageMap image_map;
double cyan_red[3]; gdouble cyan_red[3];
double magenta_green[3]; gdouble magenta_green[3];
double yellow_blue[3]; gdouble yellow_blue[3];
guchar r_lookup[256]; guchar r_lookup[256];
guchar g_lookup[256]; guchar g_lookup[256];
guchar b_lookup[256]; guchar b_lookup[256];
gint preserve_luminosity; gboolean preserve_luminosity;
gint preview; gboolean preview;
gint application_mode; TransferMode application_mode;
}; };
/* by_color select functions */ /* color balance functions */
Tool * tools_new_color_balance (void); Tool * tools_new_color_balance (void);
void tools_free_color_balance (Tool *); void tools_free_color_balance (Tool *tool);
void color_balance_initialize (GDisplay *); void color_balance_initialize (GDisplay *gdisp);
void color_balance (PixelRegion *, PixelRegion *, void *); void color_balance (PixelRegion *srcPR,
PixelRegion *destPR,
void *data);
void color_balance_create_lookup_tables (ColorBalanceDialog *); void color_balance_create_lookup_tables (ColorBalanceDialog *cbd);
#endif /* __COLOR_BALANCE_H__ */ #endif /* __COLOR_BALANCE_H__ */

View File

@ -34,22 +34,18 @@
#include "libgimp/gimpintl.h" #include "libgimp/gimpintl.h"
#include "libgimp/gimpmath.h" #include "libgimp/gimpmath.h"
#define TEXT_WIDTH 55 #define CYAN_RED 0x1
#define MAGENTA_GREEN 0x2
#define CR_SLIDER 0x1 #define YELLOW_BLUE 0x4
#define MG_SLIDER 0x2 #define ALL (CYAN_RED | MAGENTA_GREEN | YELLOW_BLUE)
#define YB_SLIDER 0x4
#define CR_TEXT 0x8
#define MG_TEXT 0x10
#define YB_TEXT 0x20
#define ALL 0xFF
/* the color balance structures */ /* the color balance structures */
typedef struct _ColorBalance ColorBalance; typedef struct _ColorBalance ColorBalance;
struct _ColorBalance struct _ColorBalance
{ {
int x, y; /* coords for last mouse click */ gint x, y; /* coords for last mouse click */
}; };
/* the color balance tool options */ /* the color balance tool options */
@ -74,30 +70,26 @@ static void color_balance_midtones_callback (GtkWidget *, gpointer);
static void color_balance_highlights_callback (GtkWidget *, gpointer); static void color_balance_highlights_callback (GtkWidget *, gpointer);
static void color_balance_preserve_update (GtkWidget *, gpointer); static void color_balance_preserve_update (GtkWidget *, gpointer);
static void color_balance_preview_update (GtkWidget *, gpointer); static void color_balance_preview_update (GtkWidget *, gpointer);
static void color_balance_cr_scale_update (GtkAdjustment *, gpointer); static void color_balance_cr_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_mg_scale_update (GtkAdjustment *, gpointer); static void color_balance_mg_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_yb_scale_update (GtkAdjustment *, gpointer); static void color_balance_yb_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_cr_text_update (GtkWidget *, gpointer);
static void color_balance_mg_text_update (GtkWidget *, gpointer);
static void color_balance_yb_text_update (GtkWidget *, gpointer);
/* color balance machinery */ /* color balance machinery */
void void
color_balance (PixelRegion *srcPR, color_balance (PixelRegion *srcPR,
PixelRegion *destPR, PixelRegion *destPR,
void *user_data) void *data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
unsigned char *src, *s; guchar *src, *s;
unsigned char *dest, *d; guchar *dest, *d;
int alpha; gint alpha;
int r, g, b; gint r, g, b;
int r_n, g_n, b_n; gint r_n, g_n, b_n;
int w, h; gint w, h;
cbd = (ColorBalanceDialog *) user_data; cbd = (ColorBalanceDialog *) data;
h = srcPR->h; h = srcPR->h;
src = srcPR->data; src = srcPR->data;
@ -119,7 +111,6 @@ color_balance (PixelRegion *srcPR,
g_n = cbd->g_lookup[g]; g_n = cbd->g_lookup[g];
b_n = cbd->b_lookup[b]; b_n = cbd->b_lookup[b];
if (cbd->preserve_luminosity) if (cbd->preserve_luminosity)
{ {
rgb_to_hls (&r_n, &g_n, &b_n); rgb_to_hls (&r_n, &g_n, &b_n);
@ -143,8 +134,7 @@ color_balance (PixelRegion *srcPR,
} }
} }
/* color balance action functions */
/* by_color select action functions */
static void static void
color_balance_control (Tool *tool, color_balance_control (Tool *tool,
@ -174,7 +164,7 @@ color_balance_control (Tool *tool,
} }
Tool * Tool *
tools_new_color_balance () tools_new_color_balance (void)
{ {
Tool * tool; Tool * tool;
ColorBalance * private; ColorBalance * private;
@ -216,7 +206,7 @@ tools_free_color_balance (Tool *tool)
void void
color_balance_initialize (GDisplay *gdisp) color_balance_initialize (GDisplay *gdisp)
{ {
int i; gint i;
if (! drawable_color (gimage_active_drawable (gdisp->gimage))) if (! drawable_color (gimage_active_drawable (gdisp->gimage)))
{ {
@ -252,7 +242,7 @@ color_balance_initialize (GDisplay *gdisp)
/**************************/ /**************************/
static ColorBalanceDialog * static ColorBalanceDialog *
color_balance_new_dialog () color_balance_new_dialog (void)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
GtkWidget *vbox; GtkWidget *vbox;
@ -261,6 +251,7 @@ color_balance_new_dialog ()
GtkWidget *start_label; GtkWidget *start_label;
GtkWidget *end_label; GtkWidget *end_label;
GtkWidget *label; GtkWidget *label;
GtkWidget *spinbutton;
GtkWidget *slider; GtkWidget *slider;
GtkWidget *toggle; GtkWidget *toggle;
GtkWidget *radio_button; GtkWidget *radio_button;
@ -282,7 +273,7 @@ color_balance_new_dialog ()
color_balance_highlights_callback color_balance_highlights_callback
}; };
cbd = g_malloc (sizeof (ColorBalanceDialog)); cbd = g_new (ColorBalanceDialog, 1);
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
cbd->preview = TRUE; cbd->preview = TRUE;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
@ -301,47 +292,46 @@ color_balance_new_dialog ()
NULL); NULL);
vbox = gtk_vbox_new (FALSE, 2); vbox = gtk_vbox_new (FALSE, 2);
gtk_container_set_border_width (GTK_CONTAINER (vbox), 2); gtk_container_set_border_width (GTK_CONTAINER (vbox), 4);
gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox); gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
label = gtk_label_new (_("Color Levels: ")); label = gtk_label_new (_("Color Levels:"));
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), label, TRUE, FALSE, 0);
gtk_widget_show (label); gtk_widget_show (label);
/* cyan-red text */ /* cyan-red spinbutton */
cbd->cyan_red_text = gtk_entry_new (); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_set_usize (cbd->cyan_red_text, TEXT_WIDTH, 25); cbd->cyan_red_data = GTK_ADJUSTMENT (data);
gtk_box_pack_start (GTK_BOX (hbox), cbd->cyan_red_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_text), "changed",
(GtkSignalFunc) color_balance_cr_text_update,
cbd);
gtk_widget_show (cbd->cyan_red_text);
/* magenta-green text */ spinbutton = gtk_spin_button_new (cbd->cyan_red_data, 1.0, 0);
cbd->magenta_green_text = gtk_entry_new (); gtk_widget_set_usize (spinbutton, 75, -1);
gtk_widget_set_usize (cbd->magenta_green_text, TEXT_WIDTH, 25); gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), cbd->magenta_green_text, TRUE, FALSE, 0); gtk_widget_show (spinbutton);
gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_text), "changed",
(GtkSignalFunc) color_balance_mg_text_update, /* magenta-green spinbutton */
cbd); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_show (cbd->magenta_green_text); cbd->magenta_green_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->magenta_green_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue spinbutton */
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->yellow_blue_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue text */
cbd->yellow_blue_text = gtk_entry_new ();
gtk_widget_set_usize (cbd->yellow_blue_text, TEXT_WIDTH, 25);
gtk_box_pack_start (GTK_BOX (hbox), cbd->yellow_blue_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_text), "changed",
(GtkSignalFunc) color_balance_yb_text_update,
cbd);
gtk_widget_show (cbd->yellow_blue_text);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* The table containing sliders */ /* The table containing sliders */
table = gtk_table_new (3, 3, FALSE); table = gtk_table_new (3, 3, FALSE);
gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0);
@ -351,9 +341,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->cyan_red_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->cyan_red_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -361,9 +350,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_data), "value_changed",
(GtkSignalFunc) color_balance_cr_scale_update, GTK_SIGNAL_FUNC (color_balance_cr_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Red")); end_label = gtk_label_new (_("Red"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1,
@ -378,9 +368,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->magenta_green_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->magenta_green_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -388,9 +377,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_data), "value_changed",
(GtkSignalFunc) color_balance_mg_scale_update, GTK_SIGNAL_FUNC (color_balance_mg_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Green")); end_label = gtk_label_new (_("Green"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2,
@ -405,9 +395,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->yellow_blue_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -415,9 +404,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_data), "value_changed",
(GtkSignalFunc) color_balance_yb_scale_update, GTK_SIGNAL_FUNC (color_balance_yb_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Blue")); end_label = gtk_label_new (_("Blue"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3,
@ -428,40 +418,42 @@ color_balance_new_dialog ()
gtk_widget_show (slider); gtk_widget_show (slider);
/* Horizontal box for preview and preserve luminosity toggle buttons */ /* Horizontal box for preview and preserve luminosity toggle buttons */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* The preview toggle */ /* The preview toggle */
toggle = gtk_check_button_new_with_label (_("Preview")); toggle = gtk_check_button_new_with_label (_("Preview"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview);
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preview_update, GTK_SIGNAL_FUNC (color_balance_preview_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
/* The preserve luminosity toggle */ /* The preserve luminosity toggle */
toggle = gtk_check_button_new_with_label (_("Preserve Luminosity")); toggle = gtk_check_button_new_with_label (_("Preserve Luminosity"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preserve_luminosity); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle),
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); cbd->preserve_luminosity);
gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preserve_update, GTK_SIGNAL_FUNC (color_balance_preserve_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* the radio buttons for application mode */ /* the radio buttons for application mode */
for (i = 0; i < 3; i++) for (i = 0; i < 3; i++)
{ {
radio_button = gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i])); radio_button =
gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i]));
group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button)); group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button));
gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (radio_button), "toggled", gtk_signal_connect (GTK_OBJECT (radio_button), "toggled",
(GtkSignalFunc) appl_mode_callbacks[i], GTK_SIGNAL_FUNC (appl_mode_callbacks[i]),
cbd); cbd);
gtk_widget_show (radio_button); gtk_widget_show (radio_button);
} }
@ -476,50 +468,34 @@ color_balance_new_dialog ()
static void static void
color_balance_update (ColorBalanceDialog *cbd, color_balance_update (ColorBalanceDialog *cbd,
int update) gint update)
{ {
char text[12]; if (update & CYAN_RED)
if (update & CR_SLIDER)
{ {
cbd->cyan_red_data->value = cbd->cyan_red[cbd->application_mode]; gtk_adjustment_set_value (cbd->cyan_red_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->cyan_red_data), "value_changed"); cbd->cyan_red[cbd->application_mode]);
} }
if (update & MG_SLIDER) if (update & MAGENTA_GREEN)
{ {
cbd->magenta_green_data->value = cbd->magenta_green[cbd->application_mode]; gtk_adjustment_set_value (cbd->magenta_green_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->magenta_green_data), "value_changed"); cbd->magenta_green[cbd->application_mode]);
} }
if (update & YB_SLIDER) if (update & YELLOW_BLUE)
{ {
cbd->yellow_blue_data->value = cbd->yellow_blue[cbd->application_mode]; gtk_adjustment_set_value (cbd->yellow_blue_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->yellow_blue_data), "value_changed"); cbd->yellow_blue[cbd->application_mode]);
}
if (update & CR_TEXT)
{
sprintf (text, "%0.0f", cbd->cyan_red[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->cyan_red_text), text);
}
if (update & MG_TEXT)
{
sprintf (text, "%0.0f", cbd->magenta_green[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->magenta_green_text), text);
}
if (update & YB_TEXT)
{
sprintf (text, "%0.0f", cbd->yellow_blue[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->yellow_blue_text), text);
} }
} }
void void
color_balance_create_lookup_tables (ColorBalanceDialog *cbd) color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
{ {
double *cyan_red_transfer[3]; gdouble *cyan_red_transfer[3];
double *magenta_green_transfer[3]; gdouble *magenta_green_transfer[3];
double *yellow_blue_transfer[3]; gdouble *yellow_blue_transfer[3];
int i; gint i;
gint32 r_n, g_n, b_n; gint32 r_n, g_n, b_n;
/* Set the transfer arrays (for speed) */ /* Set the transfer arrays (for speed) */
cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub; cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub;
cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub; cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub;
@ -562,7 +538,6 @@ color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
cbd->g_lookup[i] = g_n; cbd->g_lookup[i] = g_n;
cbd->b_lookup[i] = b_n; cbd->b_lookup[i] = b_n;
} }
} }
static void static void
@ -570,19 +545,20 @@ color_balance_preview (ColorBalanceDialog *cbd)
{ {
if (!cbd->image_map) if (!cbd->image_map)
g_message ("color_balance_preview(): No image map"); g_message ("color_balance_preview(): No image map");
active_tool->preserve = TRUE; active_tool->preserve = TRUE;
color_balance_create_lookup_tables(cbd); color_balance_create_lookup_tables (cbd);
image_map_apply (cbd->image_map, color_balance, (void *) cbd); image_map_apply (cbd->image_map, color_balance, (void *) cbd);
active_tool->preserve = FALSE; active_tool->preserve = FALSE;
} }
static void static void
color_balance_ok_callback (GtkWidget *widget, color_balance_ok_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -605,11 +581,12 @@ color_balance_ok_callback (GtkWidget *widget,
static void static void
color_balance_cancel_callback (GtkWidget *widget, color_balance_cancel_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -629,68 +606,66 @@ color_balance_cancel_callback (GtkWidget *widget,
static void static void
color_balance_shadows_callback (GtkWidget *widget, color_balance_shadows_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_midtones_callback (GtkWidget *widget, color_balance_midtones_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = MIDTONES; cbd->application_mode = MIDTONES;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_highlights_callback (GtkWidget *widget, color_balance_highlights_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = HIGHLIGHTS; cbd->application_mode = HIGHLIGHTS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_preserve_update (GtkWidget *w, color_balance_preserve_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
if (cbd->preview)
color_balance_preview (cbd);
}
else else
{
cbd->preserve_luminosity = FALSE; cbd->preserve_luminosity = FALSE;
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
}
} }
static void static void
color_balance_preview_update (GtkWidget *w, color_balance_preview_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{ {
cbd->preview = TRUE; cbd->preview = TRUE;
color_balance_preview (cbd); color_balance_preview (cbd);
@ -700,7 +675,7 @@ color_balance_preview_update (GtkWidget *w,
} }
static void static void
color_balance_cr_scale_update (GtkAdjustment *adjustment, color_balance_cr_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -710,7 +685,6 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
if (cbd->cyan_red[cbd->application_mode] != adjustment->value) if (cbd->cyan_red[cbd->application_mode] != adjustment->value)
{ {
cbd->cyan_red[cbd->application_mode] = adjustment->value; cbd->cyan_red[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, CR_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -718,7 +692,7 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_mg_scale_update (GtkAdjustment *adjustment, color_balance_mg_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -728,7 +702,6 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
if (cbd->magenta_green[cbd->application_mode] != adjustment->value) if (cbd->magenta_green[cbd->application_mode] != adjustment->value)
{ {
cbd->magenta_green[cbd->application_mode] = adjustment->value; cbd->magenta_green[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, MG_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -736,7 +709,7 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_yb_scale_update (GtkAdjustment *adjustment, color_balance_yb_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -746,73 +719,6 @@ color_balance_yb_scale_update (GtkAdjustment *adjustment,
if (cbd->yellow_blue[cbd->application_mode] != adjustment->value) if (cbd->yellow_blue[cbd->application_mode] != adjustment->value)
{ {
cbd->yellow_blue[cbd->application_mode] = adjustment->value; cbd->yellow_blue[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, YB_TEXT);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_cr_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->cyan_red[cbd->application_mode] != value)
{
cbd->cyan_red[cbd->application_mode] = value;
color_balance_update (cbd, CR_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_mg_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->magenta_green[cbd->application_mode] != value)
{
cbd->magenta_green[cbd->application_mode] = value;
color_balance_update (cbd, MG_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_yb_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->yellow_blue[cbd->application_mode] != value)
{
cbd->yellow_blue[cbd->application_mode] = value;
color_balance_update (cbd, YB_SLIDER);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);

View File

@ -19,6 +19,7 @@
#define __COLOR_BALANCE_H__ #define __COLOR_BALANCE_H__
#include <gtk/gtk.h> #include <gtk/gtk.h>
#include "gimpdrawableF.h" #include "gimpdrawableF.h"
#include "image_map.h" #include "image_map.h"
#include "tools.h" #include "tools.h"
@ -31,12 +32,11 @@ typedef enum
} TransferMode; } TransferMode;
typedef struct _ColorBalanceDialog ColorBalanceDialog; typedef struct _ColorBalanceDialog ColorBalanceDialog;
struct _ColorBalanceDialog struct _ColorBalanceDialog
{ {
GtkWidget *shell; GtkWidget *shell;
GtkWidget *cyan_red_text;
GtkWidget *magenta_green_text;
GtkWidget *yellow_blue_text;
GtkAdjustment *cyan_red_data; GtkAdjustment *cyan_red_data;
GtkAdjustment *magenta_green_data; GtkAdjustment *magenta_green_data;
GtkAdjustment *yellow_blue_data; GtkAdjustment *yellow_blue_data;
@ -44,26 +44,29 @@ struct _ColorBalanceDialog
GimpDrawable *drawable; GimpDrawable *drawable;
ImageMap image_map; ImageMap image_map;
double cyan_red[3]; gdouble cyan_red[3];
double magenta_green[3]; gdouble magenta_green[3];
double yellow_blue[3]; gdouble yellow_blue[3];
guchar r_lookup[256]; guchar r_lookup[256];
guchar g_lookup[256]; guchar g_lookup[256];
guchar b_lookup[256]; guchar b_lookup[256];
gint preserve_luminosity; gboolean preserve_luminosity;
gint preview; gboolean preview;
gint application_mode; TransferMode application_mode;
}; };
/* by_color select functions */ /* color balance functions */
Tool * tools_new_color_balance (void); Tool * tools_new_color_balance (void);
void tools_free_color_balance (Tool *); void tools_free_color_balance (Tool *tool);
void color_balance_initialize (GDisplay *); void color_balance_initialize (GDisplay *gdisp);
void color_balance (PixelRegion *, PixelRegion *, void *); void color_balance (PixelRegion *srcPR,
PixelRegion *destPR,
void *data);
void color_balance_create_lookup_tables (ColorBalanceDialog *); void color_balance_create_lookup_tables (ColorBalanceDialog *cbd);
#endif /* __COLOR_BALANCE_H__ */ #endif /* __COLOR_BALANCE_H__ */

View File

@ -18,7 +18,6 @@
#include "config.h" #include "config.h"
#include <string.h> #include <string.h>
#include <stdio.h>
#include "appenv.h" #include "appenv.h"
#include "devices.h" #include "devices.h"
@ -1048,7 +1047,7 @@ device_status_update (guint32 deviceid)
gtk_widget_show (deviceD->colors[i]); gtk_widget_show (deviceD->colors[i]);
/* Set the tip to be the RGB value */ /* Set the tip to be the RGB value */
sprintf (ttbuf, "[%3d,%3d,%3d]", g_snprintf (ttbuf, sizeof (ttbuf), "[%3d,%3d,%3d]",
buffer[j], buffer[j],
buffer[j+1], buffer[j+1],
buffer[j+2]); buffer[j+2]);

View File

@ -18,7 +18,6 @@
#include "config.h" #include "config.h"
#include <string.h> #include <string.h>
#include <stdio.h>
#include "appenv.h" #include "appenv.h"
#include "devices.h" #include "devices.h"
@ -1048,7 +1047,7 @@ device_status_update (guint32 deviceid)
gtk_widget_show (deviceD->colors[i]); gtk_widget_show (deviceD->colors[i]);
/* Set the tip to be the RGB value */ /* Set the tip to be the RGB value */
sprintf (ttbuf, "[%3d,%3d,%3d]", g_snprintf (ttbuf, sizeof (ttbuf), "[%3d,%3d,%3d]",
buffer[j], buffer[j],
buffer[j+1], buffer[j+1],
buffer[j+2]); buffer[j+2]);

View File

@ -18,7 +18,6 @@
#include "config.h" #include "config.h"
#include <string.h> #include <string.h>
#include <stdio.h>
#include "appenv.h" #include "appenv.h"
#include "devices.h" #include "devices.h"
@ -1048,7 +1047,7 @@ device_status_update (guint32 deviceid)
gtk_widget_show (deviceD->colors[i]); gtk_widget_show (deviceD->colors[i]);
/* Set the tip to be the RGB value */ /* Set the tip to be the RGB value */
sprintf (ttbuf, "[%3d,%3d,%3d]", g_snprintf (ttbuf, sizeof (ttbuf), "[%3d,%3d,%3d]",
buffer[j], buffer[j],
buffer[j+1], buffer[j+1],
buffer[j+2]); buffer[j+2]);

View File

@ -34,22 +34,18 @@
#include "libgimp/gimpintl.h" #include "libgimp/gimpintl.h"
#include "libgimp/gimpmath.h" #include "libgimp/gimpmath.h"
#define TEXT_WIDTH 55 #define CYAN_RED 0x1
#define MAGENTA_GREEN 0x2
#define CR_SLIDER 0x1 #define YELLOW_BLUE 0x4
#define MG_SLIDER 0x2 #define ALL (CYAN_RED | MAGENTA_GREEN | YELLOW_BLUE)
#define YB_SLIDER 0x4
#define CR_TEXT 0x8
#define MG_TEXT 0x10
#define YB_TEXT 0x20
#define ALL 0xFF
/* the color balance structures */ /* the color balance structures */
typedef struct _ColorBalance ColorBalance; typedef struct _ColorBalance ColorBalance;
struct _ColorBalance struct _ColorBalance
{ {
int x, y; /* coords for last mouse click */ gint x, y; /* coords for last mouse click */
}; };
/* the color balance tool options */ /* the color balance tool options */
@ -74,30 +70,26 @@ static void color_balance_midtones_callback (GtkWidget *, gpointer);
static void color_balance_highlights_callback (GtkWidget *, gpointer); static void color_balance_highlights_callback (GtkWidget *, gpointer);
static void color_balance_preserve_update (GtkWidget *, gpointer); static void color_balance_preserve_update (GtkWidget *, gpointer);
static void color_balance_preview_update (GtkWidget *, gpointer); static void color_balance_preview_update (GtkWidget *, gpointer);
static void color_balance_cr_scale_update (GtkAdjustment *, gpointer); static void color_balance_cr_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_mg_scale_update (GtkAdjustment *, gpointer); static void color_balance_mg_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_yb_scale_update (GtkAdjustment *, gpointer); static void color_balance_yb_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_cr_text_update (GtkWidget *, gpointer);
static void color_balance_mg_text_update (GtkWidget *, gpointer);
static void color_balance_yb_text_update (GtkWidget *, gpointer);
/* color balance machinery */ /* color balance machinery */
void void
color_balance (PixelRegion *srcPR, color_balance (PixelRegion *srcPR,
PixelRegion *destPR, PixelRegion *destPR,
void *user_data) void *data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
unsigned char *src, *s; guchar *src, *s;
unsigned char *dest, *d; guchar *dest, *d;
int alpha; gint alpha;
int r, g, b; gint r, g, b;
int r_n, g_n, b_n; gint r_n, g_n, b_n;
int w, h; gint w, h;
cbd = (ColorBalanceDialog *) user_data; cbd = (ColorBalanceDialog *) data;
h = srcPR->h; h = srcPR->h;
src = srcPR->data; src = srcPR->data;
@ -119,7 +111,6 @@ color_balance (PixelRegion *srcPR,
g_n = cbd->g_lookup[g]; g_n = cbd->g_lookup[g];
b_n = cbd->b_lookup[b]; b_n = cbd->b_lookup[b];
if (cbd->preserve_luminosity) if (cbd->preserve_luminosity)
{ {
rgb_to_hls (&r_n, &g_n, &b_n); rgb_to_hls (&r_n, &g_n, &b_n);
@ -143,8 +134,7 @@ color_balance (PixelRegion *srcPR,
} }
} }
/* color balance action functions */
/* by_color select action functions */
static void static void
color_balance_control (Tool *tool, color_balance_control (Tool *tool,
@ -174,7 +164,7 @@ color_balance_control (Tool *tool,
} }
Tool * Tool *
tools_new_color_balance () tools_new_color_balance (void)
{ {
Tool * tool; Tool * tool;
ColorBalance * private; ColorBalance * private;
@ -216,7 +206,7 @@ tools_free_color_balance (Tool *tool)
void void
color_balance_initialize (GDisplay *gdisp) color_balance_initialize (GDisplay *gdisp)
{ {
int i; gint i;
if (! drawable_color (gimage_active_drawable (gdisp->gimage))) if (! drawable_color (gimage_active_drawable (gdisp->gimage)))
{ {
@ -252,7 +242,7 @@ color_balance_initialize (GDisplay *gdisp)
/**************************/ /**************************/
static ColorBalanceDialog * static ColorBalanceDialog *
color_balance_new_dialog () color_balance_new_dialog (void)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
GtkWidget *vbox; GtkWidget *vbox;
@ -261,6 +251,7 @@ color_balance_new_dialog ()
GtkWidget *start_label; GtkWidget *start_label;
GtkWidget *end_label; GtkWidget *end_label;
GtkWidget *label; GtkWidget *label;
GtkWidget *spinbutton;
GtkWidget *slider; GtkWidget *slider;
GtkWidget *toggle; GtkWidget *toggle;
GtkWidget *radio_button; GtkWidget *radio_button;
@ -282,7 +273,7 @@ color_balance_new_dialog ()
color_balance_highlights_callback color_balance_highlights_callback
}; };
cbd = g_malloc (sizeof (ColorBalanceDialog)); cbd = g_new (ColorBalanceDialog, 1);
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
cbd->preview = TRUE; cbd->preview = TRUE;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
@ -301,47 +292,46 @@ color_balance_new_dialog ()
NULL); NULL);
vbox = gtk_vbox_new (FALSE, 2); vbox = gtk_vbox_new (FALSE, 2);
gtk_container_set_border_width (GTK_CONTAINER (vbox), 2); gtk_container_set_border_width (GTK_CONTAINER (vbox), 4);
gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox); gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
label = gtk_label_new (_("Color Levels: ")); label = gtk_label_new (_("Color Levels:"));
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), label, TRUE, FALSE, 0);
gtk_widget_show (label); gtk_widget_show (label);
/* cyan-red text */ /* cyan-red spinbutton */
cbd->cyan_red_text = gtk_entry_new (); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_set_usize (cbd->cyan_red_text, TEXT_WIDTH, 25); cbd->cyan_red_data = GTK_ADJUSTMENT (data);
gtk_box_pack_start (GTK_BOX (hbox), cbd->cyan_red_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_text), "changed",
(GtkSignalFunc) color_balance_cr_text_update,
cbd);
gtk_widget_show (cbd->cyan_red_text);
/* magenta-green text */ spinbutton = gtk_spin_button_new (cbd->cyan_red_data, 1.0, 0);
cbd->magenta_green_text = gtk_entry_new (); gtk_widget_set_usize (spinbutton, 75, -1);
gtk_widget_set_usize (cbd->magenta_green_text, TEXT_WIDTH, 25); gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), cbd->magenta_green_text, TRUE, FALSE, 0); gtk_widget_show (spinbutton);
gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_text), "changed",
(GtkSignalFunc) color_balance_mg_text_update, /* magenta-green spinbutton */
cbd); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_show (cbd->magenta_green_text); cbd->magenta_green_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->magenta_green_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue spinbutton */
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->yellow_blue_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue text */
cbd->yellow_blue_text = gtk_entry_new ();
gtk_widget_set_usize (cbd->yellow_blue_text, TEXT_WIDTH, 25);
gtk_box_pack_start (GTK_BOX (hbox), cbd->yellow_blue_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_text), "changed",
(GtkSignalFunc) color_balance_yb_text_update,
cbd);
gtk_widget_show (cbd->yellow_blue_text);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* The table containing sliders */ /* The table containing sliders */
table = gtk_table_new (3, 3, FALSE); table = gtk_table_new (3, 3, FALSE);
gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0);
@ -351,9 +341,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->cyan_red_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->cyan_red_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -361,9 +350,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_data), "value_changed",
(GtkSignalFunc) color_balance_cr_scale_update, GTK_SIGNAL_FUNC (color_balance_cr_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Red")); end_label = gtk_label_new (_("Red"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1,
@ -378,9 +368,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->magenta_green_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->magenta_green_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -388,9 +377,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_data), "value_changed",
(GtkSignalFunc) color_balance_mg_scale_update, GTK_SIGNAL_FUNC (color_balance_mg_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Green")); end_label = gtk_label_new (_("Green"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2,
@ -405,9 +395,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->yellow_blue_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -415,9 +404,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_data), "value_changed",
(GtkSignalFunc) color_balance_yb_scale_update, GTK_SIGNAL_FUNC (color_balance_yb_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Blue")); end_label = gtk_label_new (_("Blue"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3,
@ -428,40 +418,42 @@ color_balance_new_dialog ()
gtk_widget_show (slider); gtk_widget_show (slider);
/* Horizontal box for preview and preserve luminosity toggle buttons */ /* Horizontal box for preview and preserve luminosity toggle buttons */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* The preview toggle */ /* The preview toggle */
toggle = gtk_check_button_new_with_label (_("Preview")); toggle = gtk_check_button_new_with_label (_("Preview"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview);
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preview_update, GTK_SIGNAL_FUNC (color_balance_preview_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
/* The preserve luminosity toggle */ /* The preserve luminosity toggle */
toggle = gtk_check_button_new_with_label (_("Preserve Luminosity")); toggle = gtk_check_button_new_with_label (_("Preserve Luminosity"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preserve_luminosity); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle),
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); cbd->preserve_luminosity);
gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preserve_update, GTK_SIGNAL_FUNC (color_balance_preserve_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* the radio buttons for application mode */ /* the radio buttons for application mode */
for (i = 0; i < 3; i++) for (i = 0; i < 3; i++)
{ {
radio_button = gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i])); radio_button =
gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i]));
group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button)); group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button));
gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (radio_button), "toggled", gtk_signal_connect (GTK_OBJECT (radio_button), "toggled",
(GtkSignalFunc) appl_mode_callbacks[i], GTK_SIGNAL_FUNC (appl_mode_callbacks[i]),
cbd); cbd);
gtk_widget_show (radio_button); gtk_widget_show (radio_button);
} }
@ -476,50 +468,34 @@ color_balance_new_dialog ()
static void static void
color_balance_update (ColorBalanceDialog *cbd, color_balance_update (ColorBalanceDialog *cbd,
int update) gint update)
{ {
char text[12]; if (update & CYAN_RED)
if (update & CR_SLIDER)
{ {
cbd->cyan_red_data->value = cbd->cyan_red[cbd->application_mode]; gtk_adjustment_set_value (cbd->cyan_red_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->cyan_red_data), "value_changed"); cbd->cyan_red[cbd->application_mode]);
} }
if (update & MG_SLIDER) if (update & MAGENTA_GREEN)
{ {
cbd->magenta_green_data->value = cbd->magenta_green[cbd->application_mode]; gtk_adjustment_set_value (cbd->magenta_green_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->magenta_green_data), "value_changed"); cbd->magenta_green[cbd->application_mode]);
} }
if (update & YB_SLIDER) if (update & YELLOW_BLUE)
{ {
cbd->yellow_blue_data->value = cbd->yellow_blue[cbd->application_mode]; gtk_adjustment_set_value (cbd->yellow_blue_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->yellow_blue_data), "value_changed"); cbd->yellow_blue[cbd->application_mode]);
}
if (update & CR_TEXT)
{
sprintf (text, "%0.0f", cbd->cyan_red[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->cyan_red_text), text);
}
if (update & MG_TEXT)
{
sprintf (text, "%0.0f", cbd->magenta_green[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->magenta_green_text), text);
}
if (update & YB_TEXT)
{
sprintf (text, "%0.0f", cbd->yellow_blue[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->yellow_blue_text), text);
} }
} }
void void
color_balance_create_lookup_tables (ColorBalanceDialog *cbd) color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
{ {
double *cyan_red_transfer[3]; gdouble *cyan_red_transfer[3];
double *magenta_green_transfer[3]; gdouble *magenta_green_transfer[3];
double *yellow_blue_transfer[3]; gdouble *yellow_blue_transfer[3];
int i; gint i;
gint32 r_n, g_n, b_n; gint32 r_n, g_n, b_n;
/* Set the transfer arrays (for speed) */ /* Set the transfer arrays (for speed) */
cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub; cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub;
cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub; cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub;
@ -562,7 +538,6 @@ color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
cbd->g_lookup[i] = g_n; cbd->g_lookup[i] = g_n;
cbd->b_lookup[i] = b_n; cbd->b_lookup[i] = b_n;
} }
} }
static void static void
@ -570,19 +545,20 @@ color_balance_preview (ColorBalanceDialog *cbd)
{ {
if (!cbd->image_map) if (!cbd->image_map)
g_message ("color_balance_preview(): No image map"); g_message ("color_balance_preview(): No image map");
active_tool->preserve = TRUE; active_tool->preserve = TRUE;
color_balance_create_lookup_tables(cbd); color_balance_create_lookup_tables (cbd);
image_map_apply (cbd->image_map, color_balance, (void *) cbd); image_map_apply (cbd->image_map, color_balance, (void *) cbd);
active_tool->preserve = FALSE; active_tool->preserve = FALSE;
} }
static void static void
color_balance_ok_callback (GtkWidget *widget, color_balance_ok_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -605,11 +581,12 @@ color_balance_ok_callback (GtkWidget *widget,
static void static void
color_balance_cancel_callback (GtkWidget *widget, color_balance_cancel_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -629,68 +606,66 @@ color_balance_cancel_callback (GtkWidget *widget,
static void static void
color_balance_shadows_callback (GtkWidget *widget, color_balance_shadows_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_midtones_callback (GtkWidget *widget, color_balance_midtones_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = MIDTONES; cbd->application_mode = MIDTONES;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_highlights_callback (GtkWidget *widget, color_balance_highlights_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = HIGHLIGHTS; cbd->application_mode = HIGHLIGHTS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_preserve_update (GtkWidget *w, color_balance_preserve_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
if (cbd->preview)
color_balance_preview (cbd);
}
else else
{
cbd->preserve_luminosity = FALSE; cbd->preserve_luminosity = FALSE;
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
}
} }
static void static void
color_balance_preview_update (GtkWidget *w, color_balance_preview_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{ {
cbd->preview = TRUE; cbd->preview = TRUE;
color_balance_preview (cbd); color_balance_preview (cbd);
@ -700,7 +675,7 @@ color_balance_preview_update (GtkWidget *w,
} }
static void static void
color_balance_cr_scale_update (GtkAdjustment *adjustment, color_balance_cr_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -710,7 +685,6 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
if (cbd->cyan_red[cbd->application_mode] != adjustment->value) if (cbd->cyan_red[cbd->application_mode] != adjustment->value)
{ {
cbd->cyan_red[cbd->application_mode] = adjustment->value; cbd->cyan_red[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, CR_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -718,7 +692,7 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_mg_scale_update (GtkAdjustment *adjustment, color_balance_mg_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -728,7 +702,6 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
if (cbd->magenta_green[cbd->application_mode] != adjustment->value) if (cbd->magenta_green[cbd->application_mode] != adjustment->value)
{ {
cbd->magenta_green[cbd->application_mode] = adjustment->value; cbd->magenta_green[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, MG_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -736,7 +709,7 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_yb_scale_update (GtkAdjustment *adjustment, color_balance_yb_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -746,73 +719,6 @@ color_balance_yb_scale_update (GtkAdjustment *adjustment,
if (cbd->yellow_blue[cbd->application_mode] != adjustment->value) if (cbd->yellow_blue[cbd->application_mode] != adjustment->value)
{ {
cbd->yellow_blue[cbd->application_mode] = adjustment->value; cbd->yellow_blue[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, YB_TEXT);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_cr_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->cyan_red[cbd->application_mode] != value)
{
cbd->cyan_red[cbd->application_mode] = value;
color_balance_update (cbd, CR_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_mg_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->magenta_green[cbd->application_mode] != value)
{
cbd->magenta_green[cbd->application_mode] = value;
color_balance_update (cbd, MG_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_yb_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->yellow_blue[cbd->application_mode] != value)
{
cbd->yellow_blue[cbd->application_mode] = value;
color_balance_update (cbd, YB_SLIDER);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);

View File

@ -19,6 +19,7 @@
#define __COLOR_BALANCE_H__ #define __COLOR_BALANCE_H__
#include <gtk/gtk.h> #include <gtk/gtk.h>
#include "gimpdrawableF.h" #include "gimpdrawableF.h"
#include "image_map.h" #include "image_map.h"
#include "tools.h" #include "tools.h"
@ -31,12 +32,11 @@ typedef enum
} TransferMode; } TransferMode;
typedef struct _ColorBalanceDialog ColorBalanceDialog; typedef struct _ColorBalanceDialog ColorBalanceDialog;
struct _ColorBalanceDialog struct _ColorBalanceDialog
{ {
GtkWidget *shell; GtkWidget *shell;
GtkWidget *cyan_red_text;
GtkWidget *magenta_green_text;
GtkWidget *yellow_blue_text;
GtkAdjustment *cyan_red_data; GtkAdjustment *cyan_red_data;
GtkAdjustment *magenta_green_data; GtkAdjustment *magenta_green_data;
GtkAdjustment *yellow_blue_data; GtkAdjustment *yellow_blue_data;
@ -44,26 +44,29 @@ struct _ColorBalanceDialog
GimpDrawable *drawable; GimpDrawable *drawable;
ImageMap image_map; ImageMap image_map;
double cyan_red[3]; gdouble cyan_red[3];
double magenta_green[3]; gdouble magenta_green[3];
double yellow_blue[3]; gdouble yellow_blue[3];
guchar r_lookup[256]; guchar r_lookup[256];
guchar g_lookup[256]; guchar g_lookup[256];
guchar b_lookup[256]; guchar b_lookup[256];
gint preserve_luminosity; gboolean preserve_luminosity;
gint preview; gboolean preview;
gint application_mode; TransferMode application_mode;
}; };
/* by_color select functions */ /* color balance functions */
Tool * tools_new_color_balance (void); Tool * tools_new_color_balance (void);
void tools_free_color_balance (Tool *); void tools_free_color_balance (Tool *tool);
void color_balance_initialize (GDisplay *); void color_balance_initialize (GDisplay *gdisp);
void color_balance (PixelRegion *, PixelRegion *, void *); void color_balance (PixelRegion *srcPR,
PixelRegion *destPR,
void *data);
void color_balance_create_lookup_tables (ColorBalanceDialog *); void color_balance_create_lookup_tables (ColorBalanceDialog *cbd);
#endif /* __COLOR_BALANCE_H__ */ #endif /* __COLOR_BALANCE_H__ */

View File

@ -34,22 +34,18 @@
#include "libgimp/gimpintl.h" #include "libgimp/gimpintl.h"
#include "libgimp/gimpmath.h" #include "libgimp/gimpmath.h"
#define TEXT_WIDTH 55 #define CYAN_RED 0x1
#define MAGENTA_GREEN 0x2
#define CR_SLIDER 0x1 #define YELLOW_BLUE 0x4
#define MG_SLIDER 0x2 #define ALL (CYAN_RED | MAGENTA_GREEN | YELLOW_BLUE)
#define YB_SLIDER 0x4
#define CR_TEXT 0x8
#define MG_TEXT 0x10
#define YB_TEXT 0x20
#define ALL 0xFF
/* the color balance structures */ /* the color balance structures */
typedef struct _ColorBalance ColorBalance; typedef struct _ColorBalance ColorBalance;
struct _ColorBalance struct _ColorBalance
{ {
int x, y; /* coords for last mouse click */ gint x, y; /* coords for last mouse click */
}; };
/* the color balance tool options */ /* the color balance tool options */
@ -74,30 +70,26 @@ static void color_balance_midtones_callback (GtkWidget *, gpointer);
static void color_balance_highlights_callback (GtkWidget *, gpointer); static void color_balance_highlights_callback (GtkWidget *, gpointer);
static void color_balance_preserve_update (GtkWidget *, gpointer); static void color_balance_preserve_update (GtkWidget *, gpointer);
static void color_balance_preview_update (GtkWidget *, gpointer); static void color_balance_preview_update (GtkWidget *, gpointer);
static void color_balance_cr_scale_update (GtkAdjustment *, gpointer); static void color_balance_cr_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_mg_scale_update (GtkAdjustment *, gpointer); static void color_balance_mg_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_yb_scale_update (GtkAdjustment *, gpointer); static void color_balance_yb_adjustment_update (GtkAdjustment *, gpointer);
static void color_balance_cr_text_update (GtkWidget *, gpointer);
static void color_balance_mg_text_update (GtkWidget *, gpointer);
static void color_balance_yb_text_update (GtkWidget *, gpointer);
/* color balance machinery */ /* color balance machinery */
void void
color_balance (PixelRegion *srcPR, color_balance (PixelRegion *srcPR,
PixelRegion *destPR, PixelRegion *destPR,
void *user_data) void *data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
unsigned char *src, *s; guchar *src, *s;
unsigned char *dest, *d; guchar *dest, *d;
int alpha; gint alpha;
int r, g, b; gint r, g, b;
int r_n, g_n, b_n; gint r_n, g_n, b_n;
int w, h; gint w, h;
cbd = (ColorBalanceDialog *) user_data; cbd = (ColorBalanceDialog *) data;
h = srcPR->h; h = srcPR->h;
src = srcPR->data; src = srcPR->data;
@ -119,7 +111,6 @@ color_balance (PixelRegion *srcPR,
g_n = cbd->g_lookup[g]; g_n = cbd->g_lookup[g];
b_n = cbd->b_lookup[b]; b_n = cbd->b_lookup[b];
if (cbd->preserve_luminosity) if (cbd->preserve_luminosity)
{ {
rgb_to_hls (&r_n, &g_n, &b_n); rgb_to_hls (&r_n, &g_n, &b_n);
@ -143,8 +134,7 @@ color_balance (PixelRegion *srcPR,
} }
} }
/* color balance action functions */
/* by_color select action functions */
static void static void
color_balance_control (Tool *tool, color_balance_control (Tool *tool,
@ -174,7 +164,7 @@ color_balance_control (Tool *tool,
} }
Tool * Tool *
tools_new_color_balance () tools_new_color_balance (void)
{ {
Tool * tool; Tool * tool;
ColorBalance * private; ColorBalance * private;
@ -216,7 +206,7 @@ tools_free_color_balance (Tool *tool)
void void
color_balance_initialize (GDisplay *gdisp) color_balance_initialize (GDisplay *gdisp)
{ {
int i; gint i;
if (! drawable_color (gimage_active_drawable (gdisp->gimage))) if (! drawable_color (gimage_active_drawable (gdisp->gimage)))
{ {
@ -252,7 +242,7 @@ color_balance_initialize (GDisplay *gdisp)
/**************************/ /**************************/
static ColorBalanceDialog * static ColorBalanceDialog *
color_balance_new_dialog () color_balance_new_dialog (void)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
GtkWidget *vbox; GtkWidget *vbox;
@ -261,6 +251,7 @@ color_balance_new_dialog ()
GtkWidget *start_label; GtkWidget *start_label;
GtkWidget *end_label; GtkWidget *end_label;
GtkWidget *label; GtkWidget *label;
GtkWidget *spinbutton;
GtkWidget *slider; GtkWidget *slider;
GtkWidget *toggle; GtkWidget *toggle;
GtkWidget *radio_button; GtkWidget *radio_button;
@ -282,7 +273,7 @@ color_balance_new_dialog ()
color_balance_highlights_callback color_balance_highlights_callback
}; };
cbd = g_malloc (sizeof (ColorBalanceDialog)); cbd = g_new (ColorBalanceDialog, 1);
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
cbd->preview = TRUE; cbd->preview = TRUE;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
@ -301,47 +292,46 @@ color_balance_new_dialog ()
NULL); NULL);
vbox = gtk_vbox_new (FALSE, 2); vbox = gtk_vbox_new (FALSE, 2);
gtk_container_set_border_width (GTK_CONTAINER (vbox), 2); gtk_container_set_border_width (GTK_CONTAINER (vbox), 4);
gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox); gtk_container_add (GTK_CONTAINER (GTK_DIALOG (cbd->shell)->vbox), vbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
label = gtk_label_new (_("Color Levels: ")); label = gtk_label_new (_("Color Levels:"));
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), label, TRUE, FALSE, 0);
gtk_widget_show (label); gtk_widget_show (label);
/* cyan-red text */ /* cyan-red spinbutton */
cbd->cyan_red_text = gtk_entry_new (); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_set_usize (cbd->cyan_red_text, TEXT_WIDTH, 25); cbd->cyan_red_data = GTK_ADJUSTMENT (data);
gtk_box_pack_start (GTK_BOX (hbox), cbd->cyan_red_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_text), "changed",
(GtkSignalFunc) color_balance_cr_text_update,
cbd);
gtk_widget_show (cbd->cyan_red_text);
/* magenta-green text */ spinbutton = gtk_spin_button_new (cbd->cyan_red_data, 1.0, 0);
cbd->magenta_green_text = gtk_entry_new (); gtk_widget_set_usize (spinbutton, 75, -1);
gtk_widget_set_usize (cbd->magenta_green_text, TEXT_WIDTH, 25); gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (hbox), cbd->magenta_green_text, TRUE, FALSE, 0); gtk_widget_show (spinbutton);
gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_text), "changed",
(GtkSignalFunc) color_balance_mg_text_update, /* magenta-green spinbutton */
cbd); data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
gtk_widget_show (cbd->magenta_green_text); cbd->magenta_green_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->magenta_green_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue spinbutton */
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data);
spinbutton = gtk_spin_button_new (cbd->yellow_blue_data, 1.0, 0);
gtk_widget_set_usize (spinbutton, 75, -1);
gtk_box_pack_start (GTK_BOX (hbox), spinbutton, FALSE, FALSE, 0);
gtk_widget_show (spinbutton);
/* yellow-blue text */
cbd->yellow_blue_text = gtk_entry_new ();
gtk_widget_set_usize (cbd->yellow_blue_text, TEXT_WIDTH, 25);
gtk_box_pack_start (GTK_BOX (hbox), cbd->yellow_blue_text, TRUE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_text), "changed",
(GtkSignalFunc) color_balance_yb_text_update,
cbd);
gtk_widget_show (cbd->yellow_blue_text);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* The table containing sliders */ /* The table containing sliders */
table = gtk_table_new (3, 3, FALSE); table = gtk_table_new (3, 3, FALSE);
gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), table, FALSE, FALSE, 0);
@ -351,9 +341,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 0, 1,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->cyan_red_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->cyan_red_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 0, 1,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -361,9 +350,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->cyan_red_data), "value_changed",
(GtkSignalFunc) color_balance_cr_scale_update, GTK_SIGNAL_FUNC (color_balance_cr_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Red")); end_label = gtk_label_new (_("Red"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 0, 1,
@ -378,9 +368,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 1, 2,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->magenta_green_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->magenta_green_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 1, 2,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -388,9 +377,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->magenta_green_data), "value_changed",
(GtkSignalFunc) color_balance_mg_scale_update, GTK_SIGNAL_FUNC (color_balance_mg_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Green")); end_label = gtk_label_new (_("Green"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 1, 2,
@ -405,9 +395,8 @@ color_balance_new_dialog ()
gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0); gtk_misc_set_alignment (GTK_MISC (start_label), 1.0, 1.0);
gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3, gtk_table_attach (GTK_TABLE (table), start_label, 0, 1, 2, 3,
GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2); GTK_SHRINK | GTK_FILL, GTK_SHRINK | GTK_FILL, 2, 2);
data = gtk_adjustment_new (0, -100.0, 100.0, 1.0, 1.0, 0.0);
cbd->yellow_blue_data = GTK_ADJUSTMENT (data); slider = gtk_hscale_new (cbd->yellow_blue_data);
slider = gtk_hscale_new (GTK_ADJUSTMENT (data));
gtk_scale_set_digits (GTK_SCALE (slider), 0); gtk_scale_set_digits (GTK_SCALE (slider), 0);
gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3, gtk_table_attach (GTK_TABLE (table), slider, 1, 2, 2, 3,
GTK_EXPAND | GTK_SHRINK | GTK_FILL, GTK_EXPAND | GTK_SHRINK | GTK_FILL,
@ -415,9 +404,10 @@ color_balance_new_dialog ()
2, 2); 2, 2);
gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP); gtk_scale_set_value_pos (GTK_SCALE (slider), GTK_POS_TOP);
gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED); gtk_range_set_update_policy (GTK_RANGE (slider), GTK_UPDATE_DELAYED);
gtk_signal_connect (GTK_OBJECT (data), "value_changed", gtk_signal_connect (GTK_OBJECT (cbd->yellow_blue_data), "value_changed",
(GtkSignalFunc) color_balance_yb_scale_update, GTK_SIGNAL_FUNC (color_balance_yb_adjustment_update),
cbd); cbd);
end_label = gtk_label_new (_("Blue")); end_label = gtk_label_new (_("Blue"));
gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0); gtk_misc_set_alignment (GTK_MISC (end_label), 0.0, 1.0);
gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3, gtk_table_attach (GTK_TABLE (table), end_label, 2, 3, 2, 3,
@ -428,40 +418,42 @@ color_balance_new_dialog ()
gtk_widget_show (slider); gtk_widget_show (slider);
/* Horizontal box for preview and preserve luminosity toggle buttons */ /* Horizontal box for preview and preserve luminosity toggle buttons */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* The preview toggle */ /* The preview toggle */
toggle = gtk_check_button_new_with_label (_("Preview")); toggle = gtk_check_button_new_with_label (_("Preview"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preview);
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preview_update, GTK_SIGNAL_FUNC (color_balance_preview_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
/* The preserve luminosity toggle */ /* The preserve luminosity toggle */
toggle = gtk_check_button_new_with_label (_("Preserve Luminosity")); toggle = gtk_check_button_new_with_label (_("Preserve Luminosity"));
gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), cbd->preserve_luminosity); gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle),
gtk_box_pack_start (GTK_BOX (hbox), toggle, TRUE, FALSE, 0); cbd->preserve_luminosity);
gtk_box_pack_start (GTK_BOX (hbox), toggle, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (toggle), "toggled", gtk_signal_connect (GTK_OBJECT (toggle), "toggled",
(GtkSignalFunc) color_balance_preserve_update, GTK_SIGNAL_FUNC (color_balance_preserve_update),
cbd); cbd);
gtk_widget_show (toggle); gtk_widget_show (toggle);
gtk_widget_show (hbox); gtk_widget_show (hbox);
/* Horizontal box for application mode */ /* Horizontal box for application mode */
hbox = gtk_hbox_new (TRUE, 2); hbox = gtk_hbox_new (TRUE, 4);
gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (vbox), hbox, FALSE, FALSE, 0);
/* the radio buttons for application mode */ /* the radio buttons for application mode */
for (i = 0; i < 3; i++) for (i = 0; i < 3; i++)
{ {
radio_button = gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i])); radio_button =
gtk_radio_button_new_with_label (group, gettext (appl_mode_names[i]));
group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button)); group = gtk_radio_button_group (GTK_RADIO_BUTTON (radio_button));
gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0); gtk_box_pack_start (GTK_BOX (hbox), radio_button, FALSE, FALSE, 0);
gtk_signal_connect (GTK_OBJECT (radio_button), "toggled", gtk_signal_connect (GTK_OBJECT (radio_button), "toggled",
(GtkSignalFunc) appl_mode_callbacks[i], GTK_SIGNAL_FUNC (appl_mode_callbacks[i]),
cbd); cbd);
gtk_widget_show (radio_button); gtk_widget_show (radio_button);
} }
@ -476,50 +468,34 @@ color_balance_new_dialog ()
static void static void
color_balance_update (ColorBalanceDialog *cbd, color_balance_update (ColorBalanceDialog *cbd,
int update) gint update)
{ {
char text[12]; if (update & CYAN_RED)
if (update & CR_SLIDER)
{ {
cbd->cyan_red_data->value = cbd->cyan_red[cbd->application_mode]; gtk_adjustment_set_value (cbd->cyan_red_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->cyan_red_data), "value_changed"); cbd->cyan_red[cbd->application_mode]);
} }
if (update & MG_SLIDER) if (update & MAGENTA_GREEN)
{ {
cbd->magenta_green_data->value = cbd->magenta_green[cbd->application_mode]; gtk_adjustment_set_value (cbd->magenta_green_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->magenta_green_data), "value_changed"); cbd->magenta_green[cbd->application_mode]);
} }
if (update & YB_SLIDER) if (update & YELLOW_BLUE)
{ {
cbd->yellow_blue_data->value = cbd->yellow_blue[cbd->application_mode]; gtk_adjustment_set_value (cbd->yellow_blue_data,
gtk_signal_emit_by_name (GTK_OBJECT (cbd->yellow_blue_data), "value_changed"); cbd->yellow_blue[cbd->application_mode]);
}
if (update & CR_TEXT)
{
sprintf (text, "%0.0f", cbd->cyan_red[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->cyan_red_text), text);
}
if (update & MG_TEXT)
{
sprintf (text, "%0.0f", cbd->magenta_green[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->magenta_green_text), text);
}
if (update & YB_TEXT)
{
sprintf (text, "%0.0f", cbd->yellow_blue[cbd->application_mode]);
gtk_entry_set_text (GTK_ENTRY (cbd->yellow_blue_text), text);
} }
} }
void void
color_balance_create_lookup_tables (ColorBalanceDialog *cbd) color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
{ {
double *cyan_red_transfer[3]; gdouble *cyan_red_transfer[3];
double *magenta_green_transfer[3]; gdouble *magenta_green_transfer[3];
double *yellow_blue_transfer[3]; gdouble *yellow_blue_transfer[3];
int i; gint i;
gint32 r_n, g_n, b_n; gint32 r_n, g_n, b_n;
/* Set the transfer arrays (for speed) */ /* Set the transfer arrays (for speed) */
cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub; cyan_red_transfer[SHADOWS] = (cbd->cyan_red[SHADOWS] > 0) ? shadows_add : shadows_sub;
cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub; cyan_red_transfer[MIDTONES] = (cbd->cyan_red[MIDTONES] > 0) ? midtones_add : midtones_sub;
@ -562,7 +538,6 @@ color_balance_create_lookup_tables (ColorBalanceDialog *cbd)
cbd->g_lookup[i] = g_n; cbd->g_lookup[i] = g_n;
cbd->b_lookup[i] = b_n; cbd->b_lookup[i] = b_n;
} }
} }
static void static void
@ -570,19 +545,20 @@ color_balance_preview (ColorBalanceDialog *cbd)
{ {
if (!cbd->image_map) if (!cbd->image_map)
g_message ("color_balance_preview(): No image map"); g_message ("color_balance_preview(): No image map");
active_tool->preserve = TRUE; active_tool->preserve = TRUE;
color_balance_create_lookup_tables(cbd); color_balance_create_lookup_tables (cbd);
image_map_apply (cbd->image_map, color_balance, (void *) cbd); image_map_apply (cbd->image_map, color_balance, (void *) cbd);
active_tool->preserve = FALSE; active_tool->preserve = FALSE;
} }
static void static void
color_balance_ok_callback (GtkWidget *widget, color_balance_ok_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -605,11 +581,12 @@ color_balance_ok_callback (GtkWidget *widget,
static void static void
color_balance_cancel_callback (GtkWidget *widget, color_balance_cancel_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
if (GTK_WIDGET_VISIBLE (cbd->shell)) if (GTK_WIDGET_VISIBLE (cbd->shell))
gtk_widget_hide (cbd->shell); gtk_widget_hide (cbd->shell);
@ -629,68 +606,66 @@ color_balance_cancel_callback (GtkWidget *widget,
static void static void
color_balance_shadows_callback (GtkWidget *widget, color_balance_shadows_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = SHADOWS; cbd->application_mode = SHADOWS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_midtones_callback (GtkWidget *widget, color_balance_midtones_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = MIDTONES; cbd->application_mode = MIDTONES;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_highlights_callback (GtkWidget *widget, color_balance_highlights_callback (GtkWidget *widget,
gpointer client_data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) client_data; cbd = (ColorBalanceDialog *) data;
cbd->application_mode = HIGHLIGHTS; cbd->application_mode = HIGHLIGHTS;
color_balance_update (cbd, ALL); color_balance_update (cbd, ALL);
} }
static void static void
color_balance_preserve_update (GtkWidget *w, color_balance_preserve_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{
cbd->preserve_luminosity = TRUE; cbd->preserve_luminosity = TRUE;
if (cbd->preview)
color_balance_preview (cbd);
}
else else
{
cbd->preserve_luminosity = FALSE; cbd->preserve_luminosity = FALSE;
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
}
} }
static void static void
color_balance_preview_update (GtkWidget *w, color_balance_preview_update (GtkWidget *widget,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
cbd = (ColorBalanceDialog *) data; cbd = (ColorBalanceDialog *) data;
if (GTK_TOGGLE_BUTTON (w)->active) if (GTK_TOGGLE_BUTTON (widget)->active)
{ {
cbd->preview = TRUE; cbd->preview = TRUE;
color_balance_preview (cbd); color_balance_preview (cbd);
@ -700,7 +675,7 @@ color_balance_preview_update (GtkWidget *w,
} }
static void static void
color_balance_cr_scale_update (GtkAdjustment *adjustment, color_balance_cr_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -710,7 +685,6 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
if (cbd->cyan_red[cbd->application_mode] != adjustment->value) if (cbd->cyan_red[cbd->application_mode] != adjustment->value)
{ {
cbd->cyan_red[cbd->application_mode] = adjustment->value; cbd->cyan_red[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, CR_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -718,7 +692,7 @@ color_balance_cr_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_mg_scale_update (GtkAdjustment *adjustment, color_balance_mg_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -728,7 +702,6 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
if (cbd->magenta_green[cbd->application_mode] != adjustment->value) if (cbd->magenta_green[cbd->application_mode] != adjustment->value)
{ {
cbd->magenta_green[cbd->application_mode] = adjustment->value; cbd->magenta_green[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, MG_TEXT);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);
@ -736,7 +709,7 @@ color_balance_mg_scale_update (GtkAdjustment *adjustment,
} }
static void static void
color_balance_yb_scale_update (GtkAdjustment *adjustment, color_balance_yb_adjustment_update (GtkAdjustment *adjustment,
gpointer data) gpointer data)
{ {
ColorBalanceDialog *cbd; ColorBalanceDialog *cbd;
@ -746,73 +719,6 @@ color_balance_yb_scale_update (GtkAdjustment *adjustment,
if (cbd->yellow_blue[cbd->application_mode] != adjustment->value) if (cbd->yellow_blue[cbd->application_mode] != adjustment->value)
{ {
cbd->yellow_blue[cbd->application_mode] = adjustment->value; cbd->yellow_blue[cbd->application_mode] = adjustment->value;
color_balance_update (cbd, YB_TEXT);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_cr_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->cyan_red[cbd->application_mode] != value)
{
cbd->cyan_red[cbd->application_mode] = value;
color_balance_update (cbd, CR_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_mg_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->magenta_green[cbd->application_mode] != value)
{
cbd->magenta_green[cbd->application_mode] = value;
color_balance_update (cbd, MG_SLIDER);
if (cbd->preview)
color_balance_preview (cbd);
}
}
static void
color_balance_yb_text_update (GtkWidget *w,
gpointer data)
{
ColorBalanceDialog *cbd;
char *str;
int value;
str = gtk_entry_get_text (GTK_ENTRY (w));
cbd = (ColorBalanceDialog *) data;
value = BOUNDS (((int) atof (str)), -100, 100);
if ((int) cbd->yellow_blue[cbd->application_mode] != value)
{
cbd->yellow_blue[cbd->application_mode] = value;
color_balance_update (cbd, YB_SLIDER);
if (cbd->preview) if (cbd->preview)
color_balance_preview (cbd); color_balance_preview (cbd);

View File

@ -19,6 +19,7 @@
#define __COLOR_BALANCE_H__ #define __COLOR_BALANCE_H__
#include <gtk/gtk.h> #include <gtk/gtk.h>
#include "gimpdrawableF.h" #include "gimpdrawableF.h"
#include "image_map.h" #include "image_map.h"
#include "tools.h" #include "tools.h"
@ -31,12 +32,11 @@ typedef enum
} TransferMode; } TransferMode;
typedef struct _ColorBalanceDialog ColorBalanceDialog; typedef struct _ColorBalanceDialog ColorBalanceDialog;
struct _ColorBalanceDialog struct _ColorBalanceDialog
{ {
GtkWidget *shell; GtkWidget *shell;
GtkWidget *cyan_red_text;
GtkWidget *magenta_green_text;
GtkWidget *yellow_blue_text;
GtkAdjustment *cyan_red_data; GtkAdjustment *cyan_red_data;
GtkAdjustment *magenta_green_data; GtkAdjustment *magenta_green_data;
GtkAdjustment *yellow_blue_data; GtkAdjustment *yellow_blue_data;
@ -44,26 +44,29 @@ struct _ColorBalanceDialog
GimpDrawable *drawable; GimpDrawable *drawable;
ImageMap image_map; ImageMap image_map;
double cyan_red[3]; gdouble cyan_red[3];
double magenta_green[3]; gdouble magenta_green[3];
double yellow_blue[3]; gdouble yellow_blue[3];
guchar r_lookup[256]; guchar r_lookup[256];
guchar g_lookup[256]; guchar g_lookup[256];
guchar b_lookup[256]; guchar b_lookup[256];
gint preserve_luminosity; gboolean preserve_luminosity;
gint preview; gboolean preview;
gint application_mode; TransferMode application_mode;
}; };
/* by_color select functions */ /* color balance functions */
Tool * tools_new_color_balance (void); Tool * tools_new_color_balance (void);
void tools_free_color_balance (Tool *); void tools_free_color_balance (Tool *tool);
void color_balance_initialize (GDisplay *); void color_balance_initialize (GDisplay *gdisp);
void color_balance (PixelRegion *, PixelRegion *, void *); void color_balance (PixelRegion *srcPR,
PixelRegion *destPR,
void *data);
void color_balance_create_lookup_tables (ColorBalanceDialog *); void color_balance_create_lookup_tables (ColorBalanceDialog *cbd);
#endif /* __COLOR_BALANCE_H__ */ #endif /* __COLOR_BALANCE_H__ */

View File

@ -18,7 +18,6 @@
#include "config.h" #include "config.h"
#include <string.h> #include <string.h>
#include <stdio.h>
#include "appenv.h" #include "appenv.h"
#include "devices.h" #include "devices.h"
@ -1048,7 +1047,7 @@ device_status_update (guint32 deviceid)
gtk_widget_show (deviceD->colors[i]); gtk_widget_show (deviceD->colors[i]);
/* Set the tip to be the RGB value */ /* Set the tip to be the RGB value */
sprintf (ttbuf, "[%3d,%3d,%3d]", g_snprintf (ttbuf, sizeof (ttbuf), "[%3d,%3d,%3d]",
buffer[j], buffer[j],
buffer[j+1], buffer[j+1],
buffer[j+2]); buffer[j+2]);

View File

@ -18,7 +18,6 @@
#include "config.h" #include "config.h"
#include <string.h> #include <string.h>
#include <stdio.h>
#include "appenv.h" #include "appenv.h"
#include "devices.h" #include "devices.h"
@ -1048,7 +1047,7 @@ device_status_update (guint32 deviceid)
gtk_widget_show (deviceD->colors[i]); gtk_widget_show (deviceD->colors[i]);
/* Set the tip to be the RGB value */ /* Set the tip to be the RGB value */
sprintf (ttbuf, "[%3d,%3d,%3d]", g_snprintf (ttbuf, sizeof (ttbuf), "[%3d,%3d,%3d]",
buffer[j], buffer[j],
buffer[j+1], buffer[j+1],
buffer[j+2]); buffer[j+2]);