[mutter/gbsneto/offscreen-paint-node: 27/30] clutter/offscreen-effect: Implement paint_node()
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter/gbsneto/offscreen-paint-node: 27/30] clutter/offscreen-effect: Implement paint_node()
- Date: Tue, 15 Dec 2020 13:54:16 +0000 (UTC)
commit 378e002c370410bdbff71c503b152f253325bccd
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date: Sun Jul 5 17:57:37 2020 -0300
clutter/offscreen-effect: Implement paint_node()
The paint node tree that ClutterOffscreenEffect generates is
simple:
Root
|------------+
| |
Layer Pipeline
|
Actor
Right now, both pre-paint and ClutterLayerNode push the offscreen
to the framebuffer stack. That's harmless, and will go away soon
anyway.
The actor node is created and added in a separate function because
it'll be reused by the next commit.
clutter/clutter/clutter-offscreen-effect.c | 34 ++++++++++++++++++++++++++++++
1 file changed, 34 insertions(+)
---
diff --git a/clutter/clutter/clutter-offscreen-effect.c b/clutter/clutter/clutter-offscreen-effect.c
index 84a2d8557f..71ad4dd124 100644
--- a/clutter/clutter/clutter-offscreen-effect.c
+++ b/clutter/clutter/clutter-offscreen-effect.c
@@ -484,6 +484,39 @@ clutter_offscreen_effect_post_paint (ClutterEffect *effect,
clutter_offscreen_effect_paint_texture (self, paint_context);
}
+static void
+add_actor_node (ClutterOffscreenEffect *offscreen_effect,
+ ClutterPaintNode *node)
+{
+ ClutterOffscreenEffectPrivate *priv = offscreen_effect->priv;
+ ClutterPaintNode *actor_node;
+
+ actor_node = clutter_actor_node_new (priv->actor, 255);
+ clutter_paint_node_add_child (node, actor_node);
+ clutter_paint_node_unref (actor_node);
+}
+
+static void
+clutter_offscreen_effect_paint_node (ClutterEffect *effect,
+ ClutterPaintNode *node,
+ ClutterPaintContext *paint_context,
+ ClutterEffectPaintFlags flags)
+{
+ ClutterOffscreenEffect *offscreen_effect = CLUTTER_OFFSCREEN_EFFECT (effect);
+ ClutterOffscreenEffectPrivate *priv = offscreen_effect->priv;
+ ClutterPaintNode *layer_node;
+ CoglFramebuffer *fb;
+
+ fb = COGL_FRAMEBUFFER (priv->offscreen);
+ layer_node = clutter_layer_node_new_to_framebuffer (fb, priv->pipeline);
+ clutter_paint_node_set_static_name (layer_node,
+ "ClutterOffscreenEffect (actor offscreen)");
+ clutter_paint_node_add_child (node, layer_node);
+ clutter_paint_node_unref (layer_node);
+
+ add_actor_node (offscreen_effect, layer_node);
+}
+
static void
clutter_offscreen_effect_paint (ClutterEffect *effect,
ClutterPaintContext *paint_context,
@@ -557,6 +590,7 @@ clutter_offscreen_effect_class_init (ClutterOffscreenEffectClass *klass)
effect_class->pre_paint = clutter_offscreen_effect_pre_paint;
effect_class->post_paint = clutter_offscreen_effect_post_paint;
effect_class->paint = clutter_offscreen_effect_paint;
+ effect_class->paint_node = clutter_offscreen_effect_paint_node;
gobject_class->finalize = clutter_offscreen_effect_finalize;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]