summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpanoskorovesis <panoskorovesis@outlook.com>2021-07-09 19:15:38 +0300
committerpanoskorovesis <panoskorovesis@outlook.com>2021-07-13 12:21:07 +0300
commit920fa3600b4084dfed9d7e9b13847de1c4eee86a (patch)
treef8f6b25263c6a31bb142bdb9b0bca70b43ce39be
parentb3bbec35836090ce253174d79a52f8636e9ba8e6 (diff)
Add Handler for Mask Read
The handler separates MetaMaskAction::Read from metaact.hxx Read implementation is now in SvmReader.hxx Change-Id: I00fb652271055d071e36f7a1bbe7a48b00f47085
-rw-r--r--include/vcl/filter/SvmReader.hxx1
-rw-r--r--include/vcl/metaact.hxx2
-rw-r--r--vcl/source/filter/svm/SvmReader.cxx19
3 files changed, 21 insertions, 1 deletions
diff --git a/include/vcl/filter/SvmReader.hxx b/include/vcl/filter/SvmReader.hxx
index 9ce071448dca..0adcf65a9015 100644
--- a/include/vcl/filter/SvmReader.hxx
+++ b/include/vcl/filter/SvmReader.hxx
@@ -62,6 +62,7 @@ public:
rtl::Reference<MetaAction> BmpExHandler();
rtl::Reference<MetaAction> BmpExScaleHandler();
rtl::Reference<MetaAction> BmpExScalePartHandler();
+ rtl::Reference<MetaAction> MaskHandler();
};
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/include/vcl/metaact.hxx b/include/vcl/metaact.hxx
index c59257433daa..14f910994031 100644
--- a/include/vcl/metaact.hxx
+++ b/include/vcl/metaact.hxx
@@ -949,6 +949,8 @@ public:
const Bitmap& GetBitmap() const { return maBmp; }
const Color& GetColor() const { return maColor; }
const Point& GetPoint() const { return maPt; }
+ void SetBitmap(Bitmap& rBmp) { maBmp = rBmp; }
+ void SetPoint(Point& rPt) { maPt = rPt; }
};
class SAL_DLLPUBLIC_RTTI MetaMaskScaleAction final : public MetaAction
diff --git a/vcl/source/filter/svm/SvmReader.cxx b/vcl/source/filter/svm/SvmReader.cxx
index 679a6185c503..b98d4a4056cf 100644
--- a/vcl/source/filter/svm/SvmReader.cxx
+++ b/vcl/source/filter/svm/SvmReader.cxx
@@ -229,7 +229,7 @@ rtl::Reference<MetaAction> SvmReader::MetaActionHandler(ImplMetaReadData* pData)
return BmpExScalePartHandler();
break;
case MetaActionType::MASK:
- pAction = new MetaMaskAction;
+ return MaskHandler();
break;
case MetaActionType::MASKSCALE:
pAction = new MetaMaskScaleAction;
@@ -961,4 +961,21 @@ rtl::Reference<MetaAction> SvmReader::BmpExScalePartHandler()
return pAction;
}
+
+rtl::Reference<MetaAction> SvmReader::MaskHandler()
+{
+ auto pAction = new MetaMaskAction();
+
+ VersionCompatRead aCompat(mrStream);
+ Bitmap aBmp;
+ ReadDIB(aBmp, mrStream, true);
+ TypeSerializer aSerializer(mrStream);
+ Point aPoint;
+ aSerializer.readPoint(aPoint);
+
+ pAction->SetBitmap(aBmp);
+ pAction->SetPoint(aPoint);
+
+ return pAction;
+}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */