summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpanoskorovesis <panoskorovesis@outlook.com>2021-07-13 13:23:07 +0300
committerpanoskorovesis <panoskorovesis@outlook.com>2021-07-13 15:22:52 +0300
commitd23a21b4e98466a5ad792149280d3a9745545744 (patch)
tree85dd0cf46d03affc31853a2d9bb3d9d721a20e25
parent920fa3600b4084dfed9d7e9b13847de1c4eee86a (diff)
Add Handler for MaskScale Read
The handler separates MetaMaskScale::Read from metaact.hxx Read implementation is now in SvmReader.hxx Change-Id: I20aec9f6c767f82ba8bac0198e4e733511f33fab
-rw-r--r--include/vcl/filter/SvmReader.hxx1
-rw-r--r--include/vcl/metaact.hxx3
-rw-r--r--vcl/source/filter/svm/SvmReader.cxx22
3 files changed, 25 insertions, 1 deletions
diff --git a/include/vcl/filter/SvmReader.hxx b/include/vcl/filter/SvmReader.hxx
index 0adcf65a9015..9544bb2f8e4d 100644
--- a/include/vcl/filter/SvmReader.hxx
+++ b/include/vcl/filter/SvmReader.hxx
@@ -63,6 +63,7 @@ public:
rtl::Reference<MetaAction> BmpExScaleHandler();
rtl::Reference<MetaAction> BmpExScalePartHandler();
rtl::Reference<MetaAction> MaskHandler();
+ rtl::Reference<MetaAction> MaskScaleHandler();
};
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/include/vcl/metaact.hxx b/include/vcl/metaact.hxx
index 14f910994031..e48cdf2d8c0d 100644
--- a/include/vcl/metaact.hxx
+++ b/include/vcl/metaact.hxx
@@ -987,6 +987,9 @@ public:
const Color& GetColor() const { return maColor; }
const Point& GetPoint() const { return maPt; }
const Size& GetSize() const { return maSz; }
+ void SetBitmap(Bitmap& rBmp) { maBmp = rBmp; }
+ void SetPoint(Point& rPt) { maPt = rPt; }
+ void SetSize(Size& rSz) { maSz = rSz; }
};
class SAL_DLLPUBLIC_RTTI MetaMaskScalePartAction final : public MetaAction
diff --git a/vcl/source/filter/svm/SvmReader.cxx b/vcl/source/filter/svm/SvmReader.cxx
index b98d4a4056cf..624712be19ba 100644
--- a/vcl/source/filter/svm/SvmReader.cxx
+++ b/vcl/source/filter/svm/SvmReader.cxx
@@ -232,7 +232,7 @@ rtl::Reference<MetaAction> SvmReader::MetaActionHandler(ImplMetaReadData* pData)
return MaskHandler();
break;
case MetaActionType::MASKSCALE:
- pAction = new MetaMaskScaleAction;
+ return MaskScaleHandler();
break;
case MetaActionType::MASKSCALEPART:
pAction = new MetaMaskScalePartAction;
@@ -978,4 +978,24 @@ rtl::Reference<MetaAction> SvmReader::MaskHandler()
return pAction;
}
+
+rtl::Reference<MetaAction> SvmReader::MaskScaleHandler()
+{
+ auto pAction = new MetaMaskScaleAction();
+
+ VersionCompatRead aCompat(mrStream);
+ Bitmap aBmp;
+ ReadDIB(aBmp, mrStream, true);
+ TypeSerializer aSerializer(mrStream);
+ Point aPoint;
+ aSerializer.readPoint(aPoint);
+ Size aSize;
+ aSerializer.readSize(aSize);
+
+ pAction->SetBitmap(aBmp);
+ pAction->SetPoint(aPoint);
+ pAction->SetSize(aSize);
+
+ return pAction;
+}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */