[Libreoffice-commits] core.git: Branch 'distro/collabora/cp-6.4' - oox/inc oox/source sd/qa

Gülşah Köse (via logerrit) logerrit at kemper.freedesktop.org
Thu Jan 21 15:05:59 UTC 2021


 oox/inc/drawingml/fillproperties.hxx    |    3 +-
 oox/source/drawingml/fillproperties.cxx |   34 +++++++++++++++++++++++++++++++-
 oox/source/drawingml/shape.cxx          |    2 -
 sd/qa/unit/data/pptx/tdf134210.pptx     |binary
 sd/qa/unit/import-tests.cxx             |   19 +++++++++++++++++
 5 files changed, 55 insertions(+), 3 deletions(-)

New commits:
commit 9ac58bf3a6d0a72c5452a9cc162554b3a667d2e0
Author:     Gülşah Köse <gulsah.kose at collabora.com>
AuthorDate: Wed Jan 20 00:52:56 2021 +0300
Commit:     Gülşah Köse <gulsah.kose at collabora.com>
CommitDate: Thu Jan 21 16:05:24 2021 +0100

    tdf#134210 Import support for custom stretch values.
    
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/109658
    Tested-by: Jenkins
    Reviewed-by: Gülşah Köse <gulsah.kose at collabora.com>
    (cherry picked from commit 2c96bd26ec488d865370fe9d394e7c4e228e05ab)
    
    Change-Id: I33ced8d667e37b7fb79f4c87b689f45966ac0097
    Reviewed-on: https://gerrit.libreoffice.org/c/core/+/109739
    Tested-by: Jenkins CollaboraOffice <jenkinscollaboraoffice at gmail.com>
    Reviewed-by: Gülşah Köse <gulsah.kose at collabora.com>

diff --git a/oox/inc/drawingml/fillproperties.hxx b/oox/inc/drawingml/fillproperties.hxx
index 45f5c4b40272..e77885058d24 100644
--- a/oox/inc/drawingml/fillproperties.hxx
+++ b/oox/inc/drawingml/fillproperties.hxx
@@ -148,7 +148,8 @@ struct OOX_DLLPUBLIC FillProperties
                             sal_Int32 nShapeRotation = 0,
                             ::Color nPhClr = API_RGB_TRANSPARENT,
                             bool bFlipH = false,
-                            bool bFlipV = false ) const;
+                            bool bFlipV = false,
+                            bool bIsCustomShape = false ) const;
 };
 
 } // namespace drawingml
diff --git a/oox/source/drawingml/fillproperties.cxx b/oox/source/drawingml/fillproperties.cxx
index 863d3b846c60..b508f0f2ba77 100644
--- a/oox/source/drawingml/fillproperties.cxx
+++ b/oox/source/drawingml/fillproperties.cxx
@@ -93,6 +93,32 @@ Reference< XGraphic > lclRotateGraphic(uno::Reference<graphic::XGraphic> const &
     return aReturnGraphic.GetXGraphic();
 }
 
+Reference< XGraphic > lclCropGraphic(uno::Reference<graphic::XGraphic> const & xGraphic, geometry::IntegerRectangle2D aFillRect)
+{
+    ::Graphic aGraphic(xGraphic);
+    ::Graphic aReturnGraphic;
+
+    assert (aGraphic.GetType() == GraphicType::Bitmap);
+
+    BitmapEx aBitmapEx(aGraphic.GetBitmapEx());
+
+    sal_Int32 nOrigHeight = aBitmapEx.GetSizePixel().Height();
+    sal_Int32 nHeight = nOrigHeight;
+    sal_Int32 nTopCorr  = nOrigHeight * -1 * static_cast<double>(aFillRect.Y1) / 100000;
+    nHeight += nTopCorr;
+    sal_Int32 nBottomCorr = nOrigHeight * -1 * static_cast<double>(aFillRect.Y2) / 100000;
+    nHeight += nBottomCorr;
+
+    aBitmapEx.Scale(Size(aBitmapEx.GetSizePixel().Width(), nHeight));
+    aBitmapEx.Crop(tools::Rectangle(Point(0, nTopCorr), Size(aBitmapEx.GetSizePixel().Width(), nOrigHeight)));
+
+    aReturnGraphic = ::Graphic(aBitmapEx);
+    aReturnGraphic.setOriginURL(aGraphic.getOriginURL());
+
+    return aReturnGraphic.GetXGraphic();
+}
+
+
 Reference< XGraphic > lclCheckAndApplyChangeColorTransform(const BlipFillProperties &aBlipProps, uno::Reference<graphic::XGraphic> const & xGraphic,
                                                            const GraphicHelper& rGraphicHelper, const ::Color nPhClr)
 {
@@ -278,7 +304,7 @@ Color FillProperties::getBestSolidColor() const
 
 void FillProperties::pushToPropMap( ShapePropertyMap& rPropMap,
         const GraphicHelper& rGraphicHelper, sal_Int32 nShapeRotation, ::Color nPhClr,
-        bool bFlipH, bool bFlipV ) const
+        bool bFlipH, bool bFlipV, bool bIsCustomShape) const
 {
     if( moFillType.has() )
     {
@@ -668,6 +694,12 @@ void FillProperties::pushToPropMap( ShapePropertyMap& rPropMap,
                                 if ( aFillRect.Y2 )
                                     aGraphCrop.Bottom = static_cast< sal_Int32 >( ( static_cast< double >( aOriginalSize.Height ) * aFillRect.Y2 ) / 100000 );
                                 rPropMap.setProperty(PROP_GraphicCrop, aGraphCrop);
+
+                                if(bIsCustomShape)
+                                {
+                                    xGraphic = lclCropGraphic(xGraphic, aFillRect);
+                                    rPropMap.setProperty(ShapeProperty::FillBitmap, xGraphic);
+                                }
                             }
                         }
                     }
diff --git a/oox/source/drawingml/shape.cxx b/oox/source/drawingml/shape.cxx
index bf75f2e5f8df..6deae9f4992d 100644
--- a/oox/source/drawingml/shape.cxx
+++ b/oox/source/drawingml/shape.cxx
@@ -1065,7 +1065,7 @@ Reference< XShape > const & Shape::createAndInsert(
         if (getFillProperties().moFillType.has() && getFillProperties().moFillType.get() == XML_grpFill)
             getFillProperties().assignUsed(aFillProperties);
         if(!bIsCroppedGraphic)
-            aFillProperties.pushToPropMap( aShapeProps, rGraphicHelper, mnRotation, nFillPhClr, mbFlipH, mbFlipV );
+            aFillProperties.pushToPropMap( aShapeProps, rGraphicHelper, mnRotation, nFillPhClr, mbFlipH, mbFlipV, bIsCustomShape );
         LineProperties aLineProperties = getActualLineProperties(pTheme);
         aLineProperties.pushToPropMap( aShapeProps, rGraphicHelper, nLinePhClr );
         EffectProperties aEffectProperties = getActualEffectProperties(pTheme);
diff --git a/sd/qa/unit/data/pptx/tdf134210.pptx b/sd/qa/unit/data/pptx/tdf134210.pptx
new file mode 100644
index 000000000000..6867ac4801ff
Binary files /dev/null and b/sd/qa/unit/data/pptx/tdf134210.pptx differ
diff --git a/sd/qa/unit/import-tests.cxx b/sd/qa/unit/import-tests.cxx
index d3e776f2c50d..e3bd40f091eb 100644
--- a/sd/qa/unit/import-tests.cxx
+++ b/sd/qa/unit/import-tests.cxx
@@ -196,6 +196,7 @@ public:
     void testTdf90626();
     void testTdf114488();
     void testTdf134174();
+    void testTdf134210();
     void testTdf114913();
     void testTdf114821();
     void testTdf115394();
@@ -307,6 +308,7 @@ public:
     CPPUNIT_TEST(testTdf90626);
     CPPUNIT_TEST(testTdf114488);
     CPPUNIT_TEST(testTdf134174);
+    CPPUNIT_TEST(testTdf134210);
     CPPUNIT_TEST(testTdf114913);
     CPPUNIT_TEST(testTdf114821);
     CPPUNIT_TEST(testTdf115394);
@@ -2627,6 +2629,23 @@ void SdImportTest::testTdf134174()
     xDocShRef->DoClose();
 }
 
+void SdImportTest::testTdf134210()
+{
+    sd::DrawDocShellRef xDocShRef = loadURL(m_directories.getURLFromSrc(u"sd/qa/unit/data/pptx/tdf134210.pptx"), PPTX);
+    uno::Reference<beans::XPropertySet> xShape(getShapeFromPage(0, 0, xDocShRef), uno::UNO_SET_THROW);
+    CPPUNIT_ASSERT(xShape.is());
+
+    uno::Reference<graphic::XGraphic> xGraphic;
+    xShape->getPropertyValue("FillBitmap") >>= xGraphic;
+    CPPUNIT_ASSERT(xGraphic.is());
+
+    Graphic aGraphic(xGraphic);
+    BitmapEx aBitmap(aGraphic.GetBitmapEx());
+    CPPUNIT_ASSERT_EQUAL( Color(6708292), aBitmap.GetPixelColor( 0, 0 ));
+
+    xDocShRef->DoClose();
+}
+
 void SdImportTest::testTdf114913()
 {
     sd::DrawDocShellRef xDocShRef = loadURL(m_directories.getURLFromSrc("sd/qa/unit/data/pptx/tdf114913.pptx"), PPTX);


More information about the Libreoffice-commits mailing list