Initial implementation of GSK rendering pipeline

Desktop / GNOME / GTK - Emmanuele Bassi [gnome.org] - 18 October 2016 05:29 UTC

GSK is conceptually split into two scene graphs:

- a simple rendering tree of operations
- a complex set of logical layers

The latter is built on the former, and adds convenience and high level API for application developers.

The lower layer, though, is what gets transformed into the rendering pipeline, as it's simple and thus can be transformed into appropriate rendering commands with minimal state changes.

The lower layer is also suitable for reuse from more complex higher layers, like the CSS machinery in GTK, without necessarily port those layers to the GSK high level API.

This lower layer is based on GskRenderNode instances, which represent the tree of rendering operations; and a GskRenderer instance, which takes the render nodes and submits them (after potentially reordering and transforming them to a more appropriate representation) to the underlying graphic system.

7afdd3f Initial implementation of GSK rendering pipeline
gsk/Makefile.am | 146 ++-
gsk/gsk.h | 33 +
gsk/gskcairorenderer.c | 195 ++++
gsk/gskcairorendererprivate.h | 26 +
gsk/gskdebug.c | 58 +
gsk/gskdebugprivate.h | 43 +
gsk/gskenums.h | 46 +
gsk/gskenumtypes.c.template | 38 +
gsk/gskenumtypes.h.template | 24 +
gsk/gskglrenderer.c | 1092 +++++++++++++++++++
gsk/gskglrendererprivate.h | 23 +
gsk/gskprivate.c | 16 +
gsk/gskprivate.h | 12 +
gsk/gskrenderer.c | 1377 ++++++++++++++++++++++++
gsk/gskrenderer.h | 113 ++
gsk/gskrendererprivate.h | 62 ++
gsk/gskrendernode.c | 1246 +++++++++++++++++++++
gsk/gskrendernode.h | 117 ++
gsk/gskrendernodeiter.c | 254 +++++
gsk/gskrendernodeiter.h | 45 +
gsk/gskrendernodeprivate.h | 124 +++
gsk/gsktypes.h | 29 +
gsk/resources/glsl/base-renderer-fragment.glsl | 13 +
gsk/resources/glsl/base-renderer-vertex.glsl | 16 +
tests/Makefile.am | 9 +-
tests/testgskrenderer.c | 229 ++++
26 files changed, 5349 insertions(+), 37 deletions(-)

Upstream: git.gnome.org


  • Share