mirror of
https://github.com/brl/mutter.git
synced 2025-01-10 11:42:49 +00:00
clutter/paint-context: Add paint flag
A paint flag affects a paint operation in ways defined by the flags. Currently no flags are defined, so no semantical changes are defined yet. Eventually a flag aiming to avoid painting of cursors is going to be added, so that screen cast streams can decide whether to include a cursor or not. https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1207
This commit is contained in:
parent
36111270aa
commit
1b33a5a3a7
@ -21,7 +21,8 @@
|
|||||||
#include "clutter-paint-context.h"
|
#include "clutter-paint-context.h"
|
||||||
|
|
||||||
ClutterPaintContext * clutter_paint_context_new_for_view (ClutterStageView *view,
|
ClutterPaintContext * clutter_paint_context_new_for_view (ClutterStageView *view,
|
||||||
const cairo_region_t *redraw_clip);
|
const cairo_region_t *redraw_clip,
|
||||||
|
ClutterPaintFlag paint_flags);
|
||||||
|
|
||||||
gboolean clutter_paint_context_is_drawing_off_stage (ClutterPaintContext *paint_context);
|
gboolean clutter_paint_context_is_drawing_off_stage (ClutterPaintContext *paint_context);
|
||||||
|
|
||||||
|
@ -23,6 +23,8 @@ struct _ClutterPaintContext
|
|||||||
{
|
{
|
||||||
grefcount ref_count;
|
grefcount ref_count;
|
||||||
|
|
||||||
|
ClutterPaintFlag paint_flags;
|
||||||
|
|
||||||
GList *framebuffers;
|
GList *framebuffers;
|
||||||
|
|
||||||
ClutterStageView *view;
|
ClutterStageView *view;
|
||||||
@ -36,7 +38,8 @@ G_DEFINE_BOXED_TYPE (ClutterPaintContext, clutter_paint_context,
|
|||||||
|
|
||||||
ClutterPaintContext *
|
ClutterPaintContext *
|
||||||
clutter_paint_context_new_for_view (ClutterStageView *view,
|
clutter_paint_context_new_for_view (ClutterStageView *view,
|
||||||
const cairo_region_t *redraw_clip)
|
const cairo_region_t *redraw_clip,
|
||||||
|
ClutterPaintFlag paint_flags)
|
||||||
{
|
{
|
||||||
ClutterPaintContext *paint_context;
|
ClutterPaintContext *paint_context;
|
||||||
CoglFramebuffer *framebuffer;
|
CoglFramebuffer *framebuffer;
|
||||||
@ -45,6 +48,7 @@ clutter_paint_context_new_for_view (ClutterStageView *view,
|
|||||||
g_ref_count_init (&paint_context->ref_count);
|
g_ref_count_init (&paint_context->ref_count);
|
||||||
paint_context->view = view;
|
paint_context->view = view;
|
||||||
paint_context->redraw_clip = cairo_region_copy (redraw_clip);
|
paint_context->redraw_clip = cairo_region_copy (redraw_clip);
|
||||||
|
paint_context->paint_flags = paint_flags;
|
||||||
|
|
||||||
framebuffer = clutter_stage_view_get_framebuffer (view);
|
framebuffer = clutter_stage_view_get_framebuffer (view);
|
||||||
clutter_paint_context_push_framebuffer (paint_context, framebuffer);
|
clutter_paint_context_push_framebuffer (paint_context, framebuffer);
|
||||||
@ -56,12 +60,14 @@ clutter_paint_context_new_for_view (ClutterStageView *view,
|
|||||||
* clutter_paint_context_new_for_framebuffer: (skip)
|
* clutter_paint_context_new_for_framebuffer: (skip)
|
||||||
*/
|
*/
|
||||||
ClutterPaintContext *
|
ClutterPaintContext *
|
||||||
clutter_paint_context_new_for_framebuffer (CoglFramebuffer *framebuffer)
|
clutter_paint_context_new_for_framebuffer (CoglFramebuffer *framebuffer,
|
||||||
|
ClutterPaintFlag paint_flags)
|
||||||
{
|
{
|
||||||
ClutterPaintContext *paint_context;
|
ClutterPaintContext *paint_context;
|
||||||
|
|
||||||
paint_context = g_new0 (ClutterPaintContext, 1);
|
paint_context = g_new0 (ClutterPaintContext, 1);
|
||||||
g_ref_count_init (&paint_context->ref_count);
|
g_ref_count_init (&paint_context->ref_count);
|
||||||
|
paint_context->paint_flags = paint_flags;
|
||||||
|
|
||||||
clutter_paint_context_push_framebuffer (paint_context, framebuffer);
|
clutter_paint_context_push_framebuffer (paint_context, framebuffer);
|
||||||
|
|
||||||
@ -170,3 +176,12 @@ clutter_paint_context_is_drawing_off_stage (ClutterPaintContext *paint_context)
|
|||||||
|
|
||||||
return !paint_context->view;
|
return !paint_context->view;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* clutter_paint_context_get_paint_flags: (skip)
|
||||||
|
*/
|
||||||
|
ClutterPaintFlag
|
||||||
|
clutter_paint_context_get_paint_flags (ClutterPaintContext *paint_context)
|
||||||
|
{
|
||||||
|
return paint_context->paint_flags;
|
||||||
|
}
|
||||||
|
@ -29,13 +29,19 @@
|
|||||||
|
|
||||||
typedef struct _ClutterPaintContext ClutterPaintContext;
|
typedef struct _ClutterPaintContext ClutterPaintContext;
|
||||||
|
|
||||||
|
typedef enum _ClutterPaintFlag
|
||||||
|
{
|
||||||
|
CLUTTER_PAINT_FLAG_NONE = 0,
|
||||||
|
} ClutterPaintFlag;
|
||||||
|
|
||||||
#define CLUTTER_TYPE_PAINT_CONTEXT (clutter_paint_context_get_type ())
|
#define CLUTTER_TYPE_PAINT_CONTEXT (clutter_paint_context_get_type ())
|
||||||
|
|
||||||
CLUTTER_EXPORT
|
CLUTTER_EXPORT
|
||||||
GType clutter_paint_context_get_type (void);
|
GType clutter_paint_context_get_type (void);
|
||||||
|
|
||||||
CLUTTER_EXPORT
|
CLUTTER_EXPORT
|
||||||
ClutterPaintContext * clutter_paint_context_new_for_framebuffer (CoglFramebuffer *framebuffer);
|
ClutterPaintContext * clutter_paint_context_new_for_framebuffer (CoglFramebuffer *framebuffer,
|
||||||
|
ClutterPaintFlag paint_flags);
|
||||||
|
|
||||||
CLUTTER_EXPORT
|
CLUTTER_EXPORT
|
||||||
ClutterPaintContext * clutter_paint_context_ref (ClutterPaintContext *paint_context);
|
ClutterPaintContext * clutter_paint_context_ref (ClutterPaintContext *paint_context);
|
||||||
@ -62,4 +68,7 @@ void clutter_paint_context_pop_framebuffer (ClutterPaintContext *paint_context);
|
|||||||
CLUTTER_EXPORT
|
CLUTTER_EXPORT
|
||||||
const cairo_region_t * clutter_paint_context_get_redraw_clip (ClutterPaintContext *paint_context);
|
const cairo_region_t * clutter_paint_context_get_redraw_clip (ClutterPaintContext *paint_context);
|
||||||
|
|
||||||
|
CLUTTER_EXPORT
|
||||||
|
ClutterPaintFlag clutter_paint_context_get_paint_flags (ClutterPaintContext *paint_context);
|
||||||
|
|
||||||
#endif /* CLUTTER_PAINT_CONTEXT_H */
|
#endif /* CLUTTER_PAINT_CONTEXT_H */
|
||||||
|
@ -924,7 +924,8 @@ clutter_stage_do_paint_view (ClutterStage *stage,
|
|||||||
ClutterPaintContext *paint_context;
|
ClutterPaintContext *paint_context;
|
||||||
cairo_rectangle_int_t clip_rect;
|
cairo_rectangle_int_t clip_rect;
|
||||||
|
|
||||||
paint_context = clutter_paint_context_new_for_view (view, redraw_clip);
|
paint_context = clutter_paint_context_new_for_view (view, redraw_clip,
|
||||||
|
CLUTTER_PAINT_FLAG_NONE);
|
||||||
|
|
||||||
cairo_region_get_extents (redraw_clip, &clip_rect);
|
cairo_region_get_extents (redraw_clip, &clip_rect);
|
||||||
setup_view_for_pick_or_paint (stage, view, &clip_rect);
|
setup_view_for_pick_or_paint (stage, view, &clip_rect);
|
||||||
|
@ -1270,7 +1270,8 @@ get_image_via_offscreen (MetaShapedTexture *stex,
|
|||||||
root_node = clutter_root_node_new (fb, &clear_color, COGL_BUFFER_BIT_COLOR);
|
root_node = clutter_root_node_new (fb, &clear_color, COGL_BUFFER_BIT_COLOR);
|
||||||
clutter_paint_node_set_static_name (root_node, "MetaShapedTexture.offscreen");
|
clutter_paint_node_set_static_name (root_node, "MetaShapedTexture.offscreen");
|
||||||
|
|
||||||
paint_context = clutter_paint_context_new_for_framebuffer (fb);
|
paint_context =
|
||||||
|
clutter_paint_context_new_for_framebuffer (fb, CLUTTER_PAINT_FLAG_NONE);
|
||||||
|
|
||||||
do_paint_content (stex, root_node, paint_context,
|
do_paint_content (stex, root_node, paint_context,
|
||||||
stex->texture,
|
stex->texture,
|
||||||
|
@ -1321,7 +1321,9 @@ meta_window_actor_blit_to_framebuffer (MetaScreenCastWindow *screen_cast_window,
|
|||||||
cogl_framebuffer_scale (framebuffer, resource_scale, resource_scale, 1);
|
cogl_framebuffer_scale (framebuffer, resource_scale, resource_scale, 1);
|
||||||
cogl_framebuffer_translate (framebuffer, -x, -y, 0);
|
cogl_framebuffer_translate (framebuffer, -x, -y, 0);
|
||||||
|
|
||||||
paint_context = clutter_paint_context_new_for_framebuffer (framebuffer);
|
paint_context =
|
||||||
|
clutter_paint_context_new_for_framebuffer (framebuffer,
|
||||||
|
CLUTTER_PAINT_FLAG_NONE);
|
||||||
clutter_actor_paint (actor, paint_context);
|
clutter_actor_paint (actor, paint_context);
|
||||||
clutter_paint_context_destroy (paint_context);
|
clutter_paint_context_destroy (paint_context);
|
||||||
|
|
||||||
@ -1479,7 +1481,9 @@ meta_window_actor_get_image (MetaWindowActor *self,
|
|||||||
cogl_framebuffer_scale (framebuffer, resource_scale, resource_scale, 1);
|
cogl_framebuffer_scale (framebuffer, resource_scale, resource_scale, 1);
|
||||||
cogl_framebuffer_translate (framebuffer, -x, -y, 0);
|
cogl_framebuffer_translate (framebuffer, -x, -y, 0);
|
||||||
|
|
||||||
paint_context = clutter_paint_context_new_for_framebuffer (framebuffer);
|
paint_context =
|
||||||
|
clutter_paint_context_new_for_framebuffer (framebuffer,
|
||||||
|
CLUTTER_PAINT_FLAG_NONE);
|
||||||
clutter_actor_paint (actor, paint_context);
|
clutter_actor_paint (actor, paint_context);
|
||||||
clutter_paint_context_destroy (paint_context);
|
clutter_paint_context_destroy (paint_context);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user