2018-04-06 18:21:06 +00:00
|
|
|
/*
|
|
|
|
* Copyright © 2018 Benjamin Otte
|
|
|
|
*
|
|
|
|
* 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.1 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, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
* Authors: Benjamin Otte <otte@gnome.org>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
2018-07-29 02:11:14 +00:00
|
|
|
#include "gtkrootprivate.h"
|
2019-02-23 23:56:02 +00:00
|
|
|
#include "gdk/gdk-private.h"
|
2018-04-06 18:21:06 +00:00
|
|
|
|
|
|
|
/**
|
2019-02-24 20:29:08 +00:00
|
|
|
* SECTION:gtkroot
|
2018-04-06 18:21:06 +00:00
|
|
|
* @Title: GtkRoot
|
2019-02-24 20:29:08 +00:00
|
|
|
* @Short_description: Interface for root widgets
|
2018-04-06 18:21:06 +00:00
|
|
|
* @See_also: #GtkWindow
|
|
|
|
*
|
|
|
|
* #GtkRoot is the interface implemented by all widgets that can act as a toplevel
|
|
|
|
* widget to a hierarchy of widgets. The root widget takes care of providing the
|
|
|
|
* connection to the windowing system and manages layout, drawing and event delivery
|
|
|
|
* for its widget hierarchy.
|
|
|
|
*
|
|
|
|
* The obvious example of a #GtkRoot is #GtkWindow.
|
|
|
|
*/
|
|
|
|
|
|
|
|
G_DEFINE_INTERFACE (GtkRoot, gtk_root, GTK_TYPE_WIDGET)
|
|
|
|
|
2018-07-29 02:11:14 +00:00
|
|
|
static GdkDisplay *
|
|
|
|
gtk_root_default_get_display (GtkRoot *self)
|
|
|
|
{
|
|
|
|
return gdk_display_get_default ();
|
|
|
|
}
|
|
|
|
|
2019-02-10 00:06:39 +00:00
|
|
|
static GskRenderer *
|
|
|
|
gtk_root_default_get_renderer (GtkRoot *self)
|
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2019-02-09 21:15:32 +00:00
|
|
|
static void
|
|
|
|
gtk_root_default_get_surface_transform (GtkRoot *self,
|
|
|
|
int *x,
|
|
|
|
int *y)
|
|
|
|
{
|
|
|
|
*x = 0;
|
|
|
|
*y = 0;
|
|
|
|
}
|
|
|
|
|
2018-04-06 18:21:06 +00:00
|
|
|
static void
|
|
|
|
gtk_root_default_init (GtkRootInterface *iface)
|
|
|
|
{
|
2018-07-29 02:11:14 +00:00
|
|
|
iface->get_display = gtk_root_default_get_display;
|
2019-02-10 00:06:39 +00:00
|
|
|
iface->get_renderer = gtk_root_default_get_renderer;
|
2019-02-09 21:15:32 +00:00
|
|
|
iface->get_surface_transform = gtk_root_default_get_surface_transform;
|
2018-07-29 02:11:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GdkDisplay *
|
|
|
|
gtk_root_get_display (GtkRoot *self)
|
|
|
|
{
|
|
|
|
GtkRootInterface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GTK_IS_ROOT (self), NULL);
|
|
|
|
|
|
|
|
iface = GTK_ROOT_GET_IFACE (self);
|
|
|
|
return iface->get_display (self);
|
2018-04-06 18:21:06 +00:00
|
|
|
}
|
|
|
|
|
2019-02-10 00:06:39 +00:00
|
|
|
GskRenderer *
|
|
|
|
gtk_root_get_renderer (GtkRoot *self)
|
|
|
|
{
|
|
|
|
GtkRootInterface *iface;
|
|
|
|
|
|
|
|
g_return_val_if_fail (GTK_IS_ROOT (self), NULL);
|
|
|
|
|
|
|
|
iface = GTK_ROOT_GET_IFACE (self);
|
|
|
|
return iface->get_renderer (self);
|
|
|
|
}
|
2019-02-09 21:15:32 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
gtk_root_get_surface_transform (GtkRoot *self,
|
|
|
|
int *x,
|
|
|
|
int *y)
|
|
|
|
{
|
|
|
|
GtkRootInterface *iface;
|
|
|
|
|
|
|
|
g_return_if_fail (GTK_IS_ROOT (self));
|
|
|
|
g_return_if_fail (x != 0);
|
|
|
|
g_return_if_fail (y != 0);
|
|
|
|
|
|
|
|
iface = GTK_ROOT_GET_IFACE (self);
|
|
|
|
return iface->get_surface_transform (self, x, y);
|
|
|
|
}
|
2019-02-23 21:27:21 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* gtk_root_get_for_surface:
|
|
|
|
* @surface: a #GdkSurface
|
|
|
|
*
|
|
|
|
* Finds the GtkRoot associated with the surface.
|
|
|
|
*
|
|
|
|
* Returns: (transfer none): the #GtkRoot that is associated with @surface
|
|
|
|
*/
|
|
|
|
GtkWidget *
|
|
|
|
gtk_root_get_for_surface (GdkSurface *surface)
|
|
|
|
{
|
2019-02-23 23:56:02 +00:00
|
|
|
GtkWidget *widget;
|
2019-02-23 21:27:21 +00:00
|
|
|
|
2019-02-23 23:56:02 +00:00
|
|
|
widget = (GtkWidget *)gdk_surface_get_widget (surface);
|
2019-02-23 21:27:21 +00:00
|
|
|
|
2019-02-23 23:56:02 +00:00
|
|
|
if (widget && GTK_IS_ROOT (widget))
|
|
|
|
return widget;
|
2019-02-23 21:27:21 +00:00
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|