]> Pileus Git - ~andy/gtk/blob - gtk/gtkspinbutton.h
Doc comment fixing. (Mostly non-matching parameter names.)
[~andy/gtk] / gtk / gtkspinbutton.h
1 /* GTK - The GIMP Toolkit
2  * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
3  *
4  * GtkSpinButton widget for GTK+
5  * Copyright (C) 1998 Lars Hamann and Stefan Jeske
6  *
7  * This library is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2 of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with this library; if not, write to the
19  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
20  * Boston, MA 02111-1307, USA.
21  */
22
23 /*
24  * Modified by the GTK+ Team and others 1997-2000.  See the AUTHORS
25  * file for a list of people on the GTK+ Team.  See the ChangeLog
26  * files for a list of changes.  These files are distributed with
27  * GTK+ at ftp://ftp.gtk.org/pub/gtk/. 
28  */
29
30 #ifndef __GTK_SPIN_BUTTON_H__
31 #define __GTK_SPIN_BUTTON_H__
32
33
34 #include <gdk/gdk.h>
35 #include <gtk/gtkentry.h>
36 #include <gtk/gtkadjustment.h>
37
38
39 #ifdef __cplusplus
40 extern "C" {
41 #endif /* __cplusplus */
42
43
44 #define GTK_TYPE_SPIN_BUTTON                  (gtk_spin_button_get_type ())
45 #define GTK_SPIN_BUTTON(obj)                  (GTK_CHECK_CAST ((obj), GTK_TYPE_SPIN_BUTTON, GtkSpinButton))
46 #define GTK_SPIN_BUTTON_CLASS(klass)          (GTK_CHECK_CLASS_CAST ((klass), GTK_TYPE_SPIN_BUTTON, GtkSpinButtonClass))
47 #define GTK_IS_SPIN_BUTTON(obj)               (GTK_CHECK_TYPE ((obj), GTK_TYPE_SPIN_BUTTON))
48 #define GTK_IS_SPIN_BUTTON_CLASS(klass)       (GTK_CHECK_CLASS_TYPE ((klass), GTK_TYPE_SPIN_BUTTON))
49 #define GTK_SPIN_BUTTON_GET_CLASS(obj)        (GTK_CHECK_GET_CLASS ((obj), GTK_TYPE_SPIN_BUTTON, GtkSpinButtonClass))
50
51 #define GTK_INPUT_ERROR -1
52
53 typedef enum
54 {
55   GTK_UPDATE_ALWAYS,
56   GTK_UPDATE_IF_VALID
57 } GtkSpinButtonUpdatePolicy;
58
59 typedef enum
60 {
61   GTK_SPIN_STEP_FORWARD,
62   GTK_SPIN_STEP_BACKWARD,
63   GTK_SPIN_PAGE_FORWARD,
64   GTK_SPIN_PAGE_BACKWARD,
65   GTK_SPIN_HOME,
66   GTK_SPIN_END,
67   GTK_SPIN_USER_DEFINED
68 } GtkSpinType;
69
70
71 typedef struct _GtkSpinButton       GtkSpinButton;
72 typedef struct _GtkSpinButtonClass  GtkSpinButtonClass;
73
74
75 struct _GtkSpinButton
76 {
77   GtkEntry entry;
78   
79   GtkAdjustment *adjustment;
80   
81   GdkWindow *panel;
82   GtkShadowType shadow_type;
83   
84   guint32 timer;
85   guint32 ev_time;
86   
87   gfloat climb_rate;
88   gfloat timer_step;
89   
90   GtkSpinButtonUpdatePolicy update_policy;
91   
92   guint in_child : 2;
93   guint click_child : 2;
94   guint button : 2;
95   guint need_timer : 1;
96   guint timer_calls : 3;
97   guint digits : 3;
98   guint numeric : 1;
99   guint wrap : 1;
100   guint snap_to_ticks : 1;
101 };
102
103 struct _GtkSpinButtonClass
104 {
105   GtkEntryClass parent_class;
106
107   gint (*input)  (GtkSpinButton *spin_button,
108                   gfloat        *new_value);
109   gint (*output) (GtkSpinButton *spin_button);
110 };
111
112
113 GtkType         gtk_spin_button_get_type           (void) G_GNUC_CONST;
114
115 void            gtk_spin_button_configure          (GtkSpinButton  *spin_button,
116                                                     GtkAdjustment  *adjustment,
117                                                     gfloat          climb_rate,
118                                                     guint           digits);
119
120 GtkWidget*      gtk_spin_button_new                (GtkAdjustment  *adjustment,
121                                                     gfloat          climb_rate,
122                                                     guint           digits);
123
124 void            gtk_spin_button_set_adjustment     (GtkSpinButton  *spin_button,
125                                                     GtkAdjustment  *adjustment);
126
127 GtkAdjustment*  gtk_spin_button_get_adjustment     (GtkSpinButton  *spin_button);
128
129 void            gtk_spin_button_set_digits         (GtkSpinButton  *spin_button,
130                                                     guint           digits);
131
132 gfloat          gtk_spin_button_get_value_as_float (GtkSpinButton  *spin_button);
133
134 gint            gtk_spin_button_get_value_as_int   (GtkSpinButton  *spin_button);
135
136 void            gtk_spin_button_set_value          (GtkSpinButton  *spin_button, 
137                                                     gfloat          value);
138
139 void            gtk_spin_button_set_update_policy  (GtkSpinButton  *spin_button,
140                                                     GtkSpinButtonUpdatePolicy  policy);
141
142 void            gtk_spin_button_set_numeric        (GtkSpinButton  *spin_button,
143                                                     gboolean        numeric);
144
145 void            gtk_spin_button_spin               (GtkSpinButton  *spin_button,
146                                                     GtkSpinType     direction,
147                                                     gfloat          increment);
148
149 void            gtk_spin_button_set_wrap           (GtkSpinButton  *spin_button,
150                                                     gboolean        wrap);
151
152 void            gtk_spin_button_set_shadow_type    (GtkSpinButton  *spin_button,
153                                                     GtkShadowType   shadow_type);
154
155 void            gtk_spin_button_set_snap_to_ticks  (GtkSpinButton  *spin_button,
156                                                     gboolean        snap_to_ticks);
157 void            gtk_spin_button_update             (GtkSpinButton  *spin_button);
158
159
160
161 #ifdef __cplusplus
162 }
163 #endif /* __cplusplus */
164
165
166 #endif /* __GTK_SPIN_BUTTON_H__ */