2019-04-21 18:42:31 +00:00
|
|
|
/* GDK - The GIMP Drawing Kit
|
|
|
|
* Copyright (C) 2019 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 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/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Uninstalled header defining types and functions internal to GDK */
|
|
|
|
|
|
|
|
#ifndef __GDK_SURFACE_PRIVATE_H__
|
|
|
|
#define __GDK_SURFACE_PRIVATE_H__
|
|
|
|
|
|
|
|
#include <gdk-pixbuf/gdk-pixbuf.h>
|
|
|
|
#include "gdkenumtypes.h"
|
|
|
|
#include "gdksurface.h"
|
2020-09-10 04:25:51 +00:00
|
|
|
#include "gdktoplevel.h"
|
2019-04-21 18:42:31 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
2020-03-09 15:22:55 +00:00
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
GDK_SURFACE_TOPLEVEL,
|
|
|
|
GDK_SURFACE_TEMP,
|
|
|
|
GDK_SURFACE_POPUP
|
|
|
|
} GdkSurfaceType;
|
|
|
|
|
2019-04-21 18:42:31 +00:00
|
|
|
struct _GdkSurface
|
|
|
|
{
|
|
|
|
GObject parent_instance;
|
|
|
|
|
|
|
|
GdkDisplay *display;
|
|
|
|
|
2019-04-22 14:21:17 +00:00
|
|
|
GdkSurface *transient_for; /* for toplevels */
|
|
|
|
GdkSurface *parent; /* for popups */
|
2019-05-22 22:04:45 +00:00
|
|
|
GList *children; /* popups */
|
2019-04-21 18:42:31 +00:00
|
|
|
|
gdk: Replace 'WITHDRAWN' state with async 'is-mapped' boolean
It was used by all surfaces to track 'is-mapped', but still part of the
GdkToplevelState, and is now replaced with a separate boolean in the
GdkSurface structure.
It also caused issues when a widget was unmapped, and due to that
unmapped a popover which hid its corresponding surface. When this
surface was hidden, it emitted a state change event, which would then go
back into GTK and queue a resize on popover widget, which would travel
back down to the widget that was originally unmapped, causing confusino
when doing future allocations.
To summarize, one should not hide widgets during allocation, and to
avoid this, make this new is-mapped boolean asynchronous when hiding a
surface, meaning the notification event for the changed mapped state
will be emitted in an idle callback. This avoids the above described
reentry issue.
2020-12-07 17:18:38 +00:00
|
|
|
guint set_is_mapped_source_id;
|
|
|
|
gboolean pending_is_mapped;
|
|
|
|
gboolean is_mapped;
|
|
|
|
|
2020-07-24 13:54:49 +00:00
|
|
|
int x;
|
|
|
|
int y;
|
2019-04-21 18:42:31 +00:00
|
|
|
|
|
|
|
GdkGLContext *gl_paint_context;
|
|
|
|
|
|
|
|
cairo_region_t *update_area;
|
|
|
|
guint update_freeze_count;
|
2020-11-24 21:00:38 +00:00
|
|
|
GdkFrameClockPhase pending_phases;
|
2019-04-21 18:42:31 +00:00
|
|
|
/* This is the update_area that was in effect when the current expose
|
|
|
|
started. It may be smaller than the expose area if we'e painting
|
|
|
|
more than we have to, but it represents the "true" damage. */
|
|
|
|
cairo_region_t *active_update_area;
|
|
|
|
|
2020-11-23 15:39:11 +00:00
|
|
|
GdkToplevelState pending_set_flags;
|
|
|
|
GdkToplevelState pending_unset_flags;
|
2020-09-10 04:39:03 +00:00
|
|
|
GdkToplevelState state;
|
2019-04-21 18:42:31 +00:00
|
|
|
|
2020-07-25 02:57:00 +00:00
|
|
|
guint8 resize_count;
|
|
|
|
|
2019-04-21 18:42:31 +00:00
|
|
|
guint8 alpha;
|
|
|
|
guint8 fullscreen_mode;
|
|
|
|
|
|
|
|
guint modal_hint : 1;
|
|
|
|
guint destroyed : 2;
|
|
|
|
guint in_update : 1;
|
|
|
|
guint frame_clock_events_paused : 1;
|
2019-04-22 21:31:33 +00:00
|
|
|
guint autohide : 1;
|
2020-07-25 02:57:00 +00:00
|
|
|
guint shortcuts_inhibited : 1;
|
2020-02-21 21:38:36 +00:00
|
|
|
guint request_motion : 1;
|
2019-04-21 18:42:31 +00:00
|
|
|
|
2020-12-08 20:33:06 +00:00
|
|
|
guint request_motion_id;
|
|
|
|
|
2020-02-16 11:59:24 +00:00
|
|
|
struct {
|
|
|
|
GdkGravity surface_anchor;
|
|
|
|
GdkGravity rect_anchor;
|
|
|
|
} popup;
|
|
|
|
|
2019-04-21 18:42:31 +00:00
|
|
|
guint update_and_descendants_freeze_count;
|
|
|
|
|
2020-07-24 13:54:49 +00:00
|
|
|
int width, height;
|
2019-04-21 18:42:31 +00:00
|
|
|
|
|
|
|
GdkCursor *cursor;
|
|
|
|
GHashTable *device_cursor;
|
|
|
|
|
2020-03-01 19:29:06 +00:00
|
|
|
cairo_region_t *input_region;
|
2019-04-21 18:42:31 +00:00
|
|
|
|
|
|
|
GList *devices_inside;
|
|
|
|
|
|
|
|
GdkFrameClock *frame_clock; /* NULL to use from parent or default */
|
|
|
|
|
|
|
|
GSList *draw_contexts;
|
|
|
|
GdkDrawContext *paint_context;
|
|
|
|
|
|
|
|
cairo_region_t *opaque_region;
|
2020-03-20 14:17:41 +00:00
|
|
|
|
|
|
|
GdkSeat *current_shortcuts_inhibited_seat;
|
2019-04-21 18:42:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct _GdkSurfaceClass
|
|
|
|
{
|
2019-04-22 01:14:46 +00:00
|
|
|
GObjectClass parent_class;
|
|
|
|
|
|
|
|
cairo_surface_t *
|
2020-08-26 20:55:03 +00:00
|
|
|
(* ref_cairo_surface) (GdkSurface *surface);
|
|
|
|
void (* hide) (GdkSurface *surface);
|
|
|
|
void (* get_geometry) (GdkSurface *surface,
|
2020-07-24 13:54:49 +00:00
|
|
|
int *x,
|
|
|
|
int *y,
|
|
|
|
int *width,
|
|
|
|
int *height);
|
2020-08-26 20:55:03 +00:00
|
|
|
void (* get_root_coords) (GdkSurface *surface,
|
2020-07-24 13:54:49 +00:00
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
int *root_x,
|
|
|
|
int *root_y);
|
2020-08-26 20:55:03 +00:00
|
|
|
gboolean (* get_device_state) (GdkSurface *surface,
|
2019-04-22 01:14:46 +00:00
|
|
|
GdkDevice *device,
|
2020-07-24 20:32:16 +00:00
|
|
|
double *x,
|
|
|
|
double *y,
|
2019-04-22 01:14:46 +00:00
|
|
|
GdkModifierType *mask);
|
2020-03-01 19:29:06 +00:00
|
|
|
void (* set_input_region) (GdkSurface *surface,
|
|
|
|
cairo_region_t *shape_region);
|
2019-04-22 01:14:46 +00:00
|
|
|
|
2020-03-11 20:19:58 +00:00
|
|
|
/* Called to do the windowing system specific part of gdk_surface_destroy(),
|
|
|
|
*
|
|
|
|
* surface: The window being destroyed
|
|
|
|
* foreign_destroy: If TRUE, the surface or a parent was destroyed by some
|
|
|
|
* external agency. The surface has already been destroyed and no
|
|
|
|
* windowing system calls should be made. (This may never happen
|
|
|
|
* for some windowing systems.)
|
|
|
|
*/
|
2019-04-22 01:14:46 +00:00
|
|
|
void (* destroy) (GdkSurface *surface,
|
|
|
|
gboolean foreign_destroy);
|
|
|
|
|
|
|
|
|
|
|
|
/* optional */
|
|
|
|
gboolean (* beep) (GdkSurface *surface);
|
|
|
|
|
|
|
|
void (* destroy_notify) (GdkSurface *surface);
|
2020-05-17 21:49:02 +00:00
|
|
|
GdkDrag * (* drag_begin) (GdkSurface *surface,
|
|
|
|
GdkDevice *device,
|
|
|
|
GdkContentProvider *content,
|
|
|
|
GdkDragAction actions,
|
|
|
|
double dx,
|
|
|
|
double dy);
|
2019-04-22 01:14:46 +00:00
|
|
|
|
2020-07-24 13:54:49 +00:00
|
|
|
int (* get_scale_factor) (GdkSurface *surface);
|
2019-04-22 01:14:46 +00:00
|
|
|
|
|
|
|
void (* set_opaque_region) (GdkSurface *surface,
|
|
|
|
cairo_region_t *region);
|
2020-12-02 08:12:01 +00:00
|
|
|
void (* request_layout) (GdkSurface *surface);
|
2020-12-04 23:11:08 +00:00
|
|
|
gboolean (* compute_size) (GdkSurface *surface);
|
2019-04-21 18:42:31 +00:00
|
|
|
};
|
|
|
|
|
2020-08-14 01:47:54 +00:00
|
|
|
#define GDK_SURFACE_DESTROYED(d) (((GdkSurface *)(d))->destroyed)
|
|
|
|
|
gdk: Replace 'WITHDRAWN' state with async 'is-mapped' boolean
It was used by all surfaces to track 'is-mapped', but still part of the
GdkToplevelState, and is now replaced with a separate boolean in the
GdkSurface structure.
It also caused issues when a widget was unmapped, and due to that
unmapped a popover which hid its corresponding surface. When this
surface was hidden, it emitted a state change event, which would then go
back into GTK and queue a resize on popover widget, which would travel
back down to the widget that was originally unmapped, causing confusino
when doing future allocations.
To summarize, one should not hide widgets during allocation, and to
avoid this, make this new is-mapped boolean asynchronous when hiding a
surface, meaning the notification event for the changed mapped state
will be emitted in an idle callback. This avoids the above described
reentry issue.
2020-12-07 17:18:38 +00:00
|
|
|
#define GDK_SURFACE_IS_MAPPED(surface) ((surface)->pending_is_mapped)
|
2020-08-14 01:47:54 +00:00
|
|
|
|
2019-04-21 18:42:31 +00:00
|
|
|
void gdk_surface_set_state (GdkSurface *surface,
|
2020-09-10 04:39:03 +00:00
|
|
|
GdkToplevelState new_state);
|
2019-04-21 18:42:31 +00:00
|
|
|
|
gdk: Replace 'WITHDRAWN' state with async 'is-mapped' boolean
It was used by all surfaces to track 'is-mapped', but still part of the
GdkToplevelState, and is now replaced with a separate boolean in the
GdkSurface structure.
It also caused issues when a widget was unmapped, and due to that
unmapped a popover which hid its corresponding surface. When this
surface was hidden, it emitted a state change event, which would then go
back into GTK and queue a resize on popover widget, which would travel
back down to the widget that was originally unmapped, causing confusino
when doing future allocations.
To summarize, one should not hide widgets during allocation, and to
avoid this, make this new is-mapped boolean asynchronous when hiding a
surface, meaning the notification event for the changed mapped state
will be emitted in an idle callback. This avoids the above described
reentry issue.
2020-12-07 17:18:38 +00:00
|
|
|
void gdk_surface_set_is_mapped (GdkSurface *surface,
|
|
|
|
gboolean is_mapped);
|
|
|
|
|
2020-07-29 13:47:48 +00:00
|
|
|
GdkMonitor * gdk_surface_get_layout_monitor (GdkSurface *surface,
|
|
|
|
GdkPopupLayout *layout,
|
|
|
|
void (*get_bounds) (GdkMonitor *monitor,
|
|
|
|
GdkRectangle *bounds));
|
|
|
|
|
2020-02-16 11:59:24 +00:00
|
|
|
void gdk_surface_layout_popup_helper (GdkSurface *surface,
|
|
|
|
int width,
|
|
|
|
int height,
|
2020-12-02 13:58:45 +00:00
|
|
|
int shadow_left,
|
|
|
|
int shadow_right,
|
|
|
|
int shadow_top,
|
|
|
|
int shadow_bottom,
|
2020-07-29 13:47:48 +00:00
|
|
|
GdkMonitor *monitor,
|
|
|
|
GdkRectangle *bounds,
|
2020-02-16 11:59:24 +00:00
|
|
|
GdkPopupLayout *layout,
|
|
|
|
GdkRectangle *out_final_rect);
|
|
|
|
|
|
|
|
static inline GdkGravity
|
|
|
|
gdk_gravity_flip_horizontally (GdkGravity anchor)
|
|
|
|
{
|
|
|
|
switch (anchor)
|
|
|
|
{
|
|
|
|
default:
|
|
|
|
case GDK_GRAVITY_STATIC:
|
|
|
|
case GDK_GRAVITY_NORTH_WEST:
|
|
|
|
return GDK_GRAVITY_NORTH_EAST;
|
|
|
|
case GDK_GRAVITY_NORTH:
|
|
|
|
return GDK_GRAVITY_NORTH;
|
|
|
|
case GDK_GRAVITY_NORTH_EAST:
|
|
|
|
return GDK_GRAVITY_NORTH_WEST;
|
|
|
|
case GDK_GRAVITY_WEST:
|
|
|
|
return GDK_GRAVITY_EAST;
|
|
|
|
case GDK_GRAVITY_CENTER:
|
|
|
|
return GDK_GRAVITY_CENTER;
|
|
|
|
case GDK_GRAVITY_EAST:
|
|
|
|
return GDK_GRAVITY_WEST;
|
|
|
|
case GDK_GRAVITY_SOUTH_WEST:
|
|
|
|
return GDK_GRAVITY_SOUTH_EAST;
|
|
|
|
case GDK_GRAVITY_SOUTH:
|
|
|
|
return GDK_GRAVITY_SOUTH;
|
|
|
|
case GDK_GRAVITY_SOUTH_EAST:
|
|
|
|
return GDK_GRAVITY_SOUTH_WEST;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline GdkGravity
|
|
|
|
gdk_gravity_flip_vertically (GdkGravity anchor)
|
|
|
|
{
|
|
|
|
switch (anchor)
|
|
|
|
{
|
|
|
|
default:
|
|
|
|
case GDK_GRAVITY_STATIC:
|
|
|
|
case GDK_GRAVITY_NORTH_WEST:
|
|
|
|
return GDK_GRAVITY_SOUTH_WEST;
|
|
|
|
case GDK_GRAVITY_NORTH:
|
|
|
|
return GDK_GRAVITY_SOUTH;
|
|
|
|
case GDK_GRAVITY_NORTH_EAST:
|
|
|
|
return GDK_GRAVITY_SOUTH_EAST;
|
|
|
|
case GDK_GRAVITY_WEST:
|
|
|
|
return GDK_GRAVITY_WEST;
|
|
|
|
case GDK_GRAVITY_CENTER:
|
|
|
|
return GDK_GRAVITY_CENTER;
|
|
|
|
case GDK_GRAVITY_EAST:
|
|
|
|
return GDK_GRAVITY_EAST;
|
|
|
|
case GDK_GRAVITY_SOUTH_WEST:
|
|
|
|
return GDK_GRAVITY_NORTH_WEST;
|
|
|
|
case GDK_GRAVITY_SOUTH:
|
|
|
|
return GDK_GRAVITY_NORTH;
|
|
|
|
case GDK_GRAVITY_SOUTH_EAST:
|
|
|
|
return GDK_GRAVITY_NORTH_EAST;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_assert_not_reached ();
|
|
|
|
}
|
2019-07-15 09:35:24 +00:00
|
|
|
|
2020-08-14 01:47:54 +00:00
|
|
|
void _gdk_surface_destroy (GdkSurface *surface,
|
|
|
|
gboolean foreign_destroy);
|
|
|
|
void gdk_surface_invalidate_rect (GdkSurface *surface,
|
|
|
|
const GdkRectangle *rect);
|
|
|
|
void gdk_surface_invalidate_region (GdkSurface *surface,
|
|
|
|
const cairo_region_t *region);
|
|
|
|
void _gdk_surface_clear_update_area (GdkSurface *surface);
|
|
|
|
void _gdk_surface_update_size (GdkSurface *surface);
|
|
|
|
|
|
|
|
GdkGLContext * gdk_surface_get_paint_gl_context (GdkSurface *surface,
|
|
|
|
GError **error);
|
|
|
|
|
|
|
|
gboolean gdk_surface_handle_event (GdkEvent *event);
|
|
|
|
GdkSeat * gdk_surface_get_seat_from_event (GdkSurface *surface,
|
|
|
|
GdkEvent *event);
|
|
|
|
|
|
|
|
void gdk_surface_enter_monitor (GdkSurface *surface,
|
|
|
|
GdkMonitor *monitor);
|
|
|
|
void gdk_surface_leave_monitor (GdkSurface *surface,
|
|
|
|
GdkMonitor *monitor);
|
|
|
|
|
|
|
|
void gdk_surface_destroy_notify (GdkSurface *surface);
|
|
|
|
|
|
|
|
void gdk_synthesize_surface_state (GdkSurface *surface,
|
2020-09-10 04:39:03 +00:00
|
|
|
GdkToplevelState unset_flags,
|
|
|
|
GdkToplevelState set_flags);
|
2020-08-14 01:47:54 +00:00
|
|
|
|
|
|
|
void gdk_surface_get_root_coords (GdkSurface *surface,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
int *root_x,
|
|
|
|
int *root_y);
|
|
|
|
void gdk_surface_get_origin (GdkSurface *surface,
|
|
|
|
int *x,
|
|
|
|
int *y);
|
|
|
|
|
|
|
|
|
|
|
|
void gdk_surface_get_geometry (GdkSurface *surface,
|
|
|
|
int *x,
|
|
|
|
int *y,
|
|
|
|
int *width,
|
|
|
|
int *height);
|
|
|
|
|
2021-10-03 19:58:57 +00:00
|
|
|
void gdk_surface_set_egl_native_window (GdkSurface *self,
|
|
|
|
gpointer native_window);
|
2021-10-06 01:33:24 +00:00
|
|
|
void gdk_surface_ensure_egl_surface (GdkSurface *self,
|
|
|
|
gboolean hdr);
|
2021-10-03 19:58:57 +00:00
|
|
|
gpointer /*EGLSurface*/ gdk_surface_get_egl_surface (GdkSurface *self);
|
|
|
|
|
2021-10-03 06:20:30 +00:00
|
|
|
void gdk_surface_set_widget (GdkSurface *self,
|
|
|
|
gpointer widget);
|
|
|
|
gpointer gdk_surface_get_widget (GdkSurface *self);
|
|
|
|
|
|
|
|
void gdk_surface_freeze_updates (GdkSurface *surface);
|
|
|
|
void gdk_surface_thaw_updates (GdkSurface *surface);
|
2020-08-14 01:47:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
typedef enum
|
|
|
|
{
|
|
|
|
GDK_HINT_MIN_SIZE = 1 << 1,
|
|
|
|
GDK_HINT_MAX_SIZE = 1 << 2,
|
|
|
|
} GdkSurfaceHints;
|
|
|
|
|
|
|
|
typedef struct _GdkGeometry GdkGeometry;
|
|
|
|
|
|
|
|
struct _GdkGeometry
|
|
|
|
{
|
|
|
|
int min_width;
|
|
|
|
int min_height;
|
|
|
|
int max_width;
|
|
|
|
int max_height;
|
|
|
|
};
|
|
|
|
|
|
|
|
void gdk_surface_constrain_size (GdkGeometry *geometry,
|
|
|
|
GdkSurfaceHints flags,
|
|
|
|
int width,
|
|
|
|
int height,
|
|
|
|
int *new_width,
|
|
|
|
int *new_height);
|
|
|
|
|
2020-11-23 15:39:11 +00:00
|
|
|
void gdk_surface_queue_state_change (GdkSurface *surface,
|
|
|
|
GdkToplevelState unset_flags,
|
|
|
|
GdkToplevelState set_flags);
|
|
|
|
|
|
|
|
void gdk_surface_apply_state_change (GdkSurface *surface);
|
|
|
|
|
2020-11-24 15:02:23 +00:00
|
|
|
void gdk_surface_emit_size_changed (GdkSurface *surface,
|
|
|
|
int width,
|
|
|
|
int height);
|
|
|
|
|
2020-11-24 15:03:07 +00:00
|
|
|
void gdk_surface_request_compute_size (GdkSurface *surface);
|
|
|
|
|
2020-02-21 21:38:36 +00:00
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
|
|
void gdk_surface_request_motion (GdkSurface *surface);
|
|
|
|
|
2020-11-23 15:39:11 +00:00
|
|
|
|
2019-04-21 18:42:31 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif /* __GDK_SURFACE_PRIVATE_H__ */
|