|  |  |  | GDK Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | ||||
#include <gdk/gdkx.h> #define GDK_ROOT_WINDOW #define GDK_WINDOW_XDISPLAY (win) #define GDK_WINDOW_XID (win) #define GDK_DISPLAY_XDISPLAY (display) #define GDK_DRAWABLE_XDISPLAY (win) #define GDK_DRAWABLE_XID (win) #define GDK_SCREEN_XDISPLAY (screen) #define GDK_SCREEN_XNUMBER (screen) #define GDK_SCREEN_XSCREEN (screen) #define GDK_CURSOR_XCURSOR (cursor) #define GDK_CURSOR_XDISPLAY (cursor) #define GDK_WINDOW_XWINDOW GdkVisual* gdkx_visual_get (VisualID xvisualid); GdkWindow* gdk_window_foreign_new (GdkNativeWindow anid); GdkWindow * gdk_window_foreign_new_for_display (GdkDisplay *display,GdkNativeWindow anid); gpointer gdk_xid_table_lookup (XID xid); gpointer gdk_xid_table_lookup_for_display (GdkDisplay *display,XID xid); GdkWindow* gdk_window_lookup (GdkNativeWindow anid); GdkWindow* gdk_window_lookup_for_display (GdkDisplay *display,GdkNativeWindow anid); GdkDisplay * gdk_x11_lookup_xdisplay (Display *xdisplay); guint32 gdk_x11_get_server_time (GdkWindow *window); gboolean gdk_net_wm_supports (GdkAtom property); gboolean gdk_x11_screen_supports_net_wm_hint (GdkScreen *screen,GdkAtom property); const char* gdk_x11_screen_get_window_manager_name (GdkScreen *screen); XID gdk_x11_screen_get_monitor_output (GdkScreen *screen,gint monitor_num); GdkVisual* gdk_x11_screen_lookup_visual (GdkScreen *screen,VisualID xvisualid); void gdk_x11_window_set_user_time (GdkWindow *window,guint32 timestamp); void gdk_x11_window_move_to_current_desktop (GdkWindow *window); guint32 gdk_x11_display_get_user_time (GdkDisplay *display); Cursor gdk_x11_cursor_get_xcursor (GdkCursor *cursor); Display * gdk_x11_cursor_get_xdisplay (GdkCursor *cursor); void gdk_x11_display_broadcast_startup_message (GdkDisplay *display,const char *message_type,...); const gchar * gdk_x11_display_get_startup_notification_id (GdkDisplay *display); Display * gdk_x11_display_get_xdisplay (GdkDisplay *display); void gdk_x11_display_grab (GdkDisplay *display); void gdk_x11_display_ungrab (GdkDisplay *display); void gdk_x11_display_error_trap_push (GdkDisplay *display); void gdk_x11_display_error_trap_pop_ignored (GdkDisplay *display); void gdk_x11_display_set_cursor_theme (GdkDisplay *display,const gchar *theme,const gint size); void gdk_x11_register_standard_event_type (GdkDisplay *display,gint event_base,gint n_events); Display * gdk_x11_drawable_get_xdisplay (GdkDrawable *drawable); XID gdk_x11_drawable_get_xid (GdkDrawable *drawable); Window gdk_x11_get_default_root_xwindow (void); gint gdk_x11_get_default_screen (void); Display * gdk_x11_get_default_xdisplay (void); void gdk_x11_grab_server (void); int gdk_x11_screen_get_screen_number (GdkScreen *screen); Screen * gdk_x11_screen_get_xscreen (GdkScreen *screen); void gdk_x11_ungrab_server (void); Visual * gdk_x11_visual_get_xvisual (GdkVisual *visual); Atom gdk_x11_atom_to_xatom (GdkAtom atom); Atom gdk_x11_atom_to_xatom_for_display (GdkDisplay *display,GdkAtom atom); GdkAtom gdk_x11_xatom_to_atom (Atom xatom); GdkAtom gdk_x11_xatom_to_atom_for_display (GdkDisplay *display,Atom xatom); Atom gdk_x11_get_xatom_by_name (const gchar *atom_name); Atom gdk_x11_get_xatom_by_name_for_display (GdkDisplay *display,const gchar *atom_name); const gchar * gdk_x11_get_xatom_name (Atom xatom); const gchar * gdk_x11_get_xatom_name_for_display (GdkDisplay *display,Atom xatom);
#define GDK_ROOT_WINDOW() (gdk_x11_get_default_root_xwindow ())
Obtains the Xlib window id of the root window of the current screen.
#define GDK_WINDOW_XDISPLAY(win)
Returns the display of a GdkWindow.
| 
 | a GdkWindow. | 
| Returns : | an Xlib Display*. | 
#define GDK_WINDOW_XID(win)
Returns the X window belonging to a GdkWindow.
| 
 | a GdkWindow. | 
| Returns : | the Xlib Window of win. | 
#define GDK_DISPLAY_XDISPLAY(display)
Returns the display of a GdkDisplay.
| 
 | a GdkDisplay. | 
#define GDK_DRAWABLE_XDISPLAY(win)
Returns the display of a GdkDrawable.
| 
 | a GdkDrawable. | 
| Returns : | an Xlib Display*. | 
#define GDK_DRAWABLE_XID(win)
Returns the X resource (window or pixmap) belonging to a GdkDrawable.
| 
 | a GdkDrawable. | 
| Returns : | the ID of win's X resource. | 
#define GDK_SCREEN_XDISPLAY(screen)
Returns the display of a GdkScreen.
| 
 | a GdkScreen. | 
| Returns : | an Xlib Display*. | 
#define GDK_SCREEN_XNUMBER(screen)
Returns the index of a GdkScreen.
| 
 | a GdkScreen | 
| Returns : | the position of screenamong the screens of
  its display. | 
#define GDK_SCREEN_XSCREEN(screen)
Returns the screen of a GdkScreen.
| 
 | a GdkScreen | 
| Returns : | an Xlib Screen*. | 
#define GDK_CURSOR_XCURSOR(cursor) (gdk_x11_cursor_get_xcursor (cursor))
Returns the X cursor belonging to a GdkCursor.
| 
 | a GdkCursor. | 
| Returns : | an Xlib Cursor. | 
#define GDK_CURSOR_XDISPLAY(cursor) (gdk_x11_cursor_get_xdisplay (cursor))
Returns the display of a GdkCursor.
| 
 | a GdkCursor. | 
| Returns : | an Xlib Display*. | 
GdkVisual*          gdkx_visual_get                     (VisualID xvisualid);
Returns a GdkVisual corresponding to a X visual.
| 
 | a X visual id. | 
| Returns : | the GdkVisual. | 
GdkWindow*          gdk_window_foreign_new              (GdkNativeWindow anid);
Wraps a native window for the default display in a GdkWindow. This may fail if the window has been destroyed.
For example in the X backend, a native window handle is an Xlib XID.
GdkWindow * gdk_window_foreign_new_for_display (GdkDisplay *display,GdkNativeWindow anid);
Wraps a native window in a GdkWindow. This may fail if the window has been destroyed. If the window was already known to GDK, a new reference to the existing GdkWindow is returned.
For example in the X backend, a native window handle is an Xlib XID.
| 
 | the GdkDisplay where the window handle comes from. | 
| 
 | a native window handle. | 
| Returns : | a GdkWindow wrapper for the native window or NULLif the window has been destroyed. The wrapper will be
  newly created, if one doesn't exist already. | 
Since 2.2
gpointer            gdk_xid_table_lookup                (XID xid);
Returns the Gdk object associated with the given X id for the default display.
gpointer gdk_xid_table_lookup_for_display (GdkDisplay *display,XID xid);
Returns the GDK object associated with the given X id.
| 
 | the GdkDisplay. | 
| 
 | an X id. | 
| Returns : | the associated GdkWindow or NULLif no
    object is associated with the X id. | 
Since 2.2
GdkWindow*          gdk_window_lookup                   (GdkNativeWindow anid);
Looks up the GdkWindow that wraps the given native window handle.
For example in the X backend, a native window handle is an Xlib XID.
GdkWindow* gdk_window_lookup_for_display (GdkDisplay *display,GdkNativeWindow anid);
Looks up the GdkWindow that wraps the given native window handle.
For example in the X backend, a native window handle is an Xlib XID.
| 
 | the GdkDisplay corresponding to the window handle | 
| 
 | a native window handle. | 
| Returns : | the GdkWindow wrapper for the native window, 
   or NULLif there is none. | 
Since 2.2
GdkDisplay *        gdk_x11_lookup_xdisplay             (Display *xdisplay);
Find the GdkDisplay corresponding to display, if any exists.
| 
 | a pointer to an X Display | 
| Returns : | the GdkDisplay, if found, otherwise NULL. | 
Since 2.2
guint32             gdk_x11_get_server_time             (GdkWindow *window);
Routine to get the current X server time stamp.
| 
 | a GdkWindow, used for communication with the server. The window must have GDK_PROPERTY_CHANGE_MASK in its events mask or a hang will result. | 
| Returns : | the time stamp. | 
gboolean            gdk_net_wm_supports                 (GdkAtom property);
This function is specific to the X11 backend of GDK, and indicates
whether the window manager for the default screen supports a certain
hint from the Extended Window Manager Hints Specification. See
gdk_x11_screen_supports_net_wm_hint() for complete details.
| 
 | a property atom. | 
| Returns : | TRUEif the window manager supportsproperty | 
gboolean gdk_x11_screen_supports_net_wm_hint (GdkScreen *screen,GdkAtom property);
This function is specific to the X11 backend of GDK, and indicates whether the window manager supports a certain hint from the Extended Window Manager Hints Specification. You can find this specification on http://www.freedesktop.org.
When using this function, keep in mind that the window manager
can change over time; so you shouldn't use this function in
a way that impacts persistent application state. A common bug
is that your application can start up before the window manager
does when the user logs in, and before the window manager starts
gdk_x11_screen_supports_net_wm_hint() will return FALSE for every property.
You can monitor the window_manager_changed signal on GdkScreen to detect
a window manager change.
| 
 | the relevant GdkScreen. | 
| 
 | a property atom. | 
| Returns : | TRUEif the window manager supportsproperty | 
Since 2.2
const char*         gdk_x11_screen_get_window_manager_name
                                                        (GdkScreen *screen);
Returns the name of the window manager for screen.
| 
 | a GdkScreen | 
| Returns : | the name of the window manager screen screen, or
"unknown" if the window manager is unknown. The string is owned by GDK
and should not be freed. | 
Since 2.2
XID gdk_x11_screen_get_monitor_output (GdkScreen *screen,gint monitor_num);
Gets the XID of the specified output/monitor. If the X server does not support version 1.2 of the RANDR extension, 0 is returned.
| 
 | a GdkScreen | 
| 
 | number of the monitor, between 0 and gdk_screen_get_n_monitors (screen) | 
| Returns : | the XID of the monitor | 
Since 2.14
GdkVisual* gdk_x11_screen_lookup_visual (GdkScreen *screen,VisualID xvisualid);
Looks up the GdkVisual for a particular screen and X Visual ID.
| 
 | a GdkScreen. | 
| 
 | an X Visual ID. | 
| Returns : | the GdkVisual (owned by the screen object), or NULLif the visual ID wasn't found. | 
Since 2.2
void gdk_x11_window_set_user_time (GdkWindow *window,guint32 timestamp);
The application can use this call to update the _NET_WM_USER_TIME property on a toplevel window. This property stores an Xserver time which represents the time of the last user input event received for this window. This property may be used by the window manager to alter the focus, stacking, and/or placement behavior of windows when they are mapped depending on whether the new window was created by a user action or is a "pop-up" window activated by a timer or some other event.
Note that this property is automatically updated by GDK, so this function should only be used by applications which handle input events bypassing GDK.
| 
 | A toplevel GdkWindow | 
| 
 | An XServer timestamp to which the property should be set | 
Since 2.6
void                gdk_x11_window_move_to_current_desktop
                                                        (GdkWindow *window);
Moves the window to the correct workspace when running under a window manager that supports multiple workspaces, as described in the Extended Window Manager Hints. Will not do anything if the window is already on all workspaces.
| 
 | a GdkWindow | 
Since 2.8
guint32             gdk_x11_display_get_user_time       (GdkDisplay *display);
Returns the timestamp of the last user interaction on 
display. The timestamp is taken from events caused
by user interaction such as key presses or pointer 
movements. See gdk_x11_window_set_user_time().
| 
 | a GdkDisplay | 
| Returns : | the timestamp of the last user interaction | 
Since 2.8
Cursor              gdk_x11_cursor_get_xcursor          (GdkCursor *cursor);
Returns the X cursor belonging to a GdkCursor.
| 
 | a GdkCursor. | 
| Returns : | an Xlib Cursor. | 
Display *           gdk_x11_cursor_get_xdisplay         (GdkCursor *cursor);
Returns the display of a GdkCursor.
| 
 | a GdkCursor. | 
| Returns : | an Xlib Display*. | 
void gdk_x11_display_broadcast_startup_message (GdkDisplay *display,const char *message_type,...);
Sends a startup notification message of type message_type to
display. 
This is a convenience function for use by code that implements the freedesktop startup notification specification. Applications should not normally need to call it directly. See the Startup Notification Protocol specification for definitions of the message types and keys that can be used.
| 
 | a GdkDisplay | 
| 
 | startup notification message type ("new", "change", or "remove") | 
| 
 | a list of key/value pairs (as strings), terminated by a NULLkey. (ANULLvalue for a key will cause that key to be
skipped in the output.) | 
Since 2.12
const gchar *       gdk_x11_display_get_startup_notification_id
                                                        (GdkDisplay *display);
Gets the startup notification ID for a display.
| 
 | a GdkDisplay | 
| Returns : | the startup notification ID for display | 
Since 2.12
Display *           gdk_x11_display_get_xdisplay        (GdkDisplay *display);
Returns the X display of a GdkDisplay.
| 
 | a GdkDisplay | 
| Returns : | an X display. | 
Since 2.2
void                gdk_x11_display_grab                (GdkDisplay *display);
Call XGrabServer() on display. 
To ungrab the display again, use gdk_x11_display_ungrab(). 
gdk_x11_display_grab()/gdk_x11_display_ungrab() calls can be nested.
| 
 | a GdkDisplay | 
Since 2.2
void                gdk_x11_display_ungrab              (GdkDisplay *display);
Ungrab display after it has been grabbed with 
gdk_x11_display_grab().
| 
 | a GdkDisplay | 
Since 2.2
void                gdk_x11_display_error_trap_push     (GdkDisplay *display);
Begins a range of X requests on display for which X error events
will be ignored. Unignored errors (when no trap is pushed) will abort
the application. Use gdk_x11_display_error_trap_pop() or
gdk_x11_display_error_trap_pop_ignored()to lift a trap pushed
with this function.
See also gdk_error_trap_push() to push a trap on all displays.
| 
 | a GdkDisplay | 
Since 3.0
void                gdk_x11_display_error_trap_pop_ignored
                                                        (GdkDisplay *display);
Pops the error trap pushed by gdk_x11_display_error_trap_push().
Does not block to see if an error occurred; merely records the
range of requests to ignore errors for, and ignores those errors
if they arrive asynchronously.
See gdk_error_trap_pop_ignored() for the all-displays-at-once
equivalent.
| 
 | the display | 
Since 3.0
void gdk_x11_display_set_cursor_theme (GdkDisplay *display,const gchar *theme,const gint size);
Sets the cursor theme from which the images for cursor should be taken.
If the windowing system supports it, existing cursors created 
with gdk_cursor_new(), gdk_cursor_new_for_display() and 
gdk_cursor_new_for_name() are updated to reflect the theme 
change. Custom cursors constructed with
gdk_cursor_new_from_pixbuf() will have to be handled
by the application (GTK+ applications can learn about 
cursor theme changes by listening for change notification
for the corresponding GtkSetting).
| 
 | a GdkDisplay | 
| 
 | the name of the cursor theme to use, or NULLto unset
        a previously set value | 
| 
 | the cursor size to use, or 0 to keep the previous size | 
Since 2.8
void gdk_x11_register_standard_event_type (GdkDisplay *display,gint event_base,gint n_events);
Registers interest in receiving extension events with type codes
between event_base and event_base + n_events - 1.
The registered events must have the window field in the same place
as core X events (this is not the case for e.g. XKB extension events).
If an event type is registered, events of this type will go through
global and window-specific filters (see gdk_window_add_filter()).
Unregistered events will only go through global filters.
GDK may register the events of some X extensions on its own.
This function should only be needed in unusual circumstances, e.g. when filtering XInput extension events on the root window.
| 
 | a GdkDisplay | 
| 
 | first event type code to register | 
| 
 | number of event type codes to register | 
Since 2.4
Display *           gdk_x11_drawable_get_xdisplay       (GdkDrawable *drawable);
Returns the display of a GdkDrawable.
| 
 | a GdkDrawable. | 
| Returns : | an Xlib Display*. | 
XID                 gdk_x11_drawable_get_xid            (GdkDrawable *drawable);
Returns the X resource (window) belonging to a GdkDrawable.
| 
 | a GdkDrawable. | 
| Returns : | the ID of drawable's X resource. | 
Window              gdk_x11_get_default_root_xwindow    (void);
Gets the root window of the default screen 
(see gdk_x11_get_default_screen()).
| Returns : | an Xlib Window. | 
gint                gdk_x11_get_default_screen          (void);
Gets the default GTK+ screen number.
| Returns : | returns the screen number specified by
  the --display command line option or the DISPLAY environment
  variable when gdk_init()callsXOpenDisplay(). | 
Display *           gdk_x11_get_default_xdisplay        (void);
Gets the default GTK+ display.
| Returns : | the Xlib Display* for the display
specified in the --displaycommand line option 
or theDISPLAYenvironment variable. | 
void                gdk_x11_grab_server                 (void);
Call gdk_x11_display_grab() on the default display. 
To ungrab the server again, use gdk_x11_ungrab_server(). 
gdk_x11_grab_server()/gdk_x11_ungrab_server() calls can be nested.
int                 gdk_x11_screen_get_screen_number    (GdkScreen *screen);
Returns the index of a GdkScreen.
| 
 | a GdkScreen. | 
| Returns : | the position of screenamong the screens of
  its display. | 
Since 2.2
Screen *            gdk_x11_screen_get_xscreen          (GdkScreen *screen);
Returns the screen of a GdkScreen.
| 
 | a GdkScreen. | 
| Returns : | an Xlib Screen*. [transfer none] | 
Since 2.2
void                gdk_x11_ungrab_server               (void);
Ungrab the default display after it has been grabbed with 
gdk_x11_grab_server().
Visual *            gdk_x11_visual_get_xvisual          (GdkVisual *visual);
Returns the X visual belonging to a GdkVisual.
| 
 | a GdkVisual. | 
| Returns : | an Xlib Visual*. | 
Atom                gdk_x11_atom_to_xatom               (GdkAtom atom);
Converts from a GdkAtom to the X atom for the default GDK display with the same string value.
| 
 | A GdkAtom | 
| Returns : | the X atom corresponding to atom. | 
Atom gdk_x11_atom_to_xatom_for_display (GdkDisplay *display,GdkAtom atom);
Converts from a GdkAtom to the X atom for a GdkDisplay
with the same string value. The special value GDK_NONE
is converted to None.
| 
 | A GdkDisplay | 
| 
 | A GdkAtom, or GDK_NONE | 
| Returns : | the X atom corresponding to atom, orNone | 
Since 2.2
GdkAtom             gdk_x11_xatom_to_atom               (Atom xatom);
Convert from an X atom for the default display to the corresponding GdkAtom.
| 
 | an X atom for the default GDK display | 
| Returns : | the corresponding GdkAtom. | 
GdkAtom gdk_x11_xatom_to_atom_for_display (GdkDisplay *display,Atom xatom);
Convert from an X atom for a GdkDisplay to the corresponding GdkAtom.
| 
 | A GdkDisplay | 
| 
 | an X atom | 
| Returns : | the corresponding GdkAtom. | 
Since 2.2
Atom                gdk_x11_get_xatom_by_name           (const gchar *atom_name);
Returns the X atom for GDK's default display corresponding to atom_name.
This function caches the result, so if called repeatedly it is much
faster than XInternAtom(), which is a round trip to the server each time.
| 
 | a string | 
| Returns : | a X atom for GDK's default display. | 
Atom gdk_x11_get_xatom_by_name_for_display (GdkDisplay *display,const gchar *atom_name);
Returns the X atom for a GdkDisplay corresponding to atom_name.
This function caches the result, so if called repeatedly it is much
faster than XInternAtom(), which is a round trip to the server each time.
| 
 | a GdkDisplay | 
| 
 | a string | 
| Returns : | a X atom for a GdkDisplay | 
Since 2.2
const gchar *       gdk_x11_get_xatom_name              (Atom xatom);
Returns the name of an X atom for GDK's default display. This
function is meant mainly for debugging, so for convenience, unlike
XAtomName()gdk_atom_name(), the result 
doesn't need to be freed. Also, this function will never return NULL, 
even if xatom is invalid.
| 
 | an X atom for GDK's default display | 
| Returns : | name of the X atom; this string is owned by GTK+, so it shouldn't be modifed or freed. | 
const gchar * gdk_x11_get_xatom_name_for_display (GdkDisplay *display,Atom xatom);
Returns the name of an X atom for its display. This
function is meant mainly for debugging, so for convenience, unlike
XAtomName() and gdk_atom_name(), the result doesn't need to
be freed.
| 
 | the GdkDisplay where xatomis defined | 
| 
 | an X atom | 
| Returns : | name of the X atom; this string is owned by GDK, so it shouldn't be modifed or freed. | 
Since 2.2