Object representing a physical screen Gdk::Screen objects are the GDK representation of a physical screen. More...
Inherits Glib::Object.
Public Member Functions | |
virtual | ~Screen () |
GdkScreen* | gobj () |
Provides access to the underlying C GObject. | |
const GdkScreen* | gobj () const |
Provides access to the underlying C GObject. | |
GdkScreen* | gobj_copy () |
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs. | |
Glib::RefPtr< Colormap > | get_default_colormap () |
Gets the default colormap for screen. | |
Glib::RefPtr< const Colormap > | get_default_colormap () const |
Gets the default colormap for screen. | |
void | set_default_colormap (const Glib::RefPtr< const Colormap >& colormap) |
Sets the default colormap for screen. | |
Glib::RefPtr< Colormap > | get_system_colormap () |
Gets the system's default colormap for screen. | |
Glib::RefPtr< const Colormap > | get_system_colormap () const |
Gets the system's default colormap for screen. | |
Glib::RefPtr< Visual > | get_system_visual () |
Get the system's default visual for screen. | |
Glib::RefPtr< const Visual > | get_system_visual () const |
Get the system's default visual for screen. | |
Glib::RefPtr< Colormap > | get_rgb_colormap () |
Gets the preferred colormap for rendering image data on screen. | |
Glib::RefPtr< const Colormap > | get_rgb_colormap () const |
Gets the preferred colormap for rendering image data on screen. | |
Glib::RefPtr< Visual > | get_rgb_visual () |
Gets a "preferred visual" chosen by GdkRGB for rendering image data on screen. | |
Glib::RefPtr< const Visual > | get_rgb_visual () const |
Gets a "preferred visual" chosen by GdkRGB for rendering image data on screen. | |
Glib::RefPtr< Colormap > | get_rgba_colormap () |
Gets a colormap to use for creating windows or pixmaps with an alpha channel. | |
Glib::RefPtr< const Colormap > | get_rgba_colormap () const |
Gets a colormap to use for creating windows or pixmaps with an alpha channel. | |
Glib::RefPtr< Visual > | get_rgba_visual () |
Gets a visual to use for creating windows or pixmaps with an alpha channel. | |
Glib::RefPtr< const Visual > | get_rgba_visual () const |
Gets a visual to use for creating windows or pixmaps with an alpha channel. | |
bool | is_composited () const |
Returns whether windows with an RGBA visual can reasonably be expected to have their alpha channel drawn correctly on the screen. | |
Glib::RefPtr< Window > | get_root_window () |
Gets the root window of screen. | |
Glib::RefPtr< const Window > | get_root_window () const |
Gets the root window of screen. | |
Glib::RefPtr< Display > | get_display () |
Gets the display to which the screen belongs. | |
Glib::RefPtr< const Display > | get_display () const |
Gets the display to which the screen belongs. | |
int | get_number () const |
Gets the index of screen among the screens in the display to which it belongs. | |
int | get_width () const |
Gets the width of screen in pixels. | |
int | get_height () const |
Gets the height of screen in pixels. | |
int | get_width_mm () const |
Gets the width of screen in millimeters. | |
int | get_height_mm () const |
Returns the height of screen in millimeters. | |
Glib::ListHandle< Glib::RefPtr < Visual > > | list_visuals () |
Lists the available visuals for the specified screen. | |
Glib::ListHandle< Glib::RefPtr < Window > > | get_toplevel_windows () |
Obtains a list of all toplevel windows known to GDK on the screen screen. | |
Glib::ustring | make_display_name () |
Determines the name to pass to Gdk::Display::open() to get a Gdk::Display with this screen as the default screen. | |
int | get_n_monitors () const |
Returns the number of monitors which screen consists of. | |
int | get_primary_monitor () const |
Gets the primary monitor for screen. | |
void | get_monitor_geometry (int monitor_num, Rectangle& dest) const |
Retrieves the Gdk::Rectangle representing the size and position of the individual monitor within the entire screen area. | |
int | get_monitor_at_point (int x, int y) const |
Returns the monitor number in which the point ( x, y) is located. | |
int | get_monitor_at_window (const Glib::RefPtr< Window >& window) const |
Returns the number of the monitor in which the largest area of the bounding rectangle of window resides. | |
int | get_monitor_width_mm (int monitor_num) const |
Gets the width in millimeters of the specified monitor, if available. | |
int | get_monitor_height_mm (int monitor_num) const |
Gets the height in millimeters of the specified monitor. | |
Glib::ustring | get_monitor_plug_name (int monitor_num) const |
Returns the output name of the specified monitor. | |
void | broadcast_client_message (GdkEvent* event) |
On X11, sends an X ClientMessage event to all toplevel windows on screen. | |
template<class ValueType > | |
bool | get_setting (const Glib::ustring& name, ValueType&value) const |
void | set_font_options (const Cairo::FontOptions& options) |
Sets the default font options for the screen. | |
Cairo::FontOptions | get_font_options () const |
Gets any options previously set with set_font_options(). | |
void | set_resolution (double dpi) |
Sets the resolution for font handling on the screen. | |
double | get_resolution () const |
Gets the resolution for font handling on the screen; see set_resolution() for full details. | |
Glib::RefPtr< Gdk::Window > | get_active_window () |
Returns the screen's currently active window. | |
Glib::RefPtr< const Gdk::Window > | get_active_window () const |
Returns the screen's currently active window. | |
Glib::ListHandle< Glib::RefPtr < Window > > | get_window_stack () |
Returns a List of Gdk::Windows representing the current window stack. | |
Glib::SignalProxy0< void > | signal_size_changed () |
The size_changed signal is emitted when the pixel width or height of a screen changes. | |
Static Public Member Functions | |
static Glib::RefPtr< Screen > | get_default () |
Gets the default screen for the default display. | |
Protected Member Functions | |
virtual void | on_size_changed () |
Related Functions | |
(Note that these are not member functions.) | |
Glib::RefPtr< Gdk::Screen > | wrap (GdkScreen* object, bool take_copy=false) |
A Glib::wrap() method for this object. |
Object representing a physical screen Gdk::Screen objects are the GDK representation of a physical screen.
It 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 colormap (get_default_colormap()), the screen width (get_width()), etc. Note that a screen may consist of multiple monitors which are merged to form a large screen area.
virtual Gdk::Screen::~Screen | ( | ) | [virtual] |
void Gdk::Screen::broadcast_client_message | ( | GdkEvent * | event | ) |
On X11, sends an X ClientMessage event to all toplevel windows on screen.
Toplevel windows are determined by checking for the WM_STATE property, as described in the Inter-Client Communication Conventions Manual (ICCCM). If no windows are found with the WM_STATE property set, the message is sent to all children of the root window.
On Windows, broadcasts a message registered with the name GDK_WIN32_CLIENT_MESSAGE to all top-level windows. The amount of data is limited to one long, i.e. four bytes.
event | The Gdk::Event. |
Glib::RefPtr<const Gdk::Window> Gdk::Screen::get_active_window | ( | ) | const |
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 <ulink url="http://www.freedesktop.org/Standards/wm-spec">Extended Window Manager Hints</ulink>. If there is no currently currently active window, or the window manager does not support the _NET_ACTIVE_WINDOW hint, this function returns 0
.
On other platforms, this function may return 0
, depending on whether it is implementable on that platform.
The returned window should be unrefed using Glib::object_unref() when no longer needed.
0
. Glib::RefPtr<Gdk::Window> Gdk::Screen::get_active_window | ( | ) |
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 <ulink url="http://www.freedesktop.org/Standards/wm-spec">Extended Window Manager Hints</ulink>. If there is no currently currently active window, or the window manager does not support the _NET_ACTIVE_WINDOW hint, this function returns 0
.
On other platforms, this function may return 0
, depending on whether it is implementable on that platform.
The returned window should be unrefed using Glib::object_unref() when no longer needed.
0
. static Glib::RefPtr<Screen> Gdk::Screen::get_default | ( | ) | [static] |
Gets the default screen for the default display.
(See Gdk::Display::get_default()).
0
if there is no default display. Glib::RefPtr<const Colormap> Gdk::Screen::get_default_colormap | ( | ) | const |
Glib::RefPtr<Colormap> Gdk::Screen::get_default_colormap | ( | ) |
Glib::RefPtr<const Display> Gdk::Screen::get_display | ( | ) | const |
Gets the display to which the screen belongs.
Glib::RefPtr<Display> Gdk::Screen::get_display | ( | ) |
Gets the display to which the screen belongs.
Cairo::FontOptions Gdk::Screen::get_font_options | ( | ) | const |
Gets any options previously set with set_font_options().
0
if no default font options have been set. int Gdk::Screen::get_height | ( | ) | const |
int Gdk::Screen::get_height_mm | ( | ) | const |
Returns the height of screen in millimeters.
Note that on some X servers this value will not be correct.
int Gdk::Screen::get_monitor_at_point | ( | int | x, | |
int | y | |||
) | const |
Returns the monitor number in which the point ( x, y) is located.
x | The x coordinate in the virtual screen. | |
y | The y coordinate in the virtual screen. |
int Gdk::Screen::get_monitor_at_window | ( | const Glib::RefPtr< Window >& | window | ) | const |
Returns the number of the monitor in which the largest area of the bounding rectangle of window resides.
window | A Gdk::Window. |
void Gdk::Screen::get_monitor_geometry | ( | int | monitor_num, | |
Rectangle& | dest | |||
) | const |
Retrieves the Gdk::Rectangle representing the size and position of the individual monitor within the entire screen area.
Note that the size of the entire screen area can be retrieved via get_width() and get_height().
monitor_num | The monitor number, between 0 and gdk_screen_get_n_monitors (screen). | |
dest | A Gdk::Rectangle to be filled with the monitor geometry. |
int Gdk::Screen::get_monitor_height_mm | ( | int | monitor_num | ) | const |
Gets the height in millimeters of the specified monitor.
monitor_num | Number of the monitor, between 0 and gdk_screen_get_n_monitors (screen). |
Glib::ustring Gdk::Screen::get_monitor_plug_name | ( | int | monitor_num | ) | const |
Returns the output name of the specified monitor.
Usually something like VGA, DVI, or TV, not the actual product name of the display device.
monitor_num | Number of the monitor, between 0 and gdk_screen_get_n_monitors (screen). |
0
if the name cannot be determined. int Gdk::Screen::get_monitor_width_mm | ( | int | monitor_num | ) | const |
Gets the width in millimeters of the specified monitor, if available.
monitor_num | Number of the monitor, between 0 and gdk_screen_get_n_monitors (screen). |
int Gdk::Screen::get_n_monitors | ( | ) | const |
Returns the number of monitors which screen consists of.
int Gdk::Screen::get_number | ( | ) | const |
Gets the index of screen among the screens in the display to which it belongs.
(See get_display())
int Gdk::Screen::get_primary_monitor | ( | ) | const |
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.
double Gdk::Screen::get_resolution | ( | ) | const |
Gets the resolution for font handling on the screen; see set_resolution() for full details.
Glib::RefPtr<const Colormap> Gdk::Screen::get_rgb_colormap | ( | ) | const |
Gets the preferred colormap for rendering image data on screen.
Not a very useful function; historically, GDK could only render RGB image data to one colormap and visual, but in the current version it can render to any colormap and visual. So there's no need to call this function.
Glib::RefPtr<Colormap> Gdk::Screen::get_rgb_colormap | ( | ) |
Gets the preferred colormap for rendering image data on screen.
Not a very useful function; historically, GDK could only render RGB image data to one colormap and visual, but in the current version it can render to any colormap and visual. So there's no need to call this function.
Glib::RefPtr<const Visual> Gdk::Screen::get_rgb_visual | ( | ) | const |
Gets a "preferred visual" chosen by GdkRGB for rendering image data on screen.
In previous versions of GDK, this was the only visual GdkRGB could use for rendering. In current versions, it's simply the visual GdkRGB would have chosen as the optimal one in those previous versions. GdkRGB can now render to drawables with any visual.
Glib::RefPtr<Visual> Gdk::Screen::get_rgb_visual | ( | ) |
Gets a "preferred visual" chosen by GdkRGB for rendering image data on screen.
In previous versions of GDK, this was the only visual GdkRGB could use for rendering. In current versions, it's simply the visual GdkRGB would have chosen as the optimal one in those previous versions. GdkRGB can now render to drawables with any visual.
Glib::RefPtr<const Colormap> Gdk::Screen::get_rgba_colormap | ( | ) | const |
Gets a colormap to use for creating windows or pixmaps with an alpha channel.
The windowing system on which GTK+ is running may not support this capability, in which case 0
will be returned. Even if a non-0
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().
0
if the capability is not available. Glib::RefPtr<Colormap> Gdk::Screen::get_rgba_colormap | ( | ) |
Gets a colormap to use for creating windows or pixmaps with an alpha channel.
The windowing system on which GTK+ is running may not support this capability, in which case 0
will be returned. Even if a non-0
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().
0
if the capability is not available. Glib::RefPtr<const Visual> Gdk::Screen::get_rgba_visual | ( | ) | const |
Gets a visual to use for creating windows or pixmaps with an alpha channel.
See the docs for get_rgba_colormap() for caveats.
0
if the capability is not available. Glib::RefPtr<Visual> Gdk::Screen::get_rgba_visual | ( | ) |
Gets a visual to use for creating windows or pixmaps with an alpha channel.
See the docs for get_rgba_colormap() for caveats.
0
if the capability is not available. Glib::RefPtr<const Window> Gdk::Screen::get_root_window | ( | ) | const |
Glib::RefPtr<Window> Gdk::Screen::get_root_window | ( | ) |
bool Gdk::Screen::get_setting | ( | const Glib::ustring & | name, | |
ValueType & | value | |||
) | const [inline] |
Glib::RefPtr<const Colormap> Gdk::Screen::get_system_colormap | ( | ) | const |
Gets the system's default colormap for screen.
Glib::RefPtr<Colormap> Gdk::Screen::get_system_colormap | ( | ) |
Gets the system's default colormap for screen.
Glib::RefPtr<const Visual> Gdk::Screen::get_system_visual | ( | ) | const |
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.
Glib::RefPtr<Visual> Gdk::Screen::get_system_visual | ( | ) |
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.
Glib::ListHandle< Glib::RefPtr<Window> > Gdk::Screen::get_toplevel_windows | ( | ) |
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()).
int Gdk::Screen::get_width | ( | ) | const |
int Gdk::Screen::get_width_mm | ( | ) | const |
Gets the width of screen in millimeters.
Note that on some X servers this value will not be correct.
Glib::ListHandle< Glib::RefPtr<Window> > Gdk::Screen::get_window_stack | ( | ) |
Returns a List of Gdk::Windows 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 <ulink url="http://www.freedesktop.org/Standards/wm-spec">Extended Window Manager Hints</ulink>. If the window manager does not support the _NET_CLIENT_LIST_STACKING hint, this function returns 0
.
On other platforms, this function may return 0
, 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 Glib::list_free() and its windows unrefed using Glib::object_unref() when no longer needed.
0
. const GdkScreen* Gdk::Screen::gobj | ( | ) | const [inline] |
Provides access to the underlying C GObject.
Reimplemented from Glib::ObjectBase.
GdkScreen* Gdk::Screen::gobj | ( | ) | [inline] |
Provides access to the underlying C GObject.
Reimplemented from Glib::ObjectBase.
GdkScreen* Gdk::Screen::gobj_copy | ( | ) |
Provides access to the underlying C instance. The caller is responsible for unrefing it. Use when directly setting fields in structs.
bool Gdk::Screen::is_composited | ( | ) | const |
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.
Glib::ListHandle< Glib::RefPtr<Visual> > Gdk::Screen::list_visuals | ( | ) |
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.
Glib::ustring Gdk::Screen::make_display_name | ( | ) |
Determines the name to pass to Gdk::Display::open() to get a Gdk::Display with this screen as the default screen.
virtual void Gdk::Screen::on_size_changed | ( | ) | [protected, virtual] |
void Gdk::Screen::set_default_colormap | ( | const Glib::RefPtr< const Colormap >& | colormap | ) |
void Gdk::Screen::set_font_options | ( | const Cairo::FontOptions & | options | ) |
Sets the default font options for the screen.
These options will be set on any Pango::Context'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.
options | A cairo_font_options_t, or 0 to unset any previously set default font options. |
void Gdk::Screen::set_resolution | ( | double | dpi | ) |
Sets the resolution for font handling on the screen.
This is a scale factor between points specified in a Pango::FontDescription and cairo units. The default value is 96, meaning that a 10 point font will be 13 units high. (10 * 96. / 72. = 13.3).
dpi | The resolution in "dots per inch". (Physical inches aren't actually involved; the terminology is conventional.). |
Glib::SignalProxy0< void > Gdk::Screen::signal_size_changed | ( | ) |
The size_changed signal is emitted when the pixel width or height of a screen changes.
void on_my_size_changed()
Glib::RefPtr< Gdk::Screen > wrap | ( | GdkScreen * | object, | |
bool | take_copy = false | |||
) | [related] |
A Glib::wrap() method for this object.
object | The C instance. | |
take_copy | False if the result should take ownership of the C instance. True if it should take a new copy or ref. |