diff options
author | Havoc Pennington <hp@pobox.com> | 2001-06-04 02:31:12 +0000 |
---|---|---|
committer | Havoc Pennington <hp@src.gnome.org> | 2001-06-04 02:31:12 +0000 |
commit | 42f429be76e96f1861a17da2cd5ef56741172e25 (patch) | |
tree | 3ca33e80692cfb0f73e4621113bce3dbcb0546a9 /gtk/gtkhscrollbar.c | |
parent | 741c71eb931cb85651e9f5aba99db4017dda180a (diff) | |
download | gtk+-42f429be76e96f1861a17da2cd5ef56741172e25.tar.gz |
make this special-case hscale/vscale details, so we can use it for
2001-06-03 Havoc Pennington <hp@pobox.com>
* gtk/gtkstyle.c (gtk_default_draw_slider): make this special-case
hscale/vscale details, so we can use it for scrollbar as well.
* tests/testgtk.c (reformat_value): honor digits from GtkScale
* gtk/gtkenums.h (GtkTroughType): Remove this enum
(GtkScrollType): add START and END from GtkTroughType
* gtk/gtkstyle.c (gtk_default_draw_slider): was not properly using
its x/y arguments
* gtk/gtkrange.h, gtk/gtkrange.c, gtk/gtkscrollbar.h,
gtk/gtkscrollbar.c, gtk/gtkscale.h, gtk/gtkscale.c,
gtk/gtkhscrollbar.h, gtk/gtkhscrollbar.c, gtk/gtkvscrollbar.h,
gtk/gtkvscrollbar.c, gtk/gtkhscale.h, gtk/gtkhscale.c,
gtk/gtkvscale.h, gtk/gtkvscale.c: Rewrite GtkRange and subclasses.
Notable changes in the process:
- stepper_size style property is the height for vertical
ranges, width for horizontal; the other dimension matches
the trough size
- add ability to do NeXT-style steppers (and several other styles
that don't make any sense)
- added min_slider_length, fixed_slider_length properties to
GtkScrollbar
- cleaned some private (or at least useless) functions out of
gtkscale.h
- moved bindings to GtkScale from subclasses, even arrow keys,
since blind users don't know scale orientation.
- change move_slider action signal to use new GtkScrollType,
remove GtkTroughType argument
- digits rounds the values a range will input to the given
number of decimals, but will not try to force adjustment
values set by other controllers. That is, we no longer
modify adjustment->value inside a value_changed handler.
- added getters for GtkScale setters
- middle-click begins a slider drag
Diffstat (limited to 'gtk/gtkhscrollbar.c')
-rw-r--r-- | gtk/gtkhscrollbar.c | 370 |
1 files changed, 7 insertions, 363 deletions
diff --git a/gtk/gtkhscrollbar.c b/gtk/gtkhscrollbar.c index 9ec6f22c48..0894187dec 100644 --- a/gtk/gtkhscrollbar.c +++ b/gtk/gtkhscrollbar.c @@ -1,5 +1,6 @@ /* GTK - The GIMP Toolkit * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald + * Copyright (C) 2001 Red Hat, Inc. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public @@ -29,34 +30,8 @@ #include "gdk/gdkkeysyms.h" #include "gtkintl.h" - -#define EPSILON 0.01 - -#define RANGE_CLASS(w) GTK_RANGE_GET_CLASS (w) - -enum { - PROP_0 -}; - static void gtk_hscrollbar_class_init (GtkHScrollbarClass *klass); static void gtk_hscrollbar_init (GtkHScrollbar *hscrollbar); -static void gtk_hscrollbar_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec); -static void gtk_hscrollbar_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec); -static void gtk_hscrollbar_realize (GtkWidget *widget); -static void gtk_hscrollbar_size_request (GtkWidget *widget, - GtkRequisition *requisition); -static void gtk_hscrollbar_size_allocate (GtkWidget *widget, - GtkAllocation *allocation); -static void gtk_hscrollbar_draw_step_forw (GtkRange *range); -static void gtk_hscrollbar_draw_step_back (GtkRange *range); -static void gtk_hscrollbar_slider_update (GtkRange *range); -static void gtk_hscrollbar_calc_slider_size (GtkHScrollbar *hscrollbar); GtkType gtk_hscrollbar_get_type (void) @@ -86,69 +61,17 @@ gtk_hscrollbar_get_type (void) static void gtk_hscrollbar_class_init (GtkHScrollbarClass *class) { - GObjectClass *gobject_class; - GtkObjectClass *object_class; - GtkWidgetClass *widget_class; - GtkRangeClass *range_class; - - gobject_class = (GObjectClass*) class; - object_class = (GtkObjectClass*) class; - widget_class = (GtkWidgetClass*) class; - range_class = (GtkRangeClass*) class; - - gobject_class->set_property = gtk_hscrollbar_set_property; - gobject_class->get_property = gtk_hscrollbar_get_property; - - widget_class->realize = gtk_hscrollbar_realize; - widget_class->size_request = gtk_hscrollbar_size_request; - widget_class->size_allocate = gtk_hscrollbar_size_allocate; - - range_class->draw_step_forw = gtk_hscrollbar_draw_step_forw; - range_class->draw_step_back = gtk_hscrollbar_draw_step_back; - range_class->slider_update = gtk_hscrollbar_slider_update; - range_class->trough_click = _gtk_range_default_htrough_click; - range_class->motion = _gtk_range_default_hmotion; -} - -static void -gtk_hscrollbar_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec) -{ - GtkHScrollbar *hscrollbar; - - hscrollbar = GTK_HSCROLLBAR (object); - - switch (prop_id) - { - default: - G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); - break; - } -} - -static void -gtk_hscrollbar_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec) -{ - GtkHScrollbar *hscrollbar; - - hscrollbar = GTK_HSCROLLBAR (object); - - switch (prop_id) - { - default: - G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); - break; - } + GTK_RANGE_CLASS (class)->stepper_detail = "hscrollbar"; } static void gtk_hscrollbar_init (GtkHScrollbar *hscrollbar) { + GtkRange *range; + + range = GTK_RANGE (hscrollbar); + + range->orientation = GTK_ORIENTATION_HORIZONTAL; } GtkWidget* @@ -163,282 +86,3 @@ gtk_hscrollbar_new (GtkAdjustment *adjustment) return hscrollbar; } - -static void -gtk_hscrollbar_realize (GtkWidget *widget) -{ - GtkRange *range; - GdkWindowAttr attributes; - gint attributes_mask; - gint slider_width; - gint trough_border; - gint stepper_size; - - g_return_if_fail (widget != NULL); - g_return_if_fail (GTK_IS_HSCROLLBAR (widget)); - - GTK_WIDGET_SET_FLAGS (widget, GTK_REALIZED); - range = GTK_RANGE (widget); - - _gtk_range_get_props (range, &slider_width, &trough_border, - &stepper_size, NULL); - - attributes.x = widget->allocation.x; - attributes.y = widget->allocation.y + (widget->allocation.height - widget->requisition.height) / 2; - attributes.width = widget->allocation.width; - attributes.height = widget->requisition.height; - attributes.wclass = GDK_INPUT_OUTPUT; - attributes.window_type = GDK_WINDOW_CHILD; - attributes.visual = gtk_widget_get_visual (widget); - attributes.colormap = gtk_widget_get_colormap (widget); - attributes.event_mask = gtk_widget_get_events (widget); - attributes.event_mask |= (GDK_EXPOSURE_MASK | - GDK_BUTTON_PRESS_MASK | - GDK_BUTTON_RELEASE_MASK | - GDK_ENTER_NOTIFY_MASK | - GDK_LEAVE_NOTIFY_MASK); - - attributes_mask = GDK_WA_X | GDK_WA_Y | GDK_WA_VISUAL | GDK_WA_COLORMAP; - widget->window = gdk_window_new (gtk_widget_get_parent_window (widget), &attributes, attributes_mask); - - range->trough = widget->window; - gdk_window_ref (range->trough); - - attributes.x = trough_border; - attributes.y = trough_border; - attributes.width = stepper_size; - attributes.height = stepper_size; - - range->step_back = gdk_window_new (range->trough, &attributes, attributes_mask); - - attributes.x = (widget->allocation.width - - trough_border - - stepper_size); - - range->step_forw = gdk_window_new (range->trough, &attributes, attributes_mask); - - attributes.x = 0; - attributes.y = trough_border; - attributes.width = RANGE_CLASS (widget)->min_slider_size; - attributes.height = slider_width; - - attributes.event_mask |= (GDK_BUTTON_MOTION_MASK | - GDK_POINTER_MOTION_HINT_MASK); - - range->slider = gdk_window_new (range->trough, &attributes, attributes_mask); - - gtk_hscrollbar_calc_slider_size (GTK_HSCROLLBAR (widget)); - _gtk_range_slider_update (GTK_RANGE (widget)); - - widget->style = gtk_style_attach (widget->style, widget->window); - - gdk_window_set_user_data (range->trough, widget); - gdk_window_set_user_data (range->slider, widget); - gdk_window_set_user_data (range->step_forw, widget); - gdk_window_set_user_data (range->step_back, widget); - - gtk_style_set_background (widget->style, range->trough, GTK_STATE_ACTIVE); - gtk_style_set_background (widget->style, range->slider, GTK_STATE_NORMAL); - gtk_style_set_background (widget->style, range->step_forw, GTK_STATE_ACTIVE); - gtk_style_set_background (widget->style, range->step_back, GTK_STATE_ACTIVE); - - gdk_window_show (range->slider); - gdk_window_show (range->step_forw); - gdk_window_show (range->step_back); -} - -static void -gtk_hscrollbar_size_request (GtkWidget *widget, - GtkRequisition *requisition) -{ - gint slider_width; - gint trough_border; - gint stepper_size; - gint stepper_spacing; - - GtkRange *range = GTK_RANGE (widget); - - _gtk_range_get_props (range, &slider_width, &trough_border, - &stepper_size, &stepper_spacing); - - requisition->width = (RANGE_CLASS (widget)->min_slider_size + - stepper_size + - stepper_spacing + - trough_border) * 2; - requisition->height = (slider_width + - trough_border * 2); -} - -static void -gtk_hscrollbar_size_allocate (GtkWidget *widget, - GtkAllocation *allocation) -{ - GtkRange *range; - gint trough_border; - gint stepper_size; - - g_return_if_fail (widget != NULL); - g_return_if_fail (GTK_IS_HSCROLLBAR (widget)); - g_return_if_fail (allocation != NULL); - - widget->allocation = *allocation; - if (GTK_WIDGET_REALIZED (widget)) - { - range = GTK_RANGE (widget); - - _gtk_range_get_props (range, NULL, &trough_border, - &stepper_size, NULL); - - gdk_window_move_resize (range->trough, - allocation->x, - allocation->y + (allocation->height - widget->requisition.height) / 2, - allocation->width, widget->requisition.height); - gdk_window_move_resize (range->step_back, - trough_border, - trough_border, - stepper_size, - widget->requisition.height - trough_border * 2); - gdk_window_move_resize (range->step_forw, - allocation->width - trough_border - - stepper_size, - trough_border, - stepper_size, - widget->requisition.height - trough_border * 2); - - _gtk_range_slider_update (GTK_RANGE (widget)); - } -} - -static void -gtk_hscrollbar_draw_step_forw (GtkRange *range) -{ - GtkStateType state_type; - GtkShadowType shadow_type; - - g_return_if_fail (range != NULL); - g_return_if_fail (GTK_IS_HSCROLLBAR (range)); - - if (GTK_WIDGET_DRAWABLE (range)) - { - if (range->in_child == RANGE_CLASS (range)->step_forw) - { - if (range->click_child == RANGE_CLASS (range)->step_forw) - state_type = GTK_STATE_ACTIVE; - else - state_type = GTK_STATE_PRELIGHT; - } - else - state_type = GTK_STATE_NORMAL; - - if (range->click_child == RANGE_CLASS (range)->step_forw) - shadow_type = GTK_SHADOW_IN; - else - shadow_type = GTK_SHADOW_OUT; - - gtk_paint_arrow (GTK_WIDGET (range)->style, range->step_forw, - state_type, shadow_type, - NULL, GTK_WIDGET (range), "hscrollbar", - GTK_ARROW_RIGHT, - TRUE, 0, 0, -1, -1); - } -} - -static void -gtk_hscrollbar_draw_step_back (GtkRange *range) -{ - GtkStateType state_type; - GtkShadowType shadow_type; - - g_return_if_fail (range != NULL); - g_return_if_fail (GTK_IS_HSCROLLBAR (range)); - - if (GTK_WIDGET_DRAWABLE (range)) - { - if (range->in_child == RANGE_CLASS (range)->step_back) - { - if (range->click_child == RANGE_CLASS (range)->step_back) - state_type = GTK_STATE_ACTIVE; - else - state_type = GTK_STATE_PRELIGHT; - } - else - state_type = GTK_STATE_NORMAL; - - if (range->click_child == RANGE_CLASS (range)->step_back) - shadow_type = GTK_SHADOW_IN; - else - shadow_type = GTK_SHADOW_OUT; - - gtk_paint_arrow (GTK_WIDGET (range)->style, range->step_back, - state_type, shadow_type, - NULL, GTK_WIDGET (range), "hscrollbar", - GTK_ARROW_LEFT, - TRUE, 0, 0, -1, -1); - } -} - -static void -gtk_hscrollbar_slider_update (GtkRange *range) -{ - g_return_if_fail (range != NULL); - g_return_if_fail (GTK_IS_HSCROLLBAR (range)); - - gtk_hscrollbar_calc_slider_size (GTK_HSCROLLBAR (range)); - _gtk_range_default_hslider_update (range); -} - -static void -gtk_hscrollbar_calc_slider_size (GtkHScrollbar *hscrollbar) -{ - GtkRange *range; - gint step_back_x; - gint step_back_width; - gint step_forw_x; - gint slider_width; - gint slider_height; - gint stepper_spacing; - gint left, right; - gint width; - - g_return_if_fail (hscrollbar != NULL); - g_return_if_fail (GTK_IS_HSCROLLBAR (hscrollbar)); - - if (GTK_WIDGET_REALIZED (hscrollbar)) - { - range = GTK_RANGE (hscrollbar); - - _gtk_range_get_props (range, NULL, NULL, NULL, &stepper_spacing); - - gdk_window_get_size (range->step_back, &step_back_width, NULL); - gdk_window_get_position (range->step_back, &step_back_x, NULL); - gdk_window_get_position (range->step_forw, &step_forw_x, NULL); - - left = (step_back_x + - step_back_width + - stepper_spacing); - right = step_forw_x - stepper_spacing; - width = right - left; - - if ((range->adjustment->page_size > 0) && - (range->adjustment->lower != range->adjustment->upper)) - { - if (range->adjustment->page_size > - (range->adjustment->upper - range->adjustment->lower)) - range->adjustment->page_size = range->adjustment->upper - range->adjustment->lower; - - width = (width * range->adjustment->page_size / - (range->adjustment->upper - range->adjustment->lower)); - - if (width < RANGE_CLASS (hscrollbar)->min_slider_size) - width = RANGE_CLASS (hscrollbar)->min_slider_size; - } - - gdk_window_get_size (range->slider, &slider_width, &slider_height); - - if (slider_width != width) - { - gdk_window_resize (range->slider, width, slider_height); - gdk_window_invalidate_rect (range->slider, NULL, FALSE); - } - } -} |