diff options
author | Armin Le Grand <Armin.Le.Grand@cib.de> | 2017-06-09 19:55:17 +0200 |
---|---|---|
committer | Thorsten Behrens <Thorsten.Behrens@CIB.de> | 2017-07-15 11:01:29 +0200 |
commit | 83535a28c57ffb59f795dd35332d6b3426071e32 (patch) | |
tree | a35406c5ed8c7971681385cbb081aad325e1cf54 /include/vcl | |
parent | 79f5cb620984c4d04d53a497e698472b2192d2bb (diff) |
emfplus: create a wmf/emf/emf+ primitive based importer
First steps to organize an importer that can read/interpret
wmf/emf/emf+ and deliver a primitive representation for
the content by parsing it. Use the same mechanisms as
already applied for Svg, so to reuse abilities to keep
original binary data to allow save again and embedding in
files and have an implemented replacement bitmap based
representation. For this, unify the used helper classes
to handle more than just Svg. For 1st try, add test code
and static bool switches
Change-Id: I6e0a82943541d811a8f8d65a84115569fcd8cee7
Diffstat (limited to 'include/vcl')
-rw-r--r-- | include/vcl/graph.hxx | 6 | ||||
-rw-r--r-- | include/vcl/vectorgraphicdata.hxx (renamed from include/vcl/svgdata.hxx) | 50 |
2 files changed, 35 insertions, 21 deletions
diff --git a/include/vcl/graph.hxx b/include/vcl/graph.hxx index 8dcf5925f87f..39fd594e878e 100644 --- a/include/vcl/graph.hxx +++ b/include/vcl/graph.hxx @@ -31,7 +31,7 @@ #include <vcl/gdimtf.hxx> #include <vcl/gfxlink.hxx> #include <com/sun/star/uno/Reference.hxx> -#include <vcl/svgdata.hxx> +#include <vcl/vectorgraphicdata.hxx> #include <basegfx/vector/b2dsize.hxx> @@ -118,7 +118,7 @@ public: Graphic( Graphic&& rGraphic ); Graphic( const Bitmap& rBmp ); Graphic( const BitmapEx& rBmpEx ); - Graphic( const SvgDataPtr& rSvgDataPtr ); + Graphic( const VectorGraphicDataPtr& rVectorGraphicDataPtr ); Graphic( const Animation& rAnimation ); Graphic( const GDIMetaFile& rMtf ); Graphic( const css::uno::Reference< css::graphic::XGraphic >& rxGraphic ); @@ -219,7 +219,7 @@ public: public: - const SvgDataPtr& getSvgData() const; + const VectorGraphicDataPtr& getVectorGraphicData() const; void setPdfData(const css::uno::Sequence<sal_Int8>& rPdfData); const css::uno::Sequence<sal_Int8>& getPdfData() const; diff --git a/include/vcl/svgdata.hxx b/include/vcl/vectorgraphicdata.hxx index 7ab2d8ce89c8..f46be43489db 100644 --- a/include/vcl/svgdata.hxx +++ b/include/vcl/vectorgraphicdata.hxx @@ -17,8 +17,8 @@ * the License at http://www.apache.org/licenses/LICENSE-2.0 . */ -#ifndef INCLUDED_VCL_SVGDATA_HXX -#define INCLUDED_VCL_SVGDATA_HXX +#ifndef INCLUDED_VCL_VECTORGRAPHICDATA_HXX +#define INCLUDED_VCL_VECTORGRAPHICDATA_HXX #include <basegfx/range/b2drange.hxx> #include <com/sun/star/graphic/XPrimitive2D.hpp> @@ -27,7 +27,7 @@ #include <deque> -typedef css::uno::Sequence<sal_Int8> SvgDataArray; +typedef css::uno::Sequence<sal_Int8> VectorGraphicDataArray; // helper to convert any Primitive2DSequence to a good quality BitmapEx, @@ -39,39 +39,53 @@ BitmapEx VCL_DLLPUBLIC convertPrimitive2DSequenceToBitmapEx( const sal_uInt32 nMaximumQuadraticPixels = 500000); -class VCL_DLLPUBLIC SvgData +enum class VectorGraphicDataType +{ + Svg = 0, + Emf = 1, + Wmf = 2 +}; + +class VCL_DLLPUBLIC VectorGraphicData { private: // the file and length - SvgDataArray maSvgDataArray; + VectorGraphicDataArray maVectorGraphicDataArray; // The absolute Path if available - OUString maPath; + OUString maPath; // on demand created content - basegfx::B2DRange maRange; + basegfx::B2DRange maRange; std::deque< css::uno::Reference< css::graphic::XPrimitive2D > > - maSequence; - BitmapEx maReplacement; - size_t mNestedBitmapSize; + maSequence; + BitmapEx maReplacement; + size_t mNestedBitmapSize; + VectorGraphicDataType meVectorGraphicDataType; // on demand creators void ensureReplacement(); void ensureSequenceAndRange(); - SvgData(const SvgData&) = delete; - SvgData& operator=(const SvgData&) = delete; + VectorGraphicData(const VectorGraphicData&) = delete; + VectorGraphicData& operator=(const VectorGraphicData&) = delete; public: - SvgData(const SvgDataArray& rSvgDataArray, const OUString& rPath); - SvgData(const OUString& rPath); + VectorGraphicData( + const VectorGraphicDataArray& rVectorGraphicDataArray, + const OUString& rPath, + VectorGraphicDataType eVectorDataType); // = VectorGraphicDataType::Svg); + VectorGraphicData( + const OUString& rPath, + VectorGraphicDataType eVectorDataType); /// data read - const SvgDataArray& getSvgDataArray() const { return maSvgDataArray; } - sal_uInt32 getSvgDataArrayLength() const { return maSvgDataArray.getLength(); } + const VectorGraphicDataArray& getVectorGraphicDataArray() const { return maVectorGraphicDataArray; } + sal_uInt32 getVectorGraphicDataArrayLength() const { return maVectorGraphicDataArray.getLength(); } enum class State { UNPARSED, PARSED }; std::pair<State, size_t> getSizeBytes(); const OUString& getPath() const { return maPath; } + const VectorGraphicDataType& getVectorGraphicDataType() const { return meVectorGraphicDataType; } /// data read and evtl. on demand creation const basegfx::B2DRange& getRange() const; @@ -79,8 +93,8 @@ public: const BitmapEx& getReplacement() const; }; -typedef std::shared_ptr< SvgData > SvgDataPtr; +typedef std::shared_ptr< VectorGraphicData > VectorGraphicDataPtr; -#endif // INCLUDED_VCL_SVGDATA_HXX +#endif // INCLUDED_VCL_VECTORGRAPHICDATA_HXX /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |