office-gobmx/sdext
Mike Kaganski 7b9905df45 tdf#160260: make poppler wrapper executable Unicode-aware on Windows
Change-Id: I76dc31ee14d1794fa73f990e641540ff941c7201
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/165735
Tested-by: Jenkins
Reviewed-by: Mike Kaganski <mike.kaganski@collabora.com>
2024-04-03 22:11:17 +02:00
..
inc remove leftover PresenterScreen PCH files 2024-03-19 16:33:00 +01:00
qa/unit tdf#146619 Drop unused 'using namespace' in: sdext/ 2024-03-31 19:22:57 +02:00
source tdf#160260: make poppler wrapper executable Unicode-aware on Windows 2024-04-03 22:11:17 +02:00
CppunitTest_sdext_pdfimport.mk tdf#104597 related: restore the mirroring of Bidi_Mirrored characters 2022-11-30 13:40:24 +01:00
CustomTarget_pdfimport.mk
Executable_pdf2xml.mk tdf#104597 related: restore the mirroring of Bidi_Mirrored characters 2022-11-30 13:40:24 +01:00
Executable_pdfunzip.mk tdf#104597 related: restore the mirroring of Bidi_Mirrored characters 2022-11-30 13:40:24 +01:00
Executable_xpdfimport.mk Fix building without system cairo, fontconfig, freetype, and harfbuzz 2022-09-15 20:38:00 +02:00
IwyuFilter_sdext.yaml tdf#146619 Drop unused 'using namespace' in: sdext/ 2024-03-31 19:22:57 +02:00
Library_pdfimport.mk tdf#104597 related: restore the mirroring of Bidi_Mirrored characters 2022-11-30 13:40:24 +01:00
Library_PresentationMinimizer.mk loplugin:unusedmethods 2022-12-07 17:17:33 +00:00
Makefile
Module_sdext.mk move presenter console from sdext/ to sd/ 2023-01-21 16:23:19 +00:00
Package_pdfimport_xpdfimport.mk
README.md

Extensions for the Impress and Draw Applications

source/pdfimport/ - PDF import

Uses an external poppler process to parse and handle PDF import as draw shapes.

source/minimizer/ - Presentation Minimizer

Shrinks presentations by down-scaling images, and removing extraneous eg. embedded OLE content.

source/presenter/ - Impress / Presenter Console.

This couples to sd/ in rather strange ways. Its design is heavily mangled by an attempt to use only UNO interfaces which are highly inadequate. This leads to somewhat ridiculous situations. Activating in response to configuration keys (for example), and the XPresenterHelper interface inside sd/ used to create and manage windows.

The main screen uses a hardware-accelerated canvas (e.g. cairo canvas), while the entire secondary screen uses a VCL-canvas that is created in sd::framework::FullScreenPane::CreateCanvas().

The secondary screen contains 3 Panes which each have 2 XWindows for the border area & the actual content, and each content Pane is backed by a sd::presenter::PresenterCanvas that wraps the FullScreenPane's canvas and does clipping.