![Jonas Ådahl](/assets/img/avatar_default.png)
When painting, actors rely on semi global state tracked by the state to get various things needed for painting, such as the current draw framebuffer. Having state hidden in such ways can be very deceiving as it's hard to follow changes spread out, and adding more and more state that should be tracked during a paint gets annoying as they will not change in isolation but one by one in their own places. To do this better, introduce a paint context that is passed along in paint calls that contains the necessary state needed during painting. The paint context implements a framebuffer stack just as Cogl works, which is currently needed for offscreen rendering used by clutter. The same context is passed around for paint nodes, contents and effects as well. In this commit, the context is only introduced, but not used. It aims to replace the Cogl framebuffer stack, and will allow actors to know what view it is currently painted on. https://gitlab.gnome.org/GNOME/mutter/merge_requests/935
149 lines
5.3 KiB
C
149 lines
5.3 KiB
C
/*
|
|
* Clutter.
|
|
*
|
|
* An OpenGL based 'interactive canvas' library.
|
|
*
|
|
* Copyright (C) 2011 Intel Corporation.
|
|
*
|
|
* 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/>.
|
|
*
|
|
* Author:
|
|
* Emmanuele Bassi <ebassi@linux.intel.com>
|
|
*/
|
|
|
|
#ifndef __CLUTTER_PAINT_NODE_PRIVATE_H__
|
|
#define __CLUTTER_PAINT_NODE_PRIVATE_H__
|
|
|
|
#include <glib-object.h>
|
|
#include <json-glib/json-glib.h>
|
|
#include <clutter/clutter-paint-context.h>
|
|
#include <clutter/clutter-paint-node.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define CLUTTER_PAINT_NODE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), CLUTTER_TYPE_PAINT_NODE, ClutterPaintNodeClass))
|
|
#define CLUTTER_IS_PAINT_NODE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), CLUTTER_TYPE_PAINT_NODE))
|
|
#define CLUTTER_PAINT_NODE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), CLUTTER_TYPE_PAINT_NODE, ClutterPaintNodeClass))
|
|
|
|
typedef struct _ClutterPaintOperation ClutterPaintOperation;
|
|
|
|
struct _ClutterPaintNode
|
|
{
|
|
GTypeInstance parent_instance;
|
|
|
|
ClutterPaintNode *parent;
|
|
|
|
ClutterPaintNode *first_child;
|
|
ClutterPaintNode *prev_sibling;
|
|
ClutterPaintNode *next_sibling;
|
|
ClutterPaintNode *last_child;
|
|
|
|
guint n_children;
|
|
|
|
GArray *operations;
|
|
|
|
gchar *name;
|
|
|
|
volatile int ref_count;
|
|
};
|
|
|
|
struct _ClutterPaintNodeClass
|
|
{
|
|
GTypeClass base_class;
|
|
|
|
void (* finalize) (ClutterPaintNode *node);
|
|
|
|
gboolean (* pre_draw) (ClutterPaintNode *node,
|
|
ClutterPaintContext *paint_context);
|
|
void (* draw) (ClutterPaintNode *node,
|
|
ClutterPaintContext *paint_context);
|
|
void (* post_draw) (ClutterPaintNode *node,
|
|
ClutterPaintContext *paint_context);
|
|
|
|
JsonNode*(* serialize) (ClutterPaintNode *node);
|
|
|
|
CoglFramebuffer *(* get_framebuffer) (ClutterPaintNode *node);
|
|
};
|
|
|
|
#define PAINT_OP_INIT { PAINT_OP_INVALID }
|
|
|
|
typedef enum
|
|
{
|
|
PAINT_OP_INVALID = 0,
|
|
PAINT_OP_TEX_RECT,
|
|
PAINT_OP_MULTITEX_RECT,
|
|
PAINT_OP_PATH,
|
|
PAINT_OP_PRIMITIVE
|
|
} PaintOpCode;
|
|
|
|
struct _ClutterPaintOperation
|
|
{
|
|
PaintOpCode opcode;
|
|
|
|
GArray *multitex_coords;
|
|
|
|
union {
|
|
float texrect[8];
|
|
|
|
CoglPath *path;
|
|
|
|
CoglPrimitive *primitive;
|
|
} op;
|
|
};
|
|
|
|
GType _clutter_transform_node_get_type (void) G_GNUC_CONST;
|
|
GType _clutter_dummy_node_get_type (void) G_GNUC_CONST;
|
|
|
|
void _clutter_paint_operation_paint_rectangle (const ClutterPaintOperation *op);
|
|
void _clutter_paint_operation_clip_rectangle (const ClutterPaintOperation *op);
|
|
void _clutter_paint_operation_paint_path (const ClutterPaintOperation *op);
|
|
void _clutter_paint_operation_clip_path (const ClutterPaintOperation *op);
|
|
void _clutter_paint_operation_paint_primitive (const ClutterPaintOperation *op);
|
|
|
|
void _clutter_paint_node_init_types (void);
|
|
gpointer _clutter_paint_node_create (GType gtype);
|
|
|
|
ClutterPaintNode * _clutter_transform_node_new (const CoglMatrix *matrix);
|
|
ClutterPaintNode * _clutter_dummy_node_new (ClutterActor *actor);
|
|
|
|
void _clutter_paint_node_dump_tree (ClutterPaintNode *root);
|
|
|
|
G_GNUC_INTERNAL
|
|
void clutter_paint_node_remove_child (ClutterPaintNode *node,
|
|
ClutterPaintNode *child);
|
|
G_GNUC_INTERNAL
|
|
void clutter_paint_node_replace_child (ClutterPaintNode *node,
|
|
ClutterPaintNode *old_child,
|
|
ClutterPaintNode *new_child);
|
|
G_GNUC_INTERNAL
|
|
void clutter_paint_node_remove_all (ClutterPaintNode *node);
|
|
|
|
G_GNUC_INTERNAL
|
|
guint clutter_paint_node_get_n_children (ClutterPaintNode *node);
|
|
|
|
G_GNUC_INTERNAL
|
|
ClutterPaintNode * clutter_paint_node_get_first_child (ClutterPaintNode *node);
|
|
G_GNUC_INTERNAL
|
|
ClutterPaintNode * clutter_paint_node_get_previous_sibling (ClutterPaintNode *node);
|
|
G_GNUC_INTERNAL
|
|
ClutterPaintNode * clutter_paint_node_get_next_sibling (ClutterPaintNode *node);
|
|
G_GNUC_INTERNAL
|
|
ClutterPaintNode * clutter_paint_node_get_last_child (ClutterPaintNode *node);
|
|
G_GNUC_INTERNAL
|
|
ClutterPaintNode * clutter_paint_node_get_parent (ClutterPaintNode *node);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* __CLUTTER_PAINT_NODE_PRIVATE_H__ */
|