mirror of
https://github.com/brl/mutter.git
synced 2025-01-22 17:38:56 +00:00
window: Move opaque_region to WindowX11
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/3584>
This commit is contained in:
parent
bf5f597141
commit
606197de46
@ -39,7 +39,7 @@
|
||||
#include "x11/window-x11.h"
|
||||
#include "x11/meta-sync-counter.h"
|
||||
#include "x11/meta-x11-display-private.h"
|
||||
#include "x11/window-x11.h"
|
||||
#include "x11/window-x11-private.h"
|
||||
|
||||
enum
|
||||
{
|
||||
@ -1018,13 +1018,15 @@ update_opaque_region (MetaWindowActorX11 *actor_x11)
|
||||
{
|
||||
MetaWindow *window =
|
||||
meta_window_actor_get_meta_window (META_WINDOW_ACTOR (actor_x11));
|
||||
MetaWindowX11Private *priv =
|
||||
meta_window_x11_get_private (META_WINDOW_X11 (window));
|
||||
gboolean is_maybe_transparent;
|
||||
g_autoptr (MtkRegion) opaque_region = NULL;
|
||||
MetaSurfaceActor *surface;
|
||||
|
||||
is_maybe_transparent = is_actor_maybe_transparent (actor_x11);
|
||||
if (is_maybe_transparent &&
|
||||
(window->opaque_region ||
|
||||
(priv->opaque_region ||
|
||||
(window->frame && window->frame->opaque_region)))
|
||||
{
|
||||
MtkRectangle client_area;
|
||||
@ -1037,7 +1039,7 @@ update_opaque_region (MetaWindowActorX11 *actor_x11)
|
||||
if (opaque_region && meta_window_x11_has_alpha_channel (window))
|
||||
mtk_region_subtract_rectangle (opaque_region, &client_area);
|
||||
|
||||
if (window->opaque_region)
|
||||
if (priv->opaque_region)
|
||||
{
|
||||
g_autoptr (MtkRegion) client_opaque_region = NULL;
|
||||
|
||||
@ -1051,7 +1053,7 @@ update_opaque_region (MetaWindowActorX11 *actor_x11)
|
||||
* to be undefined, and considered a client bug. In mutter's
|
||||
* case, graphical glitches will occur.
|
||||
*/
|
||||
client_opaque_region = mtk_region_copy (window->opaque_region);
|
||||
client_opaque_region = mtk_region_copy (priv->opaque_region);
|
||||
mtk_region_translate (client_opaque_region,
|
||||
client_area.x, client_area.y);
|
||||
|
||||
|
@ -243,9 +243,6 @@ struct _MetaWindow
|
||||
* the server-side client window. */
|
||||
MtkRegion *shape_region;
|
||||
|
||||
/* if non-NULL, the opaque region _NET_WM_OPAQUE_REGION */
|
||||
MtkRegion *opaque_region;
|
||||
|
||||
/* the input shape region for picking */
|
||||
MtkRegion *input_region;
|
||||
|
||||
|
@ -315,7 +315,6 @@ meta_window_finalize (GObject *object)
|
||||
|
||||
g_clear_pointer (&window->frame_bounds, mtk_region_unref);
|
||||
g_clear_pointer (&window->shape_region, mtk_region_unref);
|
||||
g_clear_pointer (&window->opaque_region, mtk_region_unref);
|
||||
g_clear_pointer (&window->input_region, mtk_region_unref);
|
||||
|
||||
if (window->transient_for)
|
||||
|
@ -629,13 +629,16 @@ static void
|
||||
meta_window_set_opaque_region (MetaWindow *window,
|
||||
MtkRegion *region)
|
||||
{
|
||||
if (mtk_region_equal (window->opaque_region, region))
|
||||
MetaWindowX11Private *priv =
|
||||
meta_window_x11_get_private (META_WINDOW_X11 (window));
|
||||
|
||||
if (mtk_region_equal (priv->opaque_region, region))
|
||||
return;
|
||||
|
||||
g_clear_pointer (&window->opaque_region, mtk_region_unref);
|
||||
g_clear_pointer (&priv->opaque_region, mtk_region_unref);
|
||||
|
||||
if (region != NULL)
|
||||
window->opaque_region = mtk_region_ref (region);
|
||||
priv->opaque_region = mtk_region_ref (region);
|
||||
|
||||
meta_compositor_window_shape_changed (window->display->compositor, window);
|
||||
}
|
||||
|
@ -69,6 +69,9 @@ struct _MetaWindowX11Private
|
||||
* relative to the frame. */
|
||||
MtkRectangle client_rect;
|
||||
|
||||
/* if non-NULL, the opaque region _NET_WM_OPAQUE_REGION */
|
||||
MtkRegion *opaque_region;
|
||||
|
||||
Pixmap wm_hints_pixmap;
|
||||
Pixmap wm_hints_mask;
|
||||
|
||||
|
@ -2149,6 +2149,7 @@ meta_window_x11_finalize (GObject *object)
|
||||
MetaWindowX11 *win = META_WINDOW_X11 (object);
|
||||
MetaWindowX11Private *priv = meta_window_x11_get_instance_private (win);
|
||||
|
||||
g_clear_pointer (&priv->opaque_region, mtk_region_unref);
|
||||
g_clear_pointer (&priv->wm_client_machine, g_free);
|
||||
g_clear_pointer (&priv->sm_client_id, g_free);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user