mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-15 14:50:06 +00:00
c3dde05d33
Similarly to GdkToplevel, GdkDragSurface's compute-size should be called by backends to query the current surface size, and should be connected to by widget implementations (like GtkDragIcon) to report the current size. GdkDragSurface-backed widgets are not parented to an existing widget, unlike popovers, and like toplevels. This means that there's nobody to actively call gdk_drag_surface_present() to update the size, and GdkDragSurface should do it on its own, just like GdkToplevel.
120 lines
3.4 KiB
C
120 lines
3.4 KiB
C
/*
|
|
* Copyright © 2020 Red Hat, Inc.
|
|
*
|
|
* 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: Matthias Clasen <mclasen@redhat.com>
|
|
*/
|
|
|
|
#include "config.h"
|
|
|
|
#include "gdkprivate.h"
|
|
#include "gdkdragsurfaceprivate.h"
|
|
#include <glib/gi18n-lib.h>
|
|
|
|
/**
|
|
* GdkDragSurface:
|
|
*
|
|
* A `GdkDragSurface` is an interface for surfaces used during DND.
|
|
*/
|
|
|
|
/**
|
|
* GdkDragSurfaceInterface:
|
|
*
|
|
* The `GdkDragSurfaceInterface` implementation is private to GDK.
|
|
*/
|
|
|
|
G_DEFINE_INTERFACE (GdkDragSurface, gdk_drag_surface, GDK_TYPE_SURFACE)
|
|
|
|
enum
|
|
{
|
|
COMPUTE_SIZE,
|
|
|
|
N_SIGNALS
|
|
};
|
|
|
|
static guint signals[N_SIGNALS] = { 0 };
|
|
|
|
void
|
|
gdk_drag_surface_notify_compute_size (GdkDragSurface *surface,
|
|
GdkDragSurfaceSize *size)
|
|
{
|
|
g_signal_emit (surface, signals[COMPUTE_SIZE], 0, size);
|
|
}
|
|
|
|
static gboolean
|
|
gdk_drag_surface_default_present (GdkDragSurface *drag_surface,
|
|
int width,
|
|
int height)
|
|
{
|
|
return FALSE;
|
|
}
|
|
|
|
static void
|
|
gdk_drag_surface_default_init (GdkDragSurfaceInterface *iface)
|
|
{
|
|
iface->present = gdk_drag_surface_default_present;
|
|
|
|
/**
|
|
* GdkDragSurface::compute-size:
|
|
* @surface: a `GdkDragSurface`
|
|
* @size: (type Gdk.DragSurfaceSize) (out caller-allocates): a
|
|
* `GdkDragSurfaceSize`
|
|
*
|
|
* Emitted when the size for the surface needs to be computed, when it is
|
|
* present.
|
|
*
|
|
* It will normally be emitted during the native surface layout cycle when the
|
|
* surface size needs to be recomputed.
|
|
*
|
|
* It is the responsibility of the drag surface user to handle this signal and
|
|
* compute the desired size of the surface, storing the computed size in the
|
|
* [struct@Gdk.DragSurfaceSize] object. Failing to do so will result in an
|
|
* arbitrary size being used as a result.
|
|
*
|
|
* Since: 4.12
|
|
*/
|
|
signals[COMPUTE_SIZE] =
|
|
g_signal_new (I_("compute-size"),
|
|
GDK_TYPE_DRAG_SURFACE,
|
|
G_SIGNAL_RUN_LAST,
|
|
0,
|
|
NULL, NULL,
|
|
NULL,
|
|
G_TYPE_NONE, 1,
|
|
GDK_TYPE_DRAG_SURFACE_SIZE);
|
|
}
|
|
|
|
/**
|
|
* gdk_drag_surface_present:
|
|
* @drag_surface: the `GdkDragSurface` to show
|
|
* @width: the unconstrained drag_surface width to layout
|
|
* @height: the unconstrained drag_surface height to layout
|
|
*
|
|
* Present @drag_surface.
|
|
*
|
|
* Returns: %FALSE if it failed to be presented, otherwise %TRUE.
|
|
*/
|
|
gboolean
|
|
gdk_drag_surface_present (GdkDragSurface *drag_surface,
|
|
int width,
|
|
int height)
|
|
{
|
|
g_return_val_if_fail (GDK_IS_DRAG_SURFACE (drag_surface), FALSE);
|
|
g_return_val_if_fail (width > 0, FALSE);
|
|
g_return_val_if_fail (height > 0, FALSE);
|
|
|
|
return GDK_DRAG_SURFACE_GET_IFACE (drag_surface)->present (drag_surface, width, height);
|
|
}
|