[mutter] Add "Clutter Rendering Model" documentation
- From: Georges Basile Stavracas Neto <gbsneto src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [mutter] Add "Clutter Rendering Model" documentation
- Date: Wed, 14 Oct 2020 20:33:05 +0000 (UTC)
commit 71c96c6e59837a6abe10b53b695c77d1b280b6b0
Author: Georges Basile Stavracas Neto <georges stavracas gmail com>
Date: Wed Oct 14 20:33:04 2020 +0000
Add "Clutter Rendering Model" documentation
Clutter-Rendering-Model.md | 43 +++++++++++++++++++++++++++++++++++++++++++
1 file changed, 43 insertions(+)
---
diff --git a/Clutter-Rendering-Model.md b/Clutter-Rendering-Model.md
new file mode 100644
index 0000000..0fb9500
--- /dev/null
+++ b/Clutter-Rendering-Model.md
@@ -0,0 +1,43 @@
+Clutter renders the stage and actors in a 3D space. Most of the time, all the scene is composed of only 2D
actors. Remember that common operations, like rotating on the Z axis, and scaling and translating on the X or
Y axis, do not make actors 3D, which allows Clutter to optimize rendering for 2D.
+
+# Camera
+
+ClutterStage builds the view matrix (i.e. the matrix that transforms world coordinates into camera
coordinates) assuming that the camera is placed at (0, 0, 0) with a normal (0, 0, -1). That means the camera
is pointing *down*:
+
+data:image/s3,"s3://crabby-images/68701/687017dfb975441fc9edf9bcd2516c5b67df7041" alt="Clutter camera"
+
+The camera is implicit, and as of now, hardcoded.
+
+# Perspective
+
+When setting up the projection, ClutterStage uses a traditional perspective projection, with the addition of
a "2D plane". The 2D plane (`z-2d`) is a plane in the Z axis that all the stage will be rendered into. The
perspective projection is build with the following parameters:
+
+ * **field of view Y**: 60º (hardcoded)
+ * **aspect**: width / height (depends on monitor configuration)
+ * **z-near**: 1.0 (hardcoded)
+ * **z-2d**: `z-near + z-near * 49,36` ( = 50,36)
+ * **z-far**: `z-2d + z-2d * tan(30º) * 20` ( = 631,97)
+
+data:image/s3,"s3://crabby-images/d1e85/d1e85ab29988f50369a71ef6a600732ceae95add" alt="view_cone"
+
+# Culling
+
+Figuring out what **not** to draw is an important optimization of the rendering process. Clutter relies on
clip frusta to detect which actors it can skip drawing.
+
+## Depth Culling
+
+The z-near and z-far values above are used to build the clip frusta, which culls out actors based on their
position. If they're below than z-far, or above z-near, they are not rendered:
+
+data:image/s3,"s3://crabby-images/53bce/53bce29b7220bdea5ccfd47f1abfbbb53184ebcb" alt="view_cone__with_z_culling_"
+
+## Clip Regions
+
+Clutter supports defining which regions of the 2D screen changed. Suppose you hover a button; only the
rectangle that that button cover is redrawn, instead of the entire screen. For example:
+
+data:image/s3,"s3://crabby-images/375b0/375b022bc4f5d8d7ccd42de60eb5031583992923" alt="clip_region"
+*GNOME Shell with 3 clip regions (green)*
+
+ This is translated to the 3D scene by using multiple clip frusta. Each frustum is a slice of the view cone,
and only those actors and geometry and intersects it is rendered. If an actor doesn't touch any of the
frusta, it is skipped when drawing.
+
+data:image/s3,"s3://crabby-images/c2038/c203899145aa9123cc451e5285af9593548eaf19" alt="clip_frusta"
+*View cone with 3 clip frusta (green)*
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]