1 /* GDK - The GIMP Drawing Kit
2 * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
14 * You should have received a copy of the GNU Library General Public
15 * License along with this library; if not, write to the Free
16 * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
22 #include <gdk/gdktypes.h>
27 #endif /* __cplusplus */
30 /* Initialization, exit and events
32 void gdk_init (int *argc,
34 void gdk_exit (int error_code);
35 gchar* gdk_set_locale (void);
37 gint gdk_events_pending (void);
38 gint gdk_event_get (GdkEvent *event,
41 void gdk_event_put (GdkEvent *event);
43 GdkEvent *gdk_event_copy (GdkEvent *event);
44 void gdk_event_free (GdkEvent *event);
46 void gdk_set_debug_level (gint level);
47 void gdk_set_show_events (gint show_events);
48 void gdk_set_use_xshm (gint use_xshm);
50 gint gdk_get_debug_level (void);
51 gint gdk_get_show_events (void);
52 gint gdk_get_use_xshm (void);
54 guint32 gdk_time_get (void);
55 guint32 gdk_timer_get (void);
56 void gdk_timer_set (guint32 milliseconds);
57 void gdk_timer_enable (void);
58 void gdk_timer_disable (void);
60 gint gdk_input_add (gint source,
61 GdkInputCondition condition,
62 GdkInputFunction function,
64 void gdk_input_remove (gint tag);
66 gint gdk_pointer_grab (GdkWindow * window,
68 GdkEventMask event_mask,
69 GdkWindow * confine_to,
72 void gdk_pointer_ungrab (guint32 time);
74 gint gdk_keyboard_grab (GdkWindow * window,
77 void gdk_keyboard_ungrab (guint32 time);
79 gint gdk_screen_width (void);
80 gint gdk_screen_height (void);
82 void gdk_flush (void);
85 void gdk_key_repeat_disable (void);
86 void gdk_key_repeat_restore (void);
91 gint gdk_visual_get_best_depth (void);
92 GdkVisualType gdk_visual_get_best_type (void);
93 GdkVisual* gdk_visual_get_system (void);
94 GdkVisual* gdk_visual_get_best (void);
95 GdkVisual* gdk_visual_get_best_with_depth (gint depth);
96 GdkVisual* gdk_visual_get_best_with_type (GdkVisualType visual_type);
97 GdkVisual* gdk_visual_get_best_with_both (gint depth,
98 GdkVisualType visual_type);
100 /* Actually, these are no-ops... */
101 GdkVisual* gdk_visual_ref (GdkVisual *visual);
102 void gdk_visual_unref (GdkVisual *visual);
104 void gdk_query_depths (gint **depths,
106 void gdk_query_visual_types (GdkVisualType **visual_types,
108 void gdk_query_visuals (GdkVisual **visuals,
114 GdkWindow* gdk_window_new (GdkWindow *parent,
115 GdkWindowAttr *attributes,
116 gint attributes_mask);
118 GdkWindow * gdk_window_foreign_new (guint32 anid);
119 void gdk_window_destroy (GdkWindow *window);
120 GdkWindow* gdk_window_ref (GdkWindow *window);
121 void gdk_window_unref (GdkWindow *window);
123 void gdk_window_show (GdkWindow *window);
124 void gdk_window_hide (GdkWindow *window);
125 void gdk_window_move (GdkWindow *window,
128 void gdk_window_resize (GdkWindow *window,
131 void gdk_window_move_resize (GdkWindow *window,
136 void gdk_window_reparent (GdkWindow *window,
137 GdkWindow *new_parent,
140 void gdk_window_clear (GdkWindow *window);
141 void gdk_window_clear_area (GdkWindow *window,
146 void gdk_window_clear_area_e(GdkWindow *window,
151 void gdk_window_copy_area (GdkWindow *window,
155 GdkWindow *source_window,
160 void gdk_window_raise (GdkWindow *window);
161 void gdk_window_lower (GdkWindow *window);
163 void gdk_window_set_user_data (GdkWindow *window,
165 void gdk_window_set_override_redirect(GdkWindow *window,
166 gboolean override_redirect);
170 * This allows for making shaped (partially transparent) windows
171 * - cool feature, needed for Drag and Drag for example.
172 * The shape_mask can be the mask
173 * from gdk_pixmap_create_from_xpm. Stefan Wille
175 void gdk_window_shape_combine_mask (GdkWindow *window,
176 GdkBitmap *shape_mask,
182 * Algorithm (drop source):
183 * A window being dragged will be sent a GDK_DRAG_BEGIN message.
184 * It will then do gdk_dnd_drag_addwindow() for any other windows that are to be
186 * When we get a DROP_ENTER incoming, we send it on to the window in question.
187 * That window needs to use gdk_dnd_drop_enter_reply() to indicate the state of
188 * things (it must call that even if it's not going to accept the drop)
190 * These two turn on/off drag or drop, and if enabling it also
191 * sets the list of types supported. The list of types passed in
192 * should be in order of decreasing preference.
194 void gdk_window_dnd_drag_set (GdkWindow *window,
200 *XXX todo: add a GDK_DROP_ENTER which can look at actual data
202 void gdk_window_dnd_drop_set (GdkWindow *window,
206 guint8 destructive_op);
209 * This is used by the GDK_DRAG_BEGIN handler. An example of usage would be a
210 * file manager where multiple icons were selected and the drag began.
211 * The icon that the drag actually began on would gdk_dnd_drag_addwindow
212 * for all the other icons that were being dragged...
214 void gdk_dnd_drag_addwindow (GdkWindow *window);
215 void gdk_window_dnd_data_set (GdkWindow *window,
218 gulong data_numbytes);
221 void gdk_window_set_hints (GdkWindow *window,
229 void gdk_window_set_title (GdkWindow *window,
231 void gdk_window_set_background (GdkWindow *window,
233 void gdk_window_set_back_pixmap (GdkWindow *window,
235 gint parent_relative);
236 void gdk_window_set_cursor (GdkWindow *window,
238 void gdk_window_set_colormap (GdkWindow *window,
239 GdkColormap *colormap);
240 void gdk_window_get_user_data (GdkWindow *window,
242 void gdk_window_get_geometry (GdkWindow *window,
248 void gdk_window_get_position (GdkWindow *window,
251 void gdk_window_get_size (GdkWindow *window,
254 GdkVisual* gdk_window_get_visual (GdkWindow *window);
255 GdkColormap* gdk_window_get_colormap (GdkWindow *window);
256 GdkWindowType gdk_window_get_type (GdkWindow *window);
257 gint gdk_window_get_origin (GdkWindow *window,
260 GdkWindow* gdk_window_get_pointer (GdkWindow *window,
263 GdkModifierType *mask);
264 GdkWindow* gdk_window_get_parent (GdkWindow *window);
265 GdkWindow* gdk_window_get_toplevel (GdkWindow *window);
266 GList* gdk_window_get_children (GdkWindow *window);
267 GdkEventMask gdk_window_get_events (GdkWindow *window);
268 void gdk_window_set_events (GdkWindow *window,
269 GdkEventMask event_mask);
273 GdkCursor* gdk_cursor_new (GdkCursorType cursor_type);
274 GdkCursor* gdk_cursor_new_from_pixmap (GdkPixmap *source,
280 void gdk_cursor_destroy (GdkCursor *cursor);
285 GdkGC* gdk_gc_new (GdkWindow *window);
286 GdkGC* gdk_gc_new_with_values (GdkWindow *window,
288 GdkGCValuesMask values_mask);
289 void gdk_gc_destroy (GdkGC *gc);
290 void gdk_gc_get_values (GdkGC *gc,
291 GdkGCValues *values);
292 void gdk_gc_set_foreground (GdkGC *gc,
294 void gdk_gc_set_background (GdkGC *gc,
296 void gdk_gc_set_font (GdkGC *gc,
298 void gdk_gc_set_function (GdkGC *gc,
299 GdkFunction function);
300 void gdk_gc_set_fill (GdkGC *gc,
302 void gdk_gc_set_tile (GdkGC *gc,
304 void gdk_gc_set_stipple (GdkGC *gc,
306 void gdk_gc_set_ts_origin (GdkGC *gc,
309 void gdk_gc_set_clip_origin (GdkGC *gc,
312 void gdk_gc_set_clip_mask (GdkGC *gc,
314 void gdk_gc_set_clip_rectangle (GdkGC *gc,
315 GdkRectangle *rectangle);
316 void gdk_gc_set_subwindow (GdkGC *gc,
317 GdkSubwindowMode mode);
318 void gdk_gc_set_exposures (GdkGC *gc,
320 void gdk_gc_set_line_attributes (GdkGC *gc,
322 GdkLineStyle line_style,
323 GdkCapStyle cap_style,
324 GdkJoinStyle join_style);
329 GdkPixmap* gdk_pixmap_new (GdkWindow *window,
333 GdkBitmap* gdk_bitmap_create_from_data (GdkWindow *window,
337 GdkPixmap* gdk_pixmap_create_from_data (GdkWindow *window,
344 GdkPixmap* gdk_pixmap_create_from_xpm (GdkWindow *window,
346 GdkColor *transparent_color,
347 const gchar *filename);
348 GdkPixmap* gdk_pixmap_create_from_xpm_d (GdkWindow *window,
350 GdkColor *transparent_color,
352 void gdk_pixmap_destroy (GdkPixmap *pixmap);
358 GdkImage* gdk_image_new_bitmap(GdkVisual *,
362 GdkImage* gdk_image_new (GdkImageType type,
366 GdkImage* gdk_image_get (GdkWindow *window,
371 void gdk_image_put_pixel (GdkImage *image,
375 guint32 gdk_image_get_pixel (GdkImage *image,
378 void gdk_image_destroy (GdkImage *image);
383 GdkColormap* gdk_colormap_new (GdkVisual *visual,
385 void gdk_colormap_destroy (GdkColormap *colormap);
387 GdkColormap* gdk_colormap_ref (GdkColormap *cmap);
388 void gdk_colormap_unref (GdkColormap *cmap);
390 GdkColormap* gdk_colormap_get_system (void);
391 gint gdk_colormap_get_system_size (void);
393 void gdk_colormap_change (GdkColormap *colormap,
395 void gdk_colors_store (GdkColormap *colormap,
398 gint gdk_colors_alloc (GdkColormap *colormap,
404 void gdk_colors_free (GdkColormap *colormap,
408 gint gdk_color_white (GdkColormap *colormap,
410 gint gdk_color_black (GdkColormap *colormap,
412 gint gdk_color_parse (const gchar *spec,
414 gint gdk_color_alloc (GdkColormap *colormap,
416 gint gdk_color_change (GdkColormap *colormap,
418 gint gdk_color_equal (GdkColor *colora,
424 GdkFont* gdk_font_load (const gchar *font_name);
425 GdkFont* gdk_fontset_load (gchar *fontset_name);
426 void gdk_font_free (GdkFont *font);
427 void gdk_fontset_free (GdkFont *font);
428 GdkFont* gdk_font_ref (GdkFont *font);
429 gint gdk_font_id (GdkFont *font);
430 gint gdk_font_equal (GdkFont *fonta,
432 gint gdk_string_width (GdkFont *font,
433 const gchar *string);
434 gint gdk_text_width (GdkFont *font,
437 gint gdk_char_width (GdkFont *font,
439 gint gdk_string_measure (GdkFont *font,
440 const gchar *string);
441 gint gdk_text_measure (GdkFont *font,
444 gint gdk_char_measure (GdkFont *font,
450 void gdk_draw_point (GdkDrawable *drawable,
454 void gdk_draw_line (GdkDrawable *drawable,
460 void gdk_draw_rectangle (GdkDrawable *drawable,
467 void gdk_draw_arc (GdkDrawable *drawable,
476 void gdk_draw_polygon (GdkDrawable *drawable,
481 void gdk_draw_string (GdkDrawable *drawable,
486 const gchar *string);
487 void gdk_draw_text (GdkDrawable *drawable,
494 void gdk_draw_pixmap (GdkDrawable *drawable,
503 void gdk_draw_bitmap (GdkDrawable *drawable,
512 void gdk_draw_image (GdkDrawable *drawable,
521 void gdk_draw_points (GdkDrawable *drawable,
525 void gdk_draw_segments (GdkDrawable *drawable,
533 gint gdk_selection_owner_set (GdkWindow *owner,
537 GdkWindow* gdk_selection_owner_get (GdkAtom selection);
538 void gdk_selection_convert (GdkWindow *requestor,
542 gint gdk_selection_property_get (GdkWindow *requestor,
546 void gdk_selection_send_notify (guint32 requestor,
552 gint gdk_text_property_to_text_list (GdkAtom encoding, gint format,
553 guchar *text, gint length,
555 void gdk_free_text_list (gchar **list);
556 gint gdk_string_to_compound_text (gchar *str,
557 GdkAtom *encoding, gint *format,
558 guchar **ctext, gint *length);
559 void gdk_free_compound_text (guchar *ctext);
563 GdkAtom gdk_atom_intern (const gchar *atom_name,
564 gint only_if_exists);
565 gchar* gdk_atom_name (GdkAtom atom);
566 gint gdk_property_get (GdkWindow *window,
572 GdkAtom *actual_property_type,
577 void gdk_property_change (GdkWindow *window,
584 void gdk_property_delete (GdkWindow *window,
588 /* Rectangle utilities
590 gint gdk_rectangle_intersect (GdkRectangle *src1,
597 void gdk_input_init (void);
598 void gdk_input_exit (void);
599 GList *gdk_input_list_devices (void);
600 void gdk_input_set_extension_events (GdkWindow *window,
602 GdkExtensionMode mode);
603 void gdk_input_set_source (guint32 deviceid,
604 GdkInputSource source);
605 gint gdk_input_set_mode (guint32 deviceid,
607 void gdk_input_set_axes (guint32 deviceid,
609 void gdk_input_set_key (guint32 deviceid,
612 GdkModifierType modifiers);
613 void gdk_input_window_get_pointer (GdkWindow *window,
620 GdkModifierType *mask);
622 GdkTimeCoord *gdk_input_motion_events (GdkWindow *window,
626 gint *nevents_return);
628 /* International Input Method Support Functions
631 gint gdk_im_ready (void);
633 void gdk_im_begin (GdkIC ic, GdkWindow* window);
634 void gdk_im_end (void);
635 GdkIMStyle gdk_im_decide_style (GdkIMStyle supported_style);
636 GdkIMStyle gdk_im_set_best_style (GdkIMStyle best_allowed_style);
637 GdkIC gdk_ic_new (GdkWindow* client_window,
638 GdkWindow* focus_window,
639 GdkIMStyle style, ...);
640 void gdk_ic_destroy (GdkIC ic);
641 GdkIMStyle gdk_ic_get_style (GdkIC ic);
642 void gdk_ic_set_values (GdkIC ic, ...);
643 void gdk_ic_get_values (GdkIC ic, ...);
644 void gdk_ic_set_attr (GdkIC ic, const char *target, ...);
645 void gdk_ic_get_attr (GdkIC ic, const char *target, ...);
646 GdkEventMask gdk_ic_get_events (GdkIC ic);
649 void gdk_event_send_clientmessage_toall(GdkEvent *event);
653 GdkColorContext *gdk_color_context_new (GdkVisual *visual,
654 GdkColormap *colormap);
656 GdkColorContext *gdk_color_context_new_mono (GdkVisual *visual,
657 GdkColormap *colormap);
659 void gdk_color_context_free (GdkColorContext *cc);
661 gulong gdk_color_context_get_pixel (GdkColorContext *cc,
666 void gdk_color_context_get_pixels (GdkColorContext *cc,
673 void gdk_color_context_get_pixels_incremental (GdkColorContext *cc,
682 gint gdk_color_context_get_num_colors (GdkColorContext *cc);
683 gint gdk_color_context_get_depth (GdkColorContext *cc);
684 GdkColorContextMode gdk_color_context_get_mode (GdkColorContext *cc);
685 gint gdk_color_context_query_color (GdkColorContext *cc,
687 gint gdk_color_context_query_colors (GdkColorContext *cc,
691 gint gdk_color_context_add_palette (GdkColorContext *cc,
695 void gdk_color_context_init_dither (GdkColorContext *cc);
696 void gdk_color_context_free_dither (GdkColorContext *cc);
698 gulong gdk_color_context_get_pixel_from_palette (GdkColorContext *cc,
703 guchar gdk_color_context_get_index_from_palette (GdkColorContext *cc,
712 #endif /* __cplusplus */
715 #endif /* __GDK_H__ */