summaryrefslogtreecommitdiffstats
path: root/slideshow/README.md
diff options
context:
space:
mode:
Diffstat (limited to 'slideshow/README.md')
-rw-r--r--slideshow/README.md44
1 files changed, 44 insertions, 0 deletions
diff --git a/slideshow/README.md b/slideshow/README.md
new file mode 100644
index 0000000000..69fa42aebc
--- /dev/null
+++ b/slideshow/README.md
@@ -0,0 +1,44 @@
+# Impress Slideshow Engine
+
+## 3D Transitions
+
+The 3D transitions are slideshow transition engine using OpenGL and
+are located in `slideshow/source/engine/OGLTrans/`. They were initially
+written by GSOC student Shane.M.Mathews. Radek has later polished the
+code a bit, added few new 3D transitions, added infrastructure for
+vertex and fragment shaders. Wrote few transitions with fragment shader
+too.
+
+## Physics Animation Effects
+
+Physics animation effects are simulated by external 2d physics engine
+library `Box2D`. They don't directly call `Box2D` functions but instead
+use the wrapper in:
+
+* `slideshow/source/inc/box2dtools.hxx`
+* `slideshow/source/engine/box2dtools.cxx`
+
+The wrapper has two corresponding classes to manage the `Box2D` world
+and `Box2D` bodies.
+
+When a physics animation starts, a `Box2DWorld` is initiated and
+populated with every shape that is part of the foreground (which are
+shapes that do not belong to the master slide and not a background
+shape).
+
+After creation until the end of the slide (not the whole slideshow)
+the `Box2D` World isn't destroyed and reused. But the bodies that
+represent the shapes in the slide get destroyed when there's a point
+in time that there's no physics animation in progress. And recreated
+when another physics animation starts.
+
+If there are multiple physics animations in parallel only one of them
+takes the role of stepping through the simulation.
+
+If there are other animation effects that go in parallel which change
+the shape position, rotation, or visibility - they also report the
+change to `Box2DWorld`. These updates are collected in a queue in
+`Box2DWorld` and processed before stepping through the simulation.
+To achieve convincing results these updates are performed by setting
+the `Box2D` body's linear velocity or angular velocity instead of
+setting directly it's position or rotation.