Top |
GdkScreen objects are the GDK representation of the screen on
which windows can be displayed and on which the pointer moves.
X originally identified screens with physical screens, but
nowadays it is more common to have a single GdkScreen which
combines several physical monitors (see gdk_screen_get_n_monitors()
).
GdkScreen is used throughout GDK and GTK+ to specify which screen
the top level windows are to be displayed on. it is also used to
query the screen specification and default settings such as
the default visual (gdk_screen_get_system_visual()
), the dimensions
of the physical monitors (gdk_screen_get_monitor_geometry()
), etc.
GdkScreen *
gdk_screen_get_default (void
);
Gets the default screen for the default display. (See
gdk_display_get_default()
).
Since: 2.2
GdkVisual *
gdk_screen_get_system_visual (GdkScreen *screen
);
Get the system’s default visual for screen
.
This is the visual for the root window of the display.
The return value should not be freed.
Since: 2.2
GdkVisual *
gdk_screen_get_rgba_visual (GdkScreen *screen
);
Gets a visual to use for creating windows with an alpha channel.
The windowing system on which GTK+ is running
may not support this capability, in which case NULL
will
be returned. Even if a non-NULL
value is returned, its
possible that the window’s alpha channel won’t be honored
when displaying the window on the screen: in particular, for
X an appropriate windowing manager and compositing manager
must be running to provide appropriate display.
This functionality is not implemented in the Windows backend.
For setting an overall opacity for a top-level window, see
gdk_window_set_opacity()
.
a visual to use for windows
with an alpha channel or NULL
if the capability is not
available.
[nullable][transfer none]
Since: 2.8
gboolean
gdk_screen_is_composited (GdkScreen *screen
);
Returns whether windows with an RGBA visual can reasonably be expected to have their alpha channel drawn correctly on the screen.
On X11 this function returns whether a compositing manager is
compositing screen
.
Whether windows with RGBA visuals can reasonably be expected to have their alpha channels drawn correctly on the screen.
Since: 2.10
GdkWindow *
gdk_screen_get_root_window (GdkScreen *screen
);
Gets the root window of screen
.
Since: 2.2
GdkDisplay *
gdk_screen_get_display (GdkScreen *screen
);
Gets the display to which the screen
belongs.
Since: 2.2
gint
gdk_screen_get_number (GdkScreen *screen
);
gdk_screen_get_number
has been deprecated since version 3.22 and should not be used in newly-written code.
Gets the index of screen
among the screens in the display
to which it belongs. (See gdk_screen_get_display()
)
Since: 2.2
gint
gdk_screen_get_width (GdkScreen *screen
);
gdk_screen_get_width
has been deprecated since version 3.22 and should not be used in newly-written code.
Use per-monitor information instead
Gets the width of screen
in pixels. The returned size is in
”application pixels”, not in ”device pixels” (see
gdk_screen_get_monitor_scale_factor()
).
Since: 2.2
gint
gdk_screen_get_height (GdkScreen *screen
);
gdk_screen_get_height
has been deprecated since version 3.22 and should not be used in newly-written code.
Use per-monitor information instead
Gets the height of screen
in pixels. The returned size is in
”application pixels”, not in ”device pixels” (see
gdk_screen_get_monitor_scale_factor()
).
Since: 2.2
gint
gdk_screen_get_width_mm (GdkScreen *screen
);
gdk_screen_get_width_mm
has been deprecated since version 3.22 and should not be used in newly-written code.
Use per-monitor information instead
Gets the width of screen
in millimeters.
Note that this value is somewhat ill-defined when the screen has multiple monitors of different resolution. It is recommended to use the monitor dimensions instead.
Since: 2.2
gint
gdk_screen_get_height_mm (GdkScreen *screen
);
gdk_screen_get_height_mm
has been deprecated since version 3.22 and should not be used in newly-written code.
Use per-monitor information instead
Returns the height of screen
in millimeters.
Note that this value is somewhat ill-defined when the screen has multiple monitors of different resolution. It is recommended to use the monitor dimensions instead.
Since: 2.2
GList *
gdk_screen_list_visuals (GdkScreen *screen
);
Lists the available visuals for the specified screen
.
A visual describes a hardware image data format.
For example, a visual might support 24-bit color, or 8-bit color,
and might expect pixels to be in a certain format.
Call g_list_free()
on the return value when you’re finished with it.
a list of visuals; the list must be freed, but not its contents.
[transfer container][element-type GdkVisual]
Since: 2.2
GList *
gdk_screen_get_toplevel_windows (GdkScreen *screen
);
Obtains a list of all toplevel windows known to GDK on the screen screen
.
A toplevel window is a child of the root window (see
gdk_get_default_root_window()
).
The returned list should be freed with g_list_free()
, but
its elements need not be freed.
list of toplevel windows, free with g_list_free()
.
[transfer container][element-type GdkWindow]
Since: 2.2
gchar *
gdk_screen_make_display_name (GdkScreen *screen
);
gdk_screen_make_display_name
has been deprecated since version 3.22 and should not be used in newly-written code.
Determines the name to pass to gdk_display_open()
to get
a GdkDisplay with this screen as the default screen.
Since: 2.2
gint
gdk_screen_get_n_monitors (GdkScreen *screen
);
gdk_screen_get_n_monitors
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_display_get_n_monitors()
instead
Returns the number of monitors which screen
consists of.
Since: 2.2
gint
gdk_screen_get_primary_monitor (GdkScreen *screen
);
gdk_screen_get_primary_monitor
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_display_get_primary_monitor()
instead
Gets the primary monitor for screen
. The primary monitor
is considered the monitor where the “main desktop” lives.
While normal application windows typically allow the window
manager to place the windows, specialized desktop applications
such as panels should place themselves on the primary monitor.
If no primary monitor is configured by the user, the return value will be 0, defaulting to the first monitor.
Since: 2.20
void gdk_screen_get_monitor_geometry (GdkScreen *screen
,gint monitor_num
,GdkRectangle *dest
);
gdk_screen_get_monitor_geometry
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_monitor_get_geometry()
instead
Retrieves the GdkRectangle representing the size and position of
the individual monitor within the entire screen area. The returned
geometry is in ”application pixels”, not in ”device pixels” (see
gdk_screen_get_monitor_scale_factor()
).
Monitor numbers start at 0. To obtain the number of monitors of
screen
, use gdk_screen_get_n_monitors()
.
Note that the size of the entire screen area can be retrieved via
gdk_screen_get_width()
and gdk_screen_get_height()
.
screen |
||
monitor_num |
the monitor number |
|
dest |
a GdkRectangle to be filled with the monitor geometry. |
[out][allow-none] |
Since: 2.2
void gdk_screen_get_monitor_workarea (GdkScreen *screen
,gint monitor_num
,GdkRectangle *dest
);
gdk_screen_get_monitor_workarea
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_monitor_get_workarea()
instead
Retrieves the GdkRectangle representing the size and position of
the “work area” on a monitor within the entire screen area. The returned
geometry is in ”application pixels”, not in ”device pixels” (see
gdk_screen_get_monitor_scale_factor()
).
The work area should be considered when positioning menus and similar popups, to avoid placing them below panels, docks or other desktop components.
Note that not all backends may have a concept of workarea. This function will return the monitor geometry if a workarea is not available, or does not apply.
Monitor numbers start at 0. To obtain the number of monitors of
screen
, use gdk_screen_get_n_monitors()
.
screen |
||
monitor_num |
the monitor number |
|
dest |
a GdkRectangle to be filled with the monitor workarea. |
[out][allow-none] |
Since: 3.4
gint gdk_screen_get_monitor_at_point (GdkScreen *screen
,gint x
,gint y
);
gdk_screen_get_monitor_at_point
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_display_get_monitor_at_point()
instead
Returns the monitor number in which the point (x
,y
) is located.
screen |
a GdkScreen. |
|
x |
the x coordinate in the virtual screen. |
|
y |
the y coordinate in the virtual screen. |
the monitor number in which the point (x
,y
) lies, or
a monitor close to (x
,y
) if the point is not in any monitor.
Since: 2.2
gint gdk_screen_get_monitor_at_window (GdkScreen *screen
,GdkWindow *window
);
gdk_screen_get_monitor_at_window
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_display_get_monitor_at_window()
instead
Returns the number of the monitor in which the largest area of the
bounding rectangle of window
resides.
the monitor number in which most of window
is located,
or if window
does not intersect any monitors, a monitor,
close to window
.
Since: 2.2
gint gdk_screen_get_monitor_height_mm (GdkScreen *screen
,gint monitor_num
);
gdk_screen_get_monitor_height_mm
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_monitor_get_height_mm()
instead
Gets the height in millimeters of the specified monitor.
screen |
||
monitor_num |
number of the monitor, between 0 and gdk_screen_get_n_monitors (screen) |
Since: 2.14
gint gdk_screen_get_monitor_width_mm (GdkScreen *screen
,gint monitor_num
);
gdk_screen_get_monitor_width_mm
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_monitor_get_width_mm()
instead
Gets the width in millimeters of the specified monitor, if available.
screen |
||
monitor_num |
number of the monitor, between 0 and gdk_screen_get_n_monitors (screen) |
Since: 2.14
gchar * gdk_screen_get_monitor_plug_name (GdkScreen *screen
,gint monitor_num
);
gdk_screen_get_monitor_plug_name
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_monitor_get_model()
instead
Returns the output name of the specified monitor. Usually something like VGA, DVI, or TV, not the actual product name of the display device.
screen |
||
monitor_num |
number of the monitor, between 0 and gdk_screen_get_n_monitors (screen) |
a newly-allocated string containing the name
of the monitor, or NULL
if the name cannot be determined.
[nullable]
Since: 2.14
gint gdk_screen_get_monitor_scale_factor (GdkScreen *screen
,gint monitor_num
);
gdk_screen_get_monitor_scale_factor
has been deprecated since version 3.22 and should not be used in newly-written code.
Use gdk_monitor_get_scale_factor()
instead
Returns the internal scale factor that maps from monitor coordinates to the actual device pixels. On traditional systems this is 1, but on very high density outputs this can be a higher value (often 2).
This can be used if you want to create pixel based data for a
particular monitor, but most of the time you’re drawing to a window
where it is better to use gdk_window_get_scale_factor()
instead.
screen |
screen to get scale factor for |
|
monitor_num |
number of the monitor, between 0 and gdk_screen_get_n_monitors (screen) |
Since: 3.10
gboolean gdk_screen_get_setting (GdkScreen *screen
,const gchar *name
,GValue *value
);
Retrieves a desktop-wide setting such as double-click time
for the GdkScreen screen
.
FIXME needs a list of valid settings here, or a link to more information.
screen |
the GdkScreen where the setting is located |
|
name |
the name of the setting |
|
value |
location to store the value of the setting |
Since: 2.2
const cairo_font_options_t *
gdk_screen_get_font_options (GdkScreen *screen
);
Gets any options previously set with gdk_screen_set_font_options()
.
Since: 2.10
void gdk_screen_set_font_options (GdkScreen *screen
,const cairo_font_options_t *options
);
Sets the default font options for the screen. These
options will be set on any PangoContext’s newly created
with gdk_pango_context_get_for_screen()
. Changing the
default set of font options does not affect contexts that
have already been created.
screen |
||
options |
a cairo_font_options_t, or |
[allow-none] |
Since: 2.10
gdouble
gdk_screen_get_resolution (GdkScreen *screen
);
Gets the resolution for font handling on the screen; see
gdk_screen_set_resolution()
for full details.
Since: 2.10
void gdk_screen_set_resolution (GdkScreen *screen
,gdouble dpi
);
Sets the resolution for font handling on the screen. This is a scale factor between points specified in a PangoFontDescription and cairo units. The default value is 96, meaning that a 10 point font will be 13 units high. (10 * 96. / 72. = 13.3).
screen |
||
dpi |
the resolution in “dots per inch”. (Physical inches aren’t actually involved; the terminology is conventional.) |
Since: 2.10
GdkWindow *
gdk_screen_get_active_window (GdkScreen *screen
);
gdk_screen_get_active_window
has been deprecated since version 3.22 and should not be used in newly-written code.
Returns the screen’s currently active window.
On X11, this is done by inspecting the _NET_ACTIVE_WINDOW property
on the root window, as described in the
Extended Window Manager Hints.
If there is no currently currently active
window, or the window manager does not support the
_NET_ACTIVE_WINDOW hint, this function returns NULL
.
On other platforms, this function may return NULL
, depending on whether
it is implementable on that platform.
The returned window should be unrefed using g_object_unref()
when
no longer needed.
Since: 2.10
GList *
gdk_screen_get_window_stack (GdkScreen *screen
);
Returns a GList of GdkWindows representing the current window stack.
On X11, this is done by inspecting the _NET_CLIENT_LIST_STACKING
property on the root window, as described in the
Extended Window Manager Hints.
If the window manager does not support the
_NET_CLIENT_LIST_STACKING hint, this function returns NULL
.
On other platforms, this function may return NULL
, depending on whether
it is implementable on that platform.
The returned list is newly allocated and owns references to the
windows it contains, so it should be freed using g_list_free()
and
its windows unrefed using g_object_unref()
when no longer needed.
a
list of GdkWindows for the current window stack, or NULL
.
[nullable][transfer full][element-type GdkWindow]
Since: 2.10
“font-options”
property“font-options” gpointer
The default font options for the screen.
Owner: GdkScreen
Flags: Read / Write
“composited-changed”
signalvoid user_function (GdkScreen *screen, gpointer user_data)
The ::composited-changed signal is emitted when the composited status of the screen changes
screen |
the object on which the signal is emitted |
|
user_data |
user data set when the signal handler was connected. |
Flags: Run Last
Since: 2.10
“monitors-changed”
signalvoid user_function (GdkScreen *screen, gpointer user_data)
The ::monitors-changed signal is emitted when the number, size or position of the monitors attached to the screen change.
Only for X11 and OS X for now. A future implementation for Win32 may be a possibility.
screen |
the object on which the signal is emitted |
|
user_data |
user data set when the signal handler was connected. |
Flags: Run Last
Since: 2.14
“size-changed”
signalvoid user_function (GdkScreen *screen, gpointer user_data)
The ::size-changed signal is emitted when the pixel width or height of a screen changes.
screen |
the object on which the signal is emitted |
|
user_data |
user data set when the signal handler was connected. |
Flags: Run Last
Since: 2.2