diff options
author | panoskorovesis <panoskorovesis@outlook.com> | 2021-07-07 15:35:15 +0300 |
---|---|---|
committer | panoskorovesis <panoskorovesis@outlook.com> | 2021-07-07 15:35:15 +0300 |
commit | 2b4ac4768bda750439165b73104242065a72b68f (patch) | |
tree | e257375f9083be409fa7d61d4d22653557606ddc | |
parent | 28f11354a80a5c431808c383f11b452f016a149e (diff) |
Add Handler for MetaChord Read
The handler separates the MetaChordAction::Read from metaact.hxx
Read implementation is now in SvmReader.hxx
Change-Id: Id4251e270bab9dc609c220ad0f304ee38b9ed2bd
-rw-r--r-- | include/vcl/filter/SvmReader.hxx | 1 | ||||
-rw-r--r-- | include/vcl/metaact.hxx | 3 | ||||
-rw-r--r-- | vcl/source/filter/svm/SvmReader.cxx | 23 |
3 files changed, 26 insertions, 1 deletions
diff --git a/include/vcl/filter/SvmReader.hxx b/include/vcl/filter/SvmReader.hxx index 04ed88d5880c..3b64225f37eb 100644 --- a/include/vcl/filter/SvmReader.hxx +++ b/include/vcl/filter/SvmReader.hxx @@ -47,6 +47,7 @@ public: rtl::Reference<MetaAction> EllipseHandler(); rtl::Reference<MetaAction> ArcHandler(); rtl::Reference<MetaAction> PieHandler(); + rtl::Reference<MetaAction> ChordHandler(); }; /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/include/vcl/metaact.hxx b/include/vcl/metaact.hxx index 461006525272..d8b1f31b6a28 100644 --- a/include/vcl/metaact.hxx +++ b/include/vcl/metaact.hxx @@ -393,6 +393,9 @@ public: const tools::Rectangle& GetRect() const { return maRect; } const Point& GetStartPoint() const { return maStartPt; } const Point& GetEndPoint() const { return maEndPt; } + void SetRect(tools::Rectangle& rRect) { maRect = rRect; } + void SetStartPoint(Point& rPoint) { maStartPt = rPoint; } + void SetEndPoint(Point& rPoint) { maEndPt = rPoint; } }; class UNLESS_MERGELIBS(VCL_DLLPUBLIC) MetaPolyLineAction final : public MetaAction diff --git a/vcl/source/filter/svm/SvmReader.cxx b/vcl/source/filter/svm/SvmReader.cxx index 3ccd2ae0d5c2..50d2ed8a7415 100644 --- a/vcl/source/filter/svm/SvmReader.cxx +++ b/vcl/source/filter/svm/SvmReader.cxx @@ -183,7 +183,7 @@ rtl::Reference<MetaAction> SvmReader::MetaActionHandler(ImplMetaReadData* pData) return PieHandler(); break; case MetaActionType::CHORD: - pAction = new MetaChordAction; + return ChordHandler(); break; case MetaActionType::POLYLINE: pAction = new MetaPolyLineAction; @@ -520,4 +520,25 @@ rtl::Reference<MetaAction> SvmReader::PieHandler() return pAction; } + +rtl::Reference<MetaAction> SvmReader::ChordHandler() +{ + auto pAction = new MetaChordAction(); + + VersionCompatRead aCompat(mrStream); + TypeSerializer aSerializer(mrStream); + + tools::Rectangle aRectangle; + aSerializer.readRectangle(aRectangle); + Point aPoint; + aSerializer.readPoint(aPoint); + Point aEndPoint; + aSerializer.readPoint(aEndPoint); + + pAction->SetRect(aRectangle); + pAction->SetStartPoint(aPoint); + pAction->SetEndPoint(aEndPoint); + + return pAction; +} /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ |