include/vcl/filter/SvmWriter.hxx    |    1 +
 vcl/source/filter/svm/SvmWriter.cxx |   23 +++++++++++++++++++++++
 2 files changed, 24 insertions(+)

New commits:
commit 1f875634f8edaf40dcf083024f03e6a623e48599
Author:     panoskorovesis <panoskorove...@outlook.com>
AuthorDate: Thu Aug 5 09:47:54 2021 +0300
Commit:     Tomaž Vajngerl <qui...@gmail.com>
CommitDate: Wed Aug 11 09:20:00 2021 +0200

    Add Handler for MaskScalePart Write
    
    The handler separates MetaMaskScalePartAction::Write from metaact.hxx
    Write implementation is now in SvmWriter.hxx
    
    Change-Id: I3c881495c013e6827c91027319a9cedcea7f96c4
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/120258
    Tested-by: Jenkins
    Reviewed-by: Tomaž Vajngerl <qui...@gmail.com>

diff --git a/include/vcl/filter/SvmWriter.hxx b/include/vcl/filter/SvmWriter.hxx
index 4ec64cf9142f..3763ef8ab8c2 100644
--- a/include/vcl/filter/SvmWriter.hxx
+++ b/include/vcl/filter/SvmWriter.hxx
@@ -64,6 +64,7 @@ public:
     void BmpExScalePartHandler(MetaBmpExScalePartAction* pAction);
     void MaskHandler(MetaMaskAction* pAction);
     void MaskScaleHandler(MetaMaskScaleAction* pAction);
+    void MaskScalePartHandler(MetaMaskScalePartAction* pAction);
     void OverlineColorHandler(MetaOverlineColorAction* pAction);
     void TextAlignHandler(MetaTextAlignAction* pAction);
     void MapModeHandler(MetaMapModeAction* pAction);
diff --git a/vcl/source/filter/svm/SvmWriter.cxx 
b/vcl/source/filter/svm/SvmWriter.cxx
index 4f045d710d32..879909267071 100644
--- a/vcl/source/filter/svm/SvmWriter.cxx
+++ b/vcl/source/filter/svm/SvmWriter.cxx
@@ -256,6 +256,13 @@ void SvmWriter::MetaActionHandler(MetaAction* pAction, 
ImplMetaWriteData* pData)
         }
         break;
 
+        case MetaActionType::MASKSCALEPART:
+        {
+            auto* pMetaAction = static_cast<MetaMaskScalePartAction*>(pAction);
+            MaskScalePartHandler(pMetaAction);
+        }
+        break;
+
         case MetaActionType::OVERLINECOLOR:
         {
             auto* pMetaAction = static_cast<MetaOverlineColorAction*>(pAction);
@@ -711,6 +718,22 @@ void SvmWriter::MaskScaleHandler(MetaMaskScaleAction* 
pAction)
     }
 }
 
+void SvmWriter::MaskScalePartHandler(MetaMaskScalePartAction* pAction)
+{
+    if (!pAction->GetBitmap().IsEmpty())
+    {
+        mrStream.WriteUInt16(static_cast<sal_uInt16>(pAction->GetType()));
+        VersionCompatWrite aCompat(mrStream, 1);
+        WriteDIB(pAction->GetBitmap(), mrStream, false, true);
+        WriteColor(pAction->GetColor());
+        TypeSerializer aSerializer(mrStream);
+        aSerializer.writePoint(pAction->GetDestPoint());
+        aSerializer.writeSize(pAction->GetDestSize());
+        aSerializer.writePoint(pAction->GetSrcPoint());
+        aSerializer.writeSize(pAction->GetSrcSize());
+    }
+}
+
 void SvmWriter::OverlineColorHandler(MetaOverlineColorAction* pAction)
 {
     mrStream.WriteUInt16(static_cast<sal_uInt16>(pAction->GetType()));

Reply via email to