diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-15 05:54:39 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-15 05:54:39 +0000 |
commit | 267c6f2ac71f92999e969232431ba04678e7437e (patch) | |
tree | 358c9467650e1d0a1d7227a21dac2e3d08b622b2 /canvas/README.md | |
parent | Initial commit. (diff) | |
download | libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip |
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'canvas/README.md')
-rw-r--r-- | canvas/README.md | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/canvas/README.md b/canvas/README.md new file mode 100644 index 0000000000..459b588d6f --- /dev/null +++ b/canvas/README.md @@ -0,0 +1,53 @@ +# UNO-based Graphics Backend + +UNO-based graphics backend, lesser impedance to modern graphics APIs +than vcl. + +## The canvas Framework + +The `canvas` framework is the successor of the system GUI and graphics +backend VCL. Basic functionality is available, supplying just as much +features as necessary to provide a VCL-equivalent feature set (except +proper BiDi/CTL support). + +The `canvas` framework consists of the following two modules, `canvas` and +`cppcanvas`. Additionally, a new generic graphics tooling is used (but +not exclusively by the canvas, Armin's drawinglayer module also make +use of it), which resides in `basegfx`. + +The UNO API used by the canvas is primarily under +`css::rendering`, with `css::rendering::XCanvas` +being the central interface. + +## The slideshow Engine + +The `slideshow` engine has replaced the former Impress-embedded +presentation framework with a fully independent UNO component, and it +is based on the canvas. Some features used there are only available +from `canvas`, like double-buffering, and hardware-accelerated +alpha-blending (currently not on all platforms). + +## Cairo canvas + +Cairo `canvas` is one of backends of canvas component. `canvas` is mostly +used for slideshow rendering and also for emf+ rendering. we hoped it +will even be used by drawing layer, but it didn't happen (yet?) for +API look at `offapi/com/sun/star/rendering/`, the implementation is in +`canvas` and `cppcanvas` modules. + +Cairo `canvas` backend uses Cairo library for rendering. Main advantage +is support of alpha transparency and in some cases accelerated +rendering. + +The backend itself is quite old and stable, not many changes in that +area lately, mostly changes for emf+ rendering, communication with +vcl and bugfixes + +## Future Works + +Look at Cairo `canvas` and situation when it is used +(mostly slideshow). + +## TODO +There still might be more cases when we +can save some roundtrips when exchanging data with vcl. |