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:

committed by
Michael Natterer

parent
40606d9461
commit
e5aad8b85b
@ -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
|
||||||
|
@ -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);
|
||||||
|
@ -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__ */
|
||||||
|
@ -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);
|
||||||
|
@ -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__ */
|
||||||
|
@ -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]);
|
||||||
|
@ -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]);
|
||||||
|
@ -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]);
|
||||||
|
@ -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);
|
||||||
|
@ -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__ */
|
||||||
|
@ -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);
|
||||||
|
@ -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__ */
|
||||||
|
@ -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]);
|
||||||
|
@ -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]);
|
||||||
|
Reference in New Issue
Block a user