From d9420a64fbb288020d33b681f40a858db49afca7 Mon Sep 17 00:00:00 2001 From: Miklos Vajna Date: Mon, 16 Apr 2018 10:11:26 +0200 Subject: tdf#117028 sw: conditionally consider fill of shape for in-textbox auto color Commit f966767e1ccfa432da33e1a0fd6de69e17a36bc3 (tdf#116925 sw: consider fill styles of shape for in-textbox auto color, 2018-04-10) did this unconditionally, but there are two cases: 1) Shape (with textbox) has a fill, in that case auto text color of textbox should consider the shape fill. 2) Shape has no fill, in that case the shape fill should not be considered when counting the background of a transparent fly frame. Fix 2) without breaking 1) by making the change to SwFrame::GetBackgroundBrush() opt-in, and only use it for auto font color, not in other cases. Change-Id: I761a1b7d6ecf47586edbe5641ec012f22f6a53d7 Reviewed-on: https://gerrit.libreoffice.org/52941 Reviewed-by: Miklos Vajna Tested-by: Jenkins --- sw/source/core/access/accpara.cxx | 2 +- sw/source/core/doc/notxtfrm.cxx | 2 +- sw/source/core/inc/frame.hxx | 3 ++- sw/source/core/layout/paintfrm.cxx | 23 ++++++++++++++--------- sw/source/core/text/inftxt.cxx | 2 +- sw/source/core/txtnode/fntcache.cxx | 2 +- 6 files changed, 20 insertions(+), 14 deletions(-) (limited to 'sw/source') diff --git a/sw/source/core/access/accpara.cxx b/sw/source/core/access/accpara.cxx index f2dff93ebf2c..5a779d55548a 100644 --- a/sw/source/core/access/accpara.cxx +++ b/sw/source/core/access/accpara.cxx @@ -994,7 +994,7 @@ static bool lcl_GetBackgroundColor( Color & rColor, drawinglayer::attribute::SdrAllFillAttributesHelperPtr aFillAttributes; if ( pFrame && - pFrame->GetBackgroundBrush( aFillAttributes, pBackgrdBrush, pSectionTOXColor, aDummyRect, false ) ) + pFrame->GetBackgroundBrush( aFillAttributes, pBackgrdBrush, pSectionTOXColor, aDummyRect, false, /*bConsiderTextBox=*/false ) ) { if ( pSectionTOXColor ) { diff --git a/sw/source/core/doc/notxtfrm.cxx b/sw/source/core/doc/notxtfrm.cxx index 4c6c8ffc80e9..6dd910fab9ee 100644 --- a/sw/source/core/doc/notxtfrm.cxx +++ b/sw/source/core/doc/notxtfrm.cxx @@ -187,7 +187,7 @@ static void lcl_ClearArea( const SwFrame &rFrame, SwRect aOrigRect; drawinglayer::attribute::SdrAllFillAttributesHelperPtr aFillAttributes; - if ( rFrame.GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigRect, false ) ) + if ( rFrame.GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigRect, false, /*bConsiderTextBox=*/false ) ) { SwRegionRects const region(rPtArea); basegfx::utils::B2DClipState aClipState; diff --git a/sw/source/core/inc/frame.hxx b/sw/source/core/inc/frame.hxx index ee21f12bd6f0..b9d90f9a0f37 100644 --- a/sw/source/core/inc/frame.hxx +++ b/sw/source/core/inc/frame.hxx @@ -557,7 +557,8 @@ public: const SvxBrushItem*& rpBrush, const Color*& rpColor, SwRect &rOrigRect, - bool bLowerMode ) const; + bool bLowerMode, + bool bConsiderTextBox ) const; inline void SetCompletePaint() const; inline void ResetCompletePaint() const; diff --git a/sw/source/core/layout/paintfrm.cxx b/sw/source/core/layout/paintfrm.cxx index bd7b911dee71..1d1cf069385c 100644 --- a/sw/source/core/layout/paintfrm.cxx +++ b/sw/source/core/layout/paintfrm.cxx @@ -3725,7 +3725,7 @@ bool SwFlyFrame::IsBackgroundTransparent() const SwRect aDummyRect; drawinglayer::attribute::SdrAllFillAttributesHelperPtr aFillAttributes; - if ( GetBackgroundBrush( aFillAttributes, pBackgrdBrush, pSectionTOXColor, aDummyRect, false) ) + if ( GetBackgroundBrush( aFillAttributes, pBackgrdBrush, pSectionTOXColor, aDummyRect, false, /*bConsiderTextBox=*/false) ) { if ( pSectionTOXColor && (pSectionTOXColor->GetTransparency() != 0) && @@ -6137,7 +6137,7 @@ void SwFrame::PaintSwFrameBackground( const SwRect &rRect, const SwPageFrame *pP bool bLowMode = true; drawinglayer::attribute::SdrAllFillAttributesHelperPtr aFillAttributes; - bool bBack = GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, bLowerMode ); + bool bBack = GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, bLowerMode, /*bConsiderTextBox=*/false ); //- Output if a separate background is used. bool bNoFlyBackground = !gProp.bSFlyMetafile && !bBack && IsFlyFrame(); if ( bNoFlyBackground ) @@ -6147,7 +6147,7 @@ void SwFrame::PaintSwFrameBackground( const SwRect &rRect, const SwPageFrame *pP // disabled this option with the parameter if ( bLowerMode ) { - bBack = GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, false ); + bBack = GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, false, /*bConsiderTextBox=*/false ); } // If still no background found for the fly frame, initialize the // background brush with global retouche color and set @@ -6946,7 +6946,7 @@ const Color SwPageFrame::GetDrawBackgrdColor() const SwRect aDummyRect; drawinglayer::attribute::SdrAllFillAttributesHelperPtr aFillAttributes; - if ( GetBackgroundBrush( aFillAttributes, pBrushItem, pDummyColor, aDummyRect, true) ) + if ( GetBackgroundBrush( aFillAttributes, pBrushItem, pDummyColor, aDummyRect, true, /*bConsiderTextBox=*/false) ) { if(aFillAttributes.get() && aFillAttributes->isUsed()) { @@ -7110,6 +7110,10 @@ void SwFrame::Retouch( const SwPageFrame * pPage, const SwRect &rRect ) const * input parameter - boolean indicating, if background brush should *not* be * taken from parent. * + * @param bConsiderTextBox + * consider the TextBox of this fly frame (if there is any) when determining + * the background color, useful for automatic font color. + * * @return true, if a background brush for the frame is found */ bool SwFrame::GetBackgroundBrush( @@ -7117,7 +7121,8 @@ bool SwFrame::GetBackgroundBrush( const SvxBrushItem* & rpBrush, const Color*& rpCol, SwRect &rOrigRect, - bool bLowerMode ) const + bool bLowerMode, + bool bConsiderTextBox ) const { const SwFrame *pFrame = this; SwViewShell *pSh = getRootFrame()->GetCurrShell(); @@ -7131,8 +7136,8 @@ bool SwFrame::GetBackgroundBrush( if (pFrame->supportsFullDrawingLayerFillAttributeSet()) { - bool bTextBox = false; - if (pFrame->IsFlyFrame()) + bool bHandledTextBox = false; + if (pFrame->IsFlyFrame() && bConsiderTextBox) { const SwFlyFrame* pFlyFrame = static_cast(pFrame); SwFrameFormat* pShape @@ -7146,12 +7151,12 @@ bool SwFrame::GetBackgroundBrush( rFillAttributes.reset( new drawinglayer::attribute::SdrAllFillAttributesHelper( pObject->GetMergedItemSet())); - bTextBox = true; + bHandledTextBox = true; } } } - if (!bTextBox) + if (!bHandledTextBox) rFillAttributes = pFrame->getSdrAllFillAttributesHelper(); } const SvxBrushItem &rBack = pFrame->GetAttrSet()->GetBackground(); diff --git a/sw/source/core/text/inftxt.cxx b/sw/source/core/text/inftxt.cxx index 92f92f7ad872..65e25af2ee58 100644 --- a/sw/source/core/text/inftxt.cxx +++ b/sw/source/core/text/inftxt.cxx @@ -535,7 +535,7 @@ static bool lcl_IsDarkBackground( const SwTextPaintInfo& rInf ) // See implementation in /core/layout/paintfrm.cxx // There is a background color, if there is a background brush and // its color is *not* "no fill"/"auto fill". - if( rInf.GetTextFrame()->GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, false ) ) + if( rInf.GetTextFrame()->GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, false, /*bConsiderTextBox=*/false ) ) { if ( !pCol ) pCol = &pItem->GetColor(); diff --git a/sw/source/core/txtnode/fntcache.cxx b/sw/source/core/txtnode/fntcache.cxx index a26aa13c2ee1..9aab72c50ddf 100644 --- a/sw/source/core/txtnode/fntcache.cxx +++ b/sw/source/core/txtnode/fntcache.cxx @@ -2511,7 +2511,7 @@ bool SwDrawTextInfo::ApplyAutoColor( vcl::Font* pFont ) /// OD 21.08.2002 #99657# /// There is a user defined setting for the background, if there /// is a background brush and its color is *not* "no fill"/"auto fill". - if( GetFrame()->GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, false ) ) + if( GetFrame()->GetBackgroundBrush( aFillAttributes, pItem, pCol, aOrigBackRect, false, /*bConsiderTextBox=*/true ) ) { if (aFillAttributes.get() && aFillAttributes->isUsed()) { -- cgit