summaryrefslogtreecommitdiff
path: root/gtk
diff options
context:
space:
mode:
authorHavoc Pennington <hp@redhat.com>2001-02-19 22:25:30 +0000
committerHavoc Pennington <hp@src.gnome.org>2001-02-19 22:25:30 +0000
commitf4fa22da5524e90e70a14b9630d810b23d0b520e (patch)
tree2118721fb1b3fd3f74e5427315266c1d94dda7cf /gtk
parent6fb6363e3013d67e19b9e2b1e5b9d1a3c8f67494 (diff)
downloadgtk+-f4fa22da5524e90e70a14b9630d810b23d0b520e.tar.gz
test was backward, so deprecated functions were excluded by default
2001-02-19 Havoc Pennington <hp@redhat.com> * gdk/gdkcolor.h: test was backward, so deprecated functions were excluded by default * gtk/gtkstyle.c (gtk_default_draw_diamond): draw etched in/out, clean up the old code a bit * gtk/gtkradiobutton.c (gtk_radio_button_draw_indicator): draw inconsistent state * gtk/gtkradiomenuitem.c (gtk_radio_menu_item_draw_indicator): draw inconsistent state * gtk/testgtk.c (create_toggle_buttons): add test for inconsistent (create_menu): add inconsistent test * gtk/gtkcheckmenuitem.c (gtk_check_menu_item_set_inconsistent): new function (gtk_check_menu_item_get_inconsistent): new function (gtk_real_check_menu_item_draw_indicator): draw the inconsistent state (using etched in for now) * gtk/gtkcheckbutton.c (gtk_real_check_button_draw_indicator): draw inconsistent state * gtk/gtktogglebutton.c (gtk_toggle_button_set_inconsistent): new function, used when the user has selected a range of stuff in different states (gtk_toggle_button_get_inconsistent): accessor for that (gtk_toggle_button_paint): draw inconsistent state (etched in? don't know what else to do)
Diffstat (limited to 'gtk')
-rw-r--r--gtk/gtkcheckbutton.c9
-rw-r--r--gtk/gtkcheckmenuitem.c55
-rw-r--r--gtk/gtkcheckmenuitem.h5
-rw-r--r--gtk/gtkradiobutton.c3
-rw-r--r--gtk/gtkradiomenuitem.c3
-rw-r--r--gtk/gtkstyle.c120
-rw-r--r--gtk/gtktogglebutton.c60
-rw-r--r--gtk/gtktogglebutton.h4
-rw-r--r--gtk/testgtk.c21
9 files changed, 221 insertions, 59 deletions
diff --git a/gtk/gtkcheckbutton.c b/gtk/gtkcheckbutton.c
index 681082d7ec..dc92a23c8d 100644
--- a/gtk/gtkcheckbutton.c
+++ b/gtk/gtkcheckbutton.c
@@ -356,8 +356,13 @@ gtk_real_check_button_draw_indicator (GtkCheckButton *check_button,
y = widget->allocation.y + (widget->allocation.height - GTK_CHECK_BUTTON_GET_CLASS (widget)->indicator_size) / 2;
width = GTK_CHECK_BUTTON_GET_CLASS (widget)->indicator_size;
height = GTK_CHECK_BUTTON_GET_CLASS (widget)->indicator_size;
-
- if (GTK_TOGGLE_BUTTON (widget)->active)
+
+ if (GTK_TOGGLE_BUTTON (widget)->inconsistent)
+ {
+ state_type = GTK_WIDGET_STATE (widget) == GTK_STATE_ACTIVE ? GTK_STATE_NORMAL : GTK_WIDGET_STATE (widget);
+ shadow_type = GTK_SHADOW_ETCHED_IN;
+ }
+ else if (GTK_TOGGLE_BUTTON (widget)->active)
{
state_type = GTK_STATE_ACTIVE;
shadow_type = GTK_SHADOW_IN;
diff --git a/gtk/gtkcheckmenuitem.c b/gtk/gtkcheckmenuitem.c
index 09b37baf79..a7cabb7361 100644
--- a/gtk/gtkcheckmenuitem.c
+++ b/gtk/gtkcheckmenuitem.c
@@ -173,6 +173,52 @@ gtk_check_menu_item_toggled (GtkCheckMenuItem *check_menu_item)
gtk_signal_emit (GTK_OBJECT (check_menu_item), check_menu_item_signals[TOGGLED]);
}
+/**
+ * gtk_check_menu_item_set_inconsistent:
+ * @check_menu_item: a #GtkCheckMenuItem
+ * @setting: %TRUE to display an "inconsistent" third state check
+ *
+ * If the user has selected a range of elements (such as some text or
+ * spreadsheet cells) that are affected by a boolean setting, and the
+ * current values in that range are inconsistent, you may want to
+ * display the check in an "in between" state. This function turns on
+ * "in between" display. Normally you would turn off the inconsistent
+ * state again if the user explicitly selects a setting. This has to be
+ * done manually, gtk_check_menu_item_set_inconsistent() only affects
+ * visual appearance, it doesn't affect the semantics of the widget.
+ *
+ **/
+void
+gtk_check_menu_item_set_inconsistent (GtkCheckMenuItem *check_menu_item,
+ gboolean setting)
+{
+ g_return_if_fail (GTK_IS_CHECK_MENU_ITEM (check_menu_item));
+
+ setting = setting != FALSE;
+
+ if (setting != check_menu_item->inconsistent)
+ {
+ check_menu_item->inconsistent = setting;
+ gtk_widget_queue_draw (GTK_WIDGET (check_menu_item));
+ }
+}
+
+/**
+ * gtk_check_menu_item_get_inconsistent:
+ * @check_menu_item: a #GtkCheckMenuItem
+ *
+ * Retrieves the value set by gtk_check_menu_item_set_inconsistent().
+ *
+ * Return value: %TRUE if inconsistent
+ **/
+gboolean
+gtk_check_menu_item_get_inconsistent (GtkCheckMenuItem *check_menu_item)
+{
+ g_return_val_if_fail (GTK_IS_CHECK_MENU_ITEM (check_menu_item), FALSE);
+
+ return check_menu_item->inconsistent;
+}
+
static void
gtk_check_menu_item_init (GtkCheckMenuItem *check_menu_item)
{
@@ -265,7 +311,14 @@ gtk_real_check_menu_item_draw_indicator (GtkCheckMenuItem *check_menu_item,
(state_type == GTK_STATE_PRELIGHT))
shadow_type = GTK_SHADOW_OUT;
}
-
+
+ if (check_menu_item->inconsistent)
+ {
+ shadow_type = GTK_SHADOW_ETCHED_IN;
+ if (state_type == GTK_STATE_ACTIVE)
+ state_type = GTK_STATE_NORMAL;
+ }
+
gtk_paint_check (widget->style, widget->window,
state_type, shadow_type,
area, widget, "check",
diff --git a/gtk/gtkcheckmenuitem.h b/gtk/gtkcheckmenuitem.h
index 4142fe9030..010088c366 100644
--- a/gtk/gtkcheckmenuitem.h
+++ b/gtk/gtkcheckmenuitem.h
@@ -54,6 +54,7 @@ struct _GtkCheckMenuItem
guint active : 1;
guint always_show_toggle : 1;
+ guint inconsistent : 1;
};
struct _GtkCheckMenuItemClass
@@ -75,6 +76,10 @@ void gtk_check_menu_item_set_show_toggle (GtkCheckMenuItem *menu_item,
gboolean always);
void gtk_check_menu_item_toggled (GtkCheckMenuItem *check_menu_item);
+void gtk_check_menu_item_set_inconsistent (GtkCheckMenuItem *check_menu_item,
+ gboolean setting);
+gboolean gtk_check_menu_item_get_inconsistent (GtkCheckMenuItem *check_menu_item);
+
#ifdef __cplusplus
}
diff --git a/gtk/gtkradiobutton.c b/gtk/gtkradiobutton.c
index 093993aea7..e231f51f95 100644
--- a/gtk/gtkradiobutton.c
+++ b/gtk/gtkradiobutton.c
@@ -416,6 +416,9 @@ gtk_radio_button_draw_indicator (GtkCheckButton *check_button,
shadow_type = GTK_SHADOW_IN;
else
shadow_type = GTK_SHADOW_OUT;
+
+ if (GTK_TOGGLE_BUTTON (widget)->inconsistent)
+ shadow_type = GTK_SHADOW_ETCHED_IN;
if (gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL)
x = widget->allocation.x + widget->allocation.width - (width + x - widget->allocation.x);
diff --git a/gtk/gtkradiomenuitem.c b/gtk/gtkradiomenuitem.c
index a8b2ac3207..27db681dcb 100644
--- a/gtk/gtkradiomenuitem.c
+++ b/gtk/gtkradiomenuitem.c
@@ -298,6 +298,9 @@ gtk_radio_menu_item_draw_indicator (GtkCheckMenuItem *check_menu_item,
else
shadow_type = GTK_SHADOW_OUT;
+ if (check_menu_item->inconsistent)
+ shadow_type = GTK_SHADOW_ETCHED_IN;
+
gtk_paint_option (widget->style, widget->window,
state_type, shadow_type,
area, widget, "option",
diff --git a/gtk/gtkstyle.c b/gtk/gtkstyle.c
index 3469c74cdc..20013e4f56 100644
--- a/gtk/gtkstyle.c
+++ b/gtk/gtkstyle.c
@@ -2229,6 +2229,18 @@ gtk_default_draw_diamond (GtkStyle *style,
{
gint half_width;
gint half_height;
+ GdkGC *outer_nw = NULL;
+ GdkGC *outer_ne = NULL;
+ GdkGC *outer_sw = NULL;
+ GdkGC *outer_se = NULL;
+ GdkGC *middle_nw = NULL;
+ GdkGC *middle_ne = NULL;
+ GdkGC *middle_sw = NULL;
+ GdkGC *middle_se = NULL;
+ GdkGC *inner_nw = NULL;
+ GdkGC *inner_ne = NULL;
+ GdkGC *inner_sw = NULL;
+ GdkGC *inner_se = NULL;
g_return_if_fail (GTK_IS_STYLE (style));
g_return_if_fail (window != NULL);
@@ -2250,89 +2262,91 @@ gtk_default_draw_diamond (GtkStyle *style,
gdk_gc_set_clip_rectangle (style->dark_gc[state_type], area);
gdk_gc_set_clip_rectangle (style->black_gc, area);
}
+
switch (shadow_type)
{
case GTK_SHADOW_IN:
- gdk_draw_line (window, style->bg_gc[state_type],
- x + 2, y + half_height,
- x + half_width, y + height - 2);
- gdk_draw_line (window, style->bg_gc[state_type],
- x + half_width, y + height - 2,
- x + width - 2, y + half_height);
- gdk_draw_line (window, style->light_gc[state_type],
- x + 1, y + half_height,
- x + half_width, y + height - 1);
- gdk_draw_line (window, style->light_gc[state_type],
- x + half_width, y + height - 1,
- x + width - 1, y + half_height);
- gdk_draw_line (window, style->light_gc[state_type],
- x, y + half_height,
- x + half_width, y + height);
- gdk_draw_line (window, style->light_gc[state_type],
- x + half_width, y + height,
- x + width, y + half_height);
-
- gdk_draw_line (window, style->black_gc,
- x + 2, y + half_height,
- x + half_width, y + 2);
- gdk_draw_line (window, style->black_gc,
- x + half_width, y + 2,
- x + width - 2, y + half_height);
- gdk_draw_line (window, style->dark_gc[state_type],
- x + 1, y + half_height,
- x + half_width, y + 1);
- gdk_draw_line (window, style->dark_gc[state_type],
- x + half_width, y + 1,
- x + width - 1, y + half_height);
- gdk_draw_line (window, style->dark_gc[state_type],
- x, y + half_height,
- x + half_width, y);
- gdk_draw_line (window, style->dark_gc[state_type],
- x + half_width, y,
- x + width, y + half_height);
+ inner_sw = inner_se = style->bg_gc[state_type];
+ middle_sw = middle_se = style->light_gc[state_type];
+ outer_sw = outer_se = style->light_gc[state_type];
+ inner_nw = inner_ne = style->black_gc;
+ middle_nw = middle_ne = style->dark_gc[state_type];
+ outer_nw = outer_ne = style->dark_gc[state_type];
break;
+
case GTK_SHADOW_OUT:
- gdk_draw_line (window, style->dark_gc[state_type],
+ inner_sw = inner_se = style->dark_gc[state_type];
+ middle_sw = middle_se = style->dark_gc[state_type];
+ outer_sw = outer_se = style->black_gc;
+ inner_nw = inner_ne = style->bg_gc[state_type];
+ middle_nw = middle_ne = style->light_gc[state_type];
+ outer_nw = outer_ne = style->light_gc[state_type];
+ break;
+
+ case GTK_SHADOW_ETCHED_IN:
+ inner_sw = inner_se = style->bg_gc[state_type];
+ middle_sw = middle_se = style->dark_gc[state_type];
+ outer_sw = outer_se = style->light_gc[state_type];
+ inner_nw = inner_ne = style->bg_gc[state_type];
+ middle_nw = middle_ne = style->light_gc[state_type];
+ outer_nw = outer_ne = style->dark_gc[state_type];
+ break;
+
+ case GTK_SHADOW_ETCHED_OUT:
+ inner_sw = inner_se = style->bg_gc[state_type];
+ middle_sw = middle_se = style->light_gc[state_type];
+ outer_sw = outer_se = style->dark_gc[state_type];
+ inner_nw = inner_ne = style->bg_gc[state_type];
+ middle_nw = middle_ne = style->dark_gc[state_type];
+ outer_nw = outer_ne = style->light_gc[state_type];
+ break;
+
+ default:
+
+ break;
+ }
+
+ if (inner_sw)
+ {
+ gdk_draw_line (window, inner_sw,
x + 2, y + half_height,
x + half_width, y + height - 2);
- gdk_draw_line (window, style->dark_gc[state_type],
+ gdk_draw_line (window, inner_se,
x + half_width, y + height - 2,
x + width - 2, y + half_height);
- gdk_draw_line (window, style->dark_gc[state_type],
+ gdk_draw_line (window, middle_sw,
x + 1, y + half_height,
x + half_width, y + height - 1);
- gdk_draw_line (window, style->dark_gc[state_type],
+ gdk_draw_line (window, middle_se,
x + half_width, y + height - 1,
x + width - 1, y + half_height);
- gdk_draw_line (window, style->black_gc,
+ gdk_draw_line (window, outer_sw,
x, y + half_height,
x + half_width, y + height);
- gdk_draw_line (window, style->black_gc,
+ gdk_draw_line (window, outer_se,
x + half_width, y + height,
x + width, y + half_height);
-
- gdk_draw_line (window, style->bg_gc[state_type],
+
+ gdk_draw_line (window, inner_nw,
x + 2, y + half_height,
x + half_width, y + 2);
- gdk_draw_line (window, style->bg_gc[state_type],
+ gdk_draw_line (window, inner_ne,
x + half_width, y + 2,
x + width - 2, y + half_height);
- gdk_draw_line (window, style->light_gc[state_type],
+ gdk_draw_line (window, middle_nw,
x + 1, y + half_height,
x + half_width, y + 1);
- gdk_draw_line (window, style->light_gc[state_type],
+ gdk_draw_line (window, middle_ne,
x + half_width, y + 1,
x + width - 1, y + half_height);
- gdk_draw_line (window, style->light_gc[state_type],
+ gdk_draw_line (window, outer_nw,
x, y + half_height,
x + half_width, y);
- gdk_draw_line (window, style->light_gc[state_type],
+ gdk_draw_line (window, outer_ne,
x + half_width, y,
x + width, y + half_height);
- break;
- default:
- break;
}
+
if (area)
{
gdk_gc_set_clip_rectangle (style->light_gc[state_type], NULL);
diff --git a/gtk/gtktogglebutton.c b/gtk/gtktogglebutton.c
index c1bb468562..e51ee8400f 100644
--- a/gtk/gtktogglebutton.c
+++ b/gtk/gtktogglebutton.c
@@ -305,6 +305,51 @@ gtk_toggle_button_toggled (GtkToggleButton *toggle_button)
gtk_signal_emit (GTK_OBJECT (toggle_button), toggle_button_signals[TOGGLED]);
}
+/**
+ * gtk_toggle_button_set_inconsistent:
+ * @toggle_button: a #GtkToggleButton
+ * @setting: %TRUE if state is inconsistent
+ *
+ * If the user has selected a range of elements (such as some text or
+ * spreadsheet cells) that are affected by a toggle button, and the
+ * current values in that range are inconsistent, you may want to
+ * display the toggle in an "in between" state. This function turns on
+ * "in between" display. Normally you would turn off the inconsistent
+ * state again if the user toggles the toggle button. This has to be
+ * done manually, gtk_toggle_button_set_inconsistent() only affects
+ * visual appearance, it doesn't affect the semantics of the button.
+ *
+ **/
+void
+gtk_toggle_button_set_inconsistent (GtkToggleButton *toggle_button,
+ gboolean setting)
+{
+ g_return_if_fail (GTK_IS_TOGGLE_BUTTON (toggle_button));
+
+ setting = setting != FALSE;
+
+ if (setting != toggle_button->inconsistent)
+ {
+ toggle_button->inconsistent = setting;
+ gtk_widget_queue_draw (GTK_WIDGET (toggle_button));
+ }
+}
+
+/**
+ * gtk_toggle_button_get_inconsistent:
+ * @toggle_button: a #GtkToggleButton
+ *
+ * Gets the value set by gtk_toggle_button_set_inconsistent().
+ *
+ * Return value: %TRUE if the button is displayed as inconsistent, %FALSE otherwise
+ **/
+gboolean
+gtk_toggle_button_get_inconsistent (GtkToggleButton *toggle_button)
+{
+ g_return_val_if_fail (GTK_IS_TOGGLE_BUTTON (toggle_button), FALSE);
+
+ return toggle_button->inconsistent;
+}
static void
gtk_toggle_button_paint (GtkWidget *widget,
@@ -313,6 +358,7 @@ gtk_toggle_button_paint (GtkWidget *widget,
GtkButton *button;
GtkToggleButton *toggle_button;
GtkShadowType shadow_type;
+ GtkStateType state_type;
gint width, height;
gint x, y;
@@ -356,9 +402,17 @@ gtk_toggle_button_paint (GtkWidget *widget,
height -= 2;
}
- if ((GTK_WIDGET_STATE (widget) == GTK_STATE_ACTIVE) ||
+ state_type = GTK_WIDGET_STATE (widget);
+
+ if (toggle_button->inconsistent)
+ {
+ if (state_type == GTK_STATE_ACTIVE)
+ state_type = GTK_STATE_NORMAL;
+ shadow_type = GTK_SHADOW_ETCHED_IN;
+ }
+ else if ((GTK_WIDGET_STATE (widget) == GTK_STATE_ACTIVE) ||
toggle_button->active)
- shadow_type = GTK_SHADOW_IN;
+ shadow_type = GTK_SHADOW_IN;
else
shadow_type = GTK_SHADOW_OUT;
@@ -366,7 +420,7 @@ gtk_toggle_button_paint (GtkWidget *widget,
(GTK_WIDGET_STATE(widget) != GTK_STATE_NORMAL &&
GTK_WIDGET_STATE(widget) != GTK_STATE_INSENSITIVE))
gtk_paint_box (widget->style, widget->window,
- GTK_WIDGET_STATE (widget),
+ state_type,
shadow_type, area, widget, "togglebutton",
x, y, width, height);
diff --git a/gtk/gtktogglebutton.h b/gtk/gtktogglebutton.h
index def107e5ac..c00b98bad5 100644
--- a/gtk/gtktogglebutton.h
+++ b/gtk/gtktogglebutton.h
@@ -54,6 +54,7 @@ struct _GtkToggleButton
guint active : 1;
guint draw_indicator : 1;
+ guint inconsistent : 1;
GdkWindow *event_window;
};
@@ -76,6 +77,9 @@ void gtk_toggle_button_set_active (GtkToggleButton *toggle_button,
gboolean gtk_toggle_button_get_active (GtkToggleButton *toggle_button);
void gtk_toggle_button_toggled (GtkToggleButton *toggle_button);
+void gtk_toggle_button_set_inconsistent (GtkToggleButton *toggle_button,
+ gboolean setting);
+gboolean gtk_toggle_button_get_inconsistent (GtkToggleButton *toggle_button);
#ifdef __cplusplus
}
diff --git a/gtk/testgtk.c b/gtk/testgtk.c
index 97bf5e270d..41374de05b 100644
--- a/gtk/testgtk.c
+++ b/gtk/testgtk.c
@@ -316,6 +316,10 @@ create_toggle_buttons (void)
button = gtk_toggle_button_new_with_label ("button3");
gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
+ button = gtk_toggle_button_new_with_label ("inconsistent");
+ gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE);
+ gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
+
separator = gtk_hseparator_new ();
gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
@@ -378,6 +382,10 @@ create_check_buttons (void)
button = gtk_check_button_new_with_label ("button3");
gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
+ button = gtk_check_button_new_with_label ("inconsistent");
+ gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE);
+ gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
+
separator = gtk_hseparator_new ();
gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
@@ -445,6 +453,12 @@ create_radio_buttons (void)
"button3");
gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
+ button = gtk_radio_button_new_with_label (
+ gtk_radio_button_group (GTK_RADIO_BUTTON (button)),
+ "inconsistent");
+ gtk_toggle_button_set_inconsistent (GTK_TOGGLE_BUTTON (button), TRUE);
+ gtk_box_pack_start (GTK_BOX (box2), button, TRUE, TRUE, 0);
+
separator = gtk_hseparator_new ();
gtk_box_pack_start (GTK_BOX (box1), separator, FALSE, TRUE, 0);
@@ -2788,15 +2802,22 @@ create_menu (gint depth, gint length, gboolean tearoff)
for (i = 0, j = 1; i < length; i++, j++)
{
sprintf (buf, "item %2d - %d", depth, j);
+
menuitem = gtk_radio_menu_item_new_with_label (group, buf);
group = gtk_radio_menu_item_group (GTK_RADIO_MENU_ITEM (menuitem));
+
if (depth % 2)
gtk_check_menu_item_set_show_toggle (GTK_CHECK_MENU_ITEM (menuitem), TRUE);
+
gtk_menu_shell_append (GTK_MENU_SHELL (menu), menuitem);
gtk_widget_show (menuitem);
if (i == 3)
gtk_widget_set_sensitive (menuitem, FALSE);
+ if (i == 5)
+ gtk_check_menu_item_set_inconsistent (GTK_CHECK_MENU_ITEM (menuitem),
+ TRUE);
+
if (i < 5)
gtk_menu_item_set_submenu (GTK_MENU_ITEM (menuitem), create_menu (depth - 1, 5, TRUE));
}