summaryrefslogtreecommitdiff
path: root/canvas/README
blob: b68da4c3bf5c0897117d3c3ca9ccd022d7ef0b61 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
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 work: 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.
Tor Lillqvist 2012-12-31convert openssl to gbuild and add to tail_buildPeter Foley 2012-12-18/p:VisualStudioVersion=11.0 here, tooTor Lillqvist 2012-12-04Revert "fix python3 build on SLED11"Luboš Luňák 2012-12-04fix python3 build on SLED11Luboš Luňák 2012-11-30Nah, wrong to use /p:PlatformToolset=Windows7.1SDKTor Lillqvist 2012-11-30We need to tell the MSVS 2010 build to use Windows7.1SDKTor Lillqvist 2012-11-30Kill the ProjectReference to ssl.vcxproj, tooTor Lillqvist 2012-11-28python3: use version variables instead of hardcoded numberMichael Stahl 2012-11-28defuzz patches to squeak by RHEL-5 patchCaolán McNamara 2012-11-27python3: try to fix clang breakage in libffiMichael Stahl 2012-11-27python3: fix MSVC "implicit int" build breaker on tinderboxMichael Stahl 2012-11-27clean up PYTHON related version etc. variables:Michael Stahl 2012-11-27Make python3 work with custom VALGRIND_CFLAGSStephan Bergmann 2012-11-26python3: build LibreOfficePython.framework on MacOS XChristian Lohmaier 2012-11-19python3: fix typos in makefileMichael Stahl 2012-11-19Using --with-system-expat does seem to work also for a "bundled" oneTor Lillqvist 2012-11-17Make building python3 with current MacOSX tools proceed a bit furtherTor Lillqvist 2012-11-17python3: add module for internal Python 3 build (not active yet)Michael Stahl