2008-07-01 22:57:50 +00:00
|
|
|
/* GDK - The GIMP Drawing Kit
|
2008-06-27 14:27:44 +00:00
|
|
|
* Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* 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
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
* Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Modified by the GTK+ Team and others 1997-2000. See the AUTHORS
|
|
|
|
* file for a list of people on the GTK+ Team. See the ChangeLog
|
|
|
|
* files for a list of changes. These files are distributed with
|
|
|
|
* GTK+ at ftp://ftp.gtk.org/pub/gtk/.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __GDK_WINDOW_IMPL_H__
|
|
|
|
#define __GDK_WINDOW_IMPL_H__
|
|
|
|
|
|
|
|
#include <gdk/gdkwindow.h>
|
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
#define GDK_TYPE_WINDOW_IMPL (gdk_window_impl_get_type ())
|
2010-11-22 19:42:00 +00:00
|
|
|
#define GDK_WINDOW_IMPL(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GDK_TYPE_WINDOW_IMPL, GdkWindowImpl))
|
|
|
|
#define GDK_WINDOW_IMPL_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GDK_TYPE_WINDOW_IMPL, GdkWindowImplClass))
|
|
|
|
#define GDK_IS_WINDOW_IMPL(object) (G_TYPE_CHECK_INSTANCE_TYPE ((object), GDK_TYPE_WINDOW_IMPL))
|
|
|
|
#define GDK_IS_WINDOW_IMPL_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GDK_TYPE_WINDOW_IMPL))
|
|
|
|
#define GDK_WINDOW_IMPL_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GDK_TYPE_WINDOW_IMPL, GdkWindowImplClass))
|
2008-06-27 14:27:44 +00:00
|
|
|
|
2010-11-22 19:42:00 +00:00
|
|
|
typedef struct _GdkWindowImpl GdkWindowImpl;
|
|
|
|
typedef struct _GdkWindowImplClass GdkWindowImplClass;
|
2008-06-27 14:27:44 +00:00
|
|
|
|
2010-11-22 19:42:00 +00:00
|
|
|
struct _GdkWindowImpl
|
2008-06-27 14:27:44 +00:00
|
|
|
{
|
2010-11-24 14:11:34 +00:00
|
|
|
GObject parent;
|
2010-11-22 19:42:00 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct _GdkWindowImplClass
|
|
|
|
{
|
2010-11-24 14:11:34 +00:00
|
|
|
GObjectClass parent_class;
|
2008-06-27 14:27:44 +00:00
|
|
|
|
2010-11-23 00:46:03 +00:00
|
|
|
cairo_surface_t *
|
|
|
|
(* ref_cairo_surface) (GdkWindow *window);
|
|
|
|
|
2009-06-16 19:34:37 +00:00
|
|
|
void (* show) (GdkWindow *window,
|
|
|
|
gboolean already_mapped);
|
2008-06-27 14:27:44 +00:00
|
|
|
void (* hide) (GdkWindow *window);
|
|
|
|
void (* withdraw) (GdkWindow *window);
|
|
|
|
void (* raise) (GdkWindow *window);
|
|
|
|
void (* lower) (GdkWindow *window);
|
2009-01-19 11:47:38 +00:00
|
|
|
void (* restack_under) (GdkWindow *window,
|
|
|
|
GList *native_siblings);
|
2009-09-02 21:38:55 +00:00
|
|
|
void (* restack_toplevel) (GdkWindow *window,
|
|
|
|
GdkWindow *sibling,
|
|
|
|
gboolean above);
|
2008-06-27 14:27:44 +00:00
|
|
|
|
|
|
|
void (* move_resize) (GdkWindow *window,
|
|
|
|
gboolean with_move,
|
|
|
|
gint x,
|
|
|
|
gint y,
|
|
|
|
gint width,
|
|
|
|
gint height);
|
|
|
|
void (* set_background) (GdkWindow *window,
|
2010-08-15 11:49:30 +00:00
|
|
|
cairo_pattern_t *pattern);
|
2008-06-27 14:27:44 +00:00
|
|
|
|
|
|
|
GdkEventMask (* get_events) (GdkWindow *window);
|
|
|
|
void (* set_events) (GdkWindow *window,
|
|
|
|
GdkEventMask event_mask);
|
|
|
|
|
|
|
|
gboolean (* reparent) (GdkWindow *window,
|
|
|
|
GdkWindow *new_parent,
|
|
|
|
gint x,
|
|
|
|
gint y);
|
2010-05-25 22:38:44 +00:00
|
|
|
|
|
|
|
void (* set_device_cursor) (GdkWindow *window,
|
|
|
|
GdkDevice *device,
|
2008-06-27 14:27:44 +00:00
|
|
|
GdkCursor *cursor);
|
|
|
|
|
|
|
|
void (* get_geometry) (GdkWindow *window,
|
|
|
|
gint *x,
|
|
|
|
gint *y,
|
|
|
|
gint *width,
|
2010-12-05 13:40:35 +00:00
|
|
|
gint *height);
|
2009-06-08 15:03:47 +00:00
|
|
|
gint (* get_root_coords) (GdkWindow *window,
|
|
|
|
gint x,
|
|
|
|
gint y,
|
|
|
|
gint *root_x,
|
|
|
|
gint *root_y);
|
2010-05-25 22:38:44 +00:00
|
|
|
gboolean (* get_device_state) (GdkWindow *window,
|
|
|
|
GdkDevice *device,
|
2009-06-04 17:21:20 +00:00
|
|
|
gint *x,
|
|
|
|
gint *y,
|
2010-05-25 22:38:44 +00:00
|
|
|
GdkModifierType *mask);
|
2008-06-27 14:27:44 +00:00
|
|
|
|
2010-11-25 11:17:11 +00:00
|
|
|
cairo_region_t * (* get_shape) (GdkWindow *window);
|
|
|
|
cairo_region_t * (* get_input_shape) (GdkWindow *window);
|
2008-06-27 14:27:44 +00:00
|
|
|
void (* shape_combine_region) (GdkWindow *window,
|
2010-06-28 12:54:37 +00:00
|
|
|
const cairo_region_t *shape_region,
|
2008-06-27 14:27:44 +00:00
|
|
|
gint offset_x,
|
|
|
|
gint offset_y);
|
2008-12-17 10:24:46 +00:00
|
|
|
void (* input_shape_combine_region) (GdkWindow *window,
|
2010-06-28 12:54:37 +00:00
|
|
|
const cairo_region_t *shape_region,
|
2008-12-17 10:24:46 +00:00
|
|
|
gint offset_x,
|
|
|
|
gint offset_y);
|
2008-06-27 14:27:44 +00:00
|
|
|
|
|
|
|
gboolean (* set_static_gravities) (GdkWindow *window,
|
|
|
|
gboolean use_static);
|
2008-07-18 13:03:42 +00:00
|
|
|
|
|
|
|
/* Called before processing updates for a window. This gives the windowing
|
|
|
|
* layer a chance to save the region for later use in avoiding duplicate
|
|
|
|
* exposes. The return value indicates whether the function has a saved
|
|
|
|
* the region; if the result is TRUE, then the windowing layer is responsible
|
|
|
|
* for destroying the region later.
|
|
|
|
*/
|
|
|
|
gboolean (* queue_antiexpose) (GdkWindow *window,
|
2010-07-21 18:37:33 +00:00
|
|
|
cairo_region_t *update_area);
|
|
|
|
|
|
|
|
/* Called to move @area inside @window by @dx x @dy pixels. @area is
|
|
|
|
* guaranteed to be inside @window. If part of @area is not invisible or
|
|
|
|
* invalid, it is this function's job to queue expose events in those
|
|
|
|
* areas.
|
|
|
|
*/
|
|
|
|
void (* translate) (GdkWindow *window,
|
|
|
|
cairo_region_t *area,
|
2008-12-15 13:55:53 +00:00
|
|
|
gint dx,
|
|
|
|
gint dy);
|
2008-12-15 14:04:44 +00:00
|
|
|
|
|
|
|
/* Called to do the windowing system specific part of gdk_window_destroy(),
|
|
|
|
*
|
|
|
|
* window: The window being destroyed
|
|
|
|
* recursing: If TRUE, then this is being called because a parent
|
|
|
|
* was destroyed. This generally means that the call to the windowing system
|
|
|
|
* to destroy the window can be omitted, since it will be destroyed as a result
|
|
|
|
* of the parent being destroyed. Unless @foreign_destroy
|
|
|
|
*
|
|
|
|
* foreign_destroy: If TRUE, the window or a parent was destroyed by some external
|
|
|
|
* agency. The window has already been destroyed and no windowing
|
|
|
|
* system calls should be made. (This may never happen for some
|
|
|
|
* windowing systems.)
|
|
|
|
*/
|
|
|
|
void (* destroy) (GdkWindow *window,
|
|
|
|
gboolean recursing,
|
|
|
|
gboolean foreign_destroy);
|
2010-10-05 13:21:40 +00:00
|
|
|
|
2010-11-23 01:09:01 +00:00
|
|
|
cairo_surface_t * (* resize_cairo_surface) (GdkWindow *window,
|
2010-10-05 13:21:40 +00:00
|
|
|
cairo_surface_t *surface,
|
|
|
|
gint width,
|
|
|
|
gint height);
|
2010-11-25 11:28:08 +00:00
|
|
|
|
|
|
|
/* optional */
|
|
|
|
gboolean (* beep) (GdkWindow *window);
|
2010-12-05 20:58:23 +00:00
|
|
|
|
|
|
|
void (* focus) (GdkWindow *window,
|
|
|
|
guint32 timestamp);
|
|
|
|
void (* set_type_hint) (GdkWindow *window,
|
|
|
|
GdkWindowTypeHint hint);
|
|
|
|
GdkWindowTypeHint (* get_type_hint) (GdkWindow *window);
|
|
|
|
void (* set_modal_hint) (GdkWindow *window,
|
|
|
|
gboolean modal);
|
|
|
|
void (* set_skip_taskbar_hint) (GdkWindow *window,
|
|
|
|
gboolean skips_taskbar);
|
|
|
|
void (* set_skip_pager_hint) (GdkWindow *window,
|
|
|
|
gboolean skips_pager);
|
|
|
|
void (* set_urgency_hint) (GdkWindow *window,
|
|
|
|
gboolean urgent);
|
|
|
|
void (* set_geometry_hints) (GdkWindow *window,
|
|
|
|
const GdkGeometry *geometry,
|
|
|
|
GdkWindowHints geom_mask);
|
|
|
|
void (* set_title) (GdkWindow *window,
|
|
|
|
const gchar *title);
|
|
|
|
void (* set_role) (GdkWindow *window,
|
|
|
|
const gchar *role);
|
|
|
|
void (* set_startup_id) (GdkWindow *window,
|
|
|
|
const gchar *startup_id);
|
|
|
|
void (* set_transient_for) (GdkWindow *window,
|
|
|
|
GdkWindow *parent);
|
|
|
|
void (* get_root_origin) (GdkWindow *window,
|
|
|
|
gint *x,
|
|
|
|
gint *y);
|
|
|
|
void (* get_frame_extents) (GdkWindow *window,
|
|
|
|
GdkRectangle *rect);
|
|
|
|
void (* set_override_redirect) (GdkWindow *window,
|
|
|
|
gboolean override_redirect);
|
|
|
|
void (* set_accept_focus) (GdkWindow *window,
|
|
|
|
gboolean accept_focus);
|
|
|
|
void (* set_focus_on_map) (GdkWindow *window,
|
|
|
|
gboolean focus_on_map);
|
|
|
|
void (* set_icon_list) (GdkWindow *window,
|
|
|
|
GList *pixbufs);
|
|
|
|
void (* set_icon_name) (GdkWindow *window,
|
|
|
|
const gchar *name);
|
|
|
|
void (* iconify) (GdkWindow *window);
|
|
|
|
void (* deiconify) (GdkWindow *window);
|
|
|
|
void (* stick) (GdkWindow *window);
|
|
|
|
void (* unstick) (GdkWindow *window);
|
|
|
|
void (* maximize) (GdkWindow *window);
|
|
|
|
void (* unmaximize) (GdkWindow *window);
|
|
|
|
void (* fullscreen) (GdkWindow *window);
|
|
|
|
void (* unfullscreen) (GdkWindow *window);
|
|
|
|
void (* set_keep_above) (GdkWindow *window,
|
|
|
|
gboolean setting);
|
|
|
|
void (* set_keep_below) (GdkWindow *window,
|
|
|
|
gboolean setting);
|
|
|
|
GdkWindow * (* get_group) (GdkWindow *window);
|
|
|
|
void (* set_group) (GdkWindow *window,
|
|
|
|
GdkWindow *leader);
|
|
|
|
void (* set_decorations) (GdkWindow *window,
|
|
|
|
GdkWMDecoration decorations);
|
|
|
|
gboolean (* get_decorations) (GdkWindow *window,
|
|
|
|
GdkWMDecoration *decorations);
|
|
|
|
void (* set_functions) (GdkWindow *window,
|
|
|
|
GdkWMFunction functions);
|
|
|
|
void (* begin_resize_drag) (GdkWindow *window,
|
|
|
|
GdkWindowEdge edge,
|
|
|
|
gint button,
|
|
|
|
gint root_x,
|
|
|
|
gint root_y,
|
|
|
|
guint32 timestamp);
|
|
|
|
void (* begin_move_drag) (GdkWindow *window,
|
|
|
|
gint button,
|
|
|
|
gint root_x,
|
|
|
|
gint root_y,
|
|
|
|
guint32 timestamp);
|
|
|
|
void (* enable_synchronized_configure) (GdkWindow *window);
|
|
|
|
void (* configure_finished) (GdkWindow *window);
|
|
|
|
void (* set_opacity) (GdkWindow *window,
|
|
|
|
gdouble opacity);
|
|
|
|
void (* destroy_notify) (GdkWindow *window);
|
|
|
|
void (* register_dnd) (GdkWindow *window);
|
2008-06-27 14:27:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Interface Functions */
|
|
|
|
GType gdk_window_impl_get_type (void) G_GNUC_CONST;
|
|
|
|
|
2008-07-18 13:03:42 +00:00
|
|
|
|
2008-06-27 14:27:44 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif /* __GDK_WINDOW_IMPL_H__ */
|