gtkspinbutton.h 7.79 KB
Newer Older
Cody Russell's avatar
Cody Russell committed
1
/* GTK - The GIMP Toolkit
2 3
 * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
 *
4 5 6
 * GtkSpinButton widget for GTK+
 * Copyright (C) 1998 Lars Hamann and Stefan Jeske
 *
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 10 11 12 13
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * 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
Javier Jardón's avatar
Javier Jardón committed
18
 * License along with this library. If not, see <http://www.gnu.org/licenses/>.
19 20
 */

21
/*
22
 * Modified by the GTK+ Team and others 1997-2000.  See the AUTHORS
23 24
 * file for a list of people on the GTK+ Team.  See the ChangeLog
 * files for a list of changes.  These files are distributed with
25
 * GTK+ at ftp://ftp.gtk.org/pub/gtk/.
26 27
 */

28 29 30 31
#ifndef __GTK_SPIN_BUTTON_H__
#define __GTK_SPIN_BUTTON_H__


32 33 34 35
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
#error "Only <gtk/gtk.h> can be included directly."
#endif

36 37 38
#include <gtk/gtkentry.h>


39
G_BEGIN_DECLS
40 41

#define GTK_TYPE_SPIN_BUTTON                  (gtk_spin_button_get_type ())
Manish Singh's avatar
Manish Singh committed
42 43 44 45 46
#define GTK_SPIN_BUTTON(obj)                  (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_SPIN_BUTTON, GtkSpinButton))
#define GTK_SPIN_BUTTON_CLASS(klass)          (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_SPIN_BUTTON, GtkSpinButtonClass))
#define GTK_IS_SPIN_BUTTON(obj)               (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_SPIN_BUTTON))
#define GTK_IS_SPIN_BUTTON_CLASS(klass)       (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_SPIN_BUTTON))
#define GTK_SPIN_BUTTON_GET_CLASS(obj)        (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_SPIN_BUTTON, GtkSpinButtonClass))
47

48 49 50 51 52 53
/**
 * GTK_INPUT_ERROR:
 *
 * Constant to return from a signal handler for the #GtkSpinButton::input
 * signal in case of conversion failure.
 */
54
#define GTK_INPUT_ERROR -1
55

56 57 58 59 60 61 62 63 64 65 66 67
/**
 * GtkSpinButtonUpdatePolicy:
 * @GTK_UPDATE_ALWAYS: When refreshing your #GtkSpinButton, the value is
 *     always displayed
 * @GTK_UPDATE_IF_VALID: When refreshing your #GtkSpinButton, the value is
 *     only displayed if it is valid within the bounds of the spin button's
 *     adjustment
 *
 * The spin button update policy determines whether the spin button displays
 * values even if they are outside the bounds of its adjustment.
 * See gtk_spin_button_set_update_policy().
 */
68 69
typedef enum
{
70 71
  GTK_UPDATE_ALWAYS,
  GTK_UPDATE_IF_VALID
72
} GtkSpinButtonUpdatePolicy;
73

74 75 76 77 78 79 80 81 82 83 84 85 86
/**
 * GtkSpinType:
 * @GTK_SPIN_STEP_FORWARD: Increment by the adjustments step increment.
 * @GTK_SPIN_STEP_BACKWARD: Decrement by the adjustments step increment.
 * @GTK_SPIN_PAGE_FORWARD: Increment by the adjustments page increment.
 * @GTK_SPIN_PAGE_BACKWARD: Decrement by the adjustments page increment.
 * @GTK_SPIN_HOME: Go to the adjustments lower bound.
 * @GTK_SPIN_END: Go to the adjustments upper bound.
 * @GTK_SPIN_USER_DEFINED: Change by a specified amount.
 *
 * The values of the GtkSpinType enumeration are used to specify the
 * change to make in gtk_spin_button_spin().
 */
87 88 89 90 91 92 93 94 95 96 97 98
typedef enum
{
  GTK_SPIN_STEP_FORWARD,
  GTK_SPIN_STEP_BACKWARD,
  GTK_SPIN_PAGE_FORWARD,
  GTK_SPIN_PAGE_BACKWARD,
  GTK_SPIN_HOME,
  GTK_SPIN_END,
  GTK_SPIN_USER_DEFINED
} GtkSpinType;


99 100 101
typedef struct _GtkSpinButton              GtkSpinButton;
typedef struct _GtkSpinButtonPrivate       GtkSpinButtonPrivate;
typedef struct _GtkSpinButtonClass         GtkSpinButtonClass;
102

103 104 105
/**
 * GtkSpinButton:
 *
106
 * The #GtkSpinButton-struct contains only private data and should
107 108
 * not be directly modified.
 */
109 110 111
struct _GtkSpinButton
{
  GtkEntry entry;
112

113
  /*< private >*/
114
  GtkSpinButtonPrivate *priv;
115 116 117 118 119
};

struct _GtkSpinButtonClass
{
  GtkEntryClass parent_class;
120 121

  gint (*input)  (GtkSpinButton *spin_button,
122
		  gdouble       *new_value);
123
  gint (*output) (GtkSpinButton *spin_button);
124
  void (*value_changed) (GtkSpinButton *spin_button);
125

Owen Taylor's avatar
Owen Taylor committed
126 127 128
  /* Action signals for keybindings, do not connect to these */
  void (*change_value) (GtkSpinButton *spin_button,
			GtkScrollType  scroll);
129

130 131
  void (*wrapped) (GtkSpinButton *spin_button);

132 133 134 135
  /* Padding for future expansion */
  void (*_gtk_reserved1) (void);
  void (*_gtk_reserved2) (void);
  void (*_gtk_reserved3) (void);
136
  void (*_gtk_reserved4) (void);
137 138
};

139

140
GDK_AVAILABLE_IN_ALL
Manish Singh's avatar
Manish Singh committed
141
GType		gtk_spin_button_get_type	   (void) G_GNUC_CONST;
142

143
GDK_AVAILABLE_IN_ALL
144
void		gtk_spin_button_configure	   (GtkSpinButton  *spin_button,
145
						    GtkAdjustment  *adjustment,
146
						    gdouble	    climb_rate,
147
						    guint	    digits);
148

149
GDK_AVAILABLE_IN_ALL
150
GtkWidget*	gtk_spin_button_new		   (GtkAdjustment  *adjustment,
151
						    gdouble	    climb_rate,
152
						    guint	    digits);
153

154
GDK_AVAILABLE_IN_ALL
155 156 157 158
GtkWidget*	gtk_spin_button_new_with_range	   (gdouble  min,
						    gdouble  max,
						    gdouble  step);

159
GDK_AVAILABLE_IN_ALL
160
void		gtk_spin_button_set_adjustment	   (GtkSpinButton  *spin_button,
161
						    GtkAdjustment  *adjustment);
162

163
GDK_AVAILABLE_IN_ALL
164
GtkAdjustment*	gtk_spin_button_get_adjustment	   (GtkSpinButton  *spin_button);
165

166
GDK_AVAILABLE_IN_ALL
167
void		gtk_spin_button_set_digits	   (GtkSpinButton  *spin_button,
168
						    guint	    digits);
169
GDK_AVAILABLE_IN_ALL
170
guint           gtk_spin_button_get_digits         (GtkSpinButton  *spin_button);
171

172
GDK_AVAILABLE_IN_ALL
173 174 175
void		gtk_spin_button_set_increments	   (GtkSpinButton  *spin_button,
						    gdouble         step,
						    gdouble         page);
176
GDK_AVAILABLE_IN_ALL
177 178 179
void            gtk_spin_button_get_increments     (GtkSpinButton  *spin_button,
						    gdouble        *step,
						    gdouble        *page);
180

181
GDK_AVAILABLE_IN_ALL
182 183 184
void		gtk_spin_button_set_range	   (GtkSpinButton  *spin_button,
						    gdouble         min,
						    gdouble         max);
185
GDK_AVAILABLE_IN_ALL
186 187 188
void            gtk_spin_button_get_range          (GtkSpinButton  *spin_button,
						    gdouble        *min,
						    gdouble        *max);
189

190
GDK_AVAILABLE_IN_ALL
191
gdouble		gtk_spin_button_get_value          (GtkSpinButton  *spin_button);
192

193
GDK_AVAILABLE_IN_ALL
194
gint		gtk_spin_button_get_value_as_int   (GtkSpinButton  *spin_button);
195

196
GDK_AVAILABLE_IN_ALL
197
void		gtk_spin_button_set_value	   (GtkSpinButton  *spin_button,
198
						    gdouble	    value);
199

200
GDK_AVAILABLE_IN_ALL
201 202
void		gtk_spin_button_set_update_policy  (GtkSpinButton  *spin_button,
						    GtkSpinButtonUpdatePolicy  policy);
203
GDK_AVAILABLE_IN_ALL
204
GtkSpinButtonUpdatePolicy gtk_spin_button_get_update_policy (GtkSpinButton *spin_button);
205

206
GDK_AVAILABLE_IN_ALL
207
void		gtk_spin_button_set_numeric	   (GtkSpinButton  *spin_button,
208
						    gboolean	    numeric);
209
GDK_AVAILABLE_IN_ALL
210
gboolean        gtk_spin_button_get_numeric        (GtkSpinButton  *spin_button);
211

212
GDK_AVAILABLE_IN_ALL
213 214
void		gtk_spin_button_spin		   (GtkSpinButton  *spin_button,
						    GtkSpinType     direction,
215
						    gdouble	    increment);
216

217
GDK_AVAILABLE_IN_ALL
218
void		gtk_spin_button_set_wrap	   (GtkSpinButton  *spin_button,
219
						    gboolean	    wrap);
220
GDK_AVAILABLE_IN_ALL
221
gboolean        gtk_spin_button_get_wrap           (GtkSpinButton  *spin_button);
222

223
GDK_AVAILABLE_IN_ALL
224
void		gtk_spin_button_set_snap_to_ticks  (GtkSpinButton  *spin_button,
225
						    gboolean	    snap_to_ticks);
226
GDK_AVAILABLE_IN_ALL
227
gboolean        gtk_spin_button_get_snap_to_ticks  (GtkSpinButton  *spin_button);
228
GDK_AVAILABLE_IN_ALL
229 230
void            gtk_spin_button_update             (GtkSpinButton  *spin_button);

231
/* private */
232 233 234
void            _gtk_spin_button_get_panels        (GtkSpinButton  *spin_button,
                                                    GdkWindow     **down_panel,
                                                    GdkWindow     **up_panel);
235

Matthias Clasen's avatar
Matthias Clasen committed
236
G_END_DECLS
237 238

#endif /* __GTK_SPIN_BUTTON_H__ */