summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sc/inc/patattr.hxx1
-rw-r--r--sc/source/core/data/patattr.cxx131
2 files changed, 62 insertions, 70 deletions
diff --git a/sc/inc/patattr.hxx b/sc/inc/patattr.hxx
index cc37c335cfc0..eacb69fd640b 100644
--- a/sc/inc/patattr.hxx
+++ b/sc/inc/patattr.hxx
@@ -43,7 +43,6 @@ enum class ScRotateDir : sal_uInt8;
enum class ScAutoFontColorMode
{
Raw, ///< COL_AUTO is returned
- Black, ///< always use black
Print, ///< black or white, depending on background
Display, ///< from style settings, or black/white if needed
IgnoreFont, ///< like DISPLAY, but ignore stored font color (assume COL_AUTO)
diff --git a/sc/source/core/data/patattr.cxx b/sc/source/core/data/patattr.cxx
index d3a9de543d3a..e2cd22a390c6 100644
--- a/sc/source/core/data/patattr.cxx
+++ b/sc/source/core/data/patattr.cxx
@@ -461,89 +461,82 @@ void ScPatternAttr::fillColor(model::ComplexColor& rComplexColor, const SfxItemS
|| eAutoMode == ScAutoFontColorMode::IgnoreFont
|| eAutoMode == ScAutoFontColorMode::IgnoreAll)
{
- if (eAutoMode == ScAutoFontColorMode::Black)
+ // get background color from conditional or own set
+ Color aBackColor;
+ if ( pCondSet )
{
- aColor = COL_BLACK;
+ const SvxBrushItem* pItem = pCondSet->GetItemIfSet(ATTR_BACKGROUND);
+ if (!pItem)
+ pItem = &rItemSet.Get(ATTR_BACKGROUND);
+ aBackColor = pItem->GetColor();
}
else
{
- // get background color from conditional or own set
- Color aBackColor;
- if ( pCondSet )
- {
- const SvxBrushItem* pItem = pCondSet->GetItemIfSet(ATTR_BACKGROUND);
- if (!pItem)
- pItem = &rItemSet.Get(ATTR_BACKGROUND);
- aBackColor = pItem->GetColor();
- }
- else
- {
- aBackColor = rItemSet.Get(ATTR_BACKGROUND).GetColor();
- }
+ aBackColor = rItemSet.Get(ATTR_BACKGROUND).GetColor();
+ }
- // if background color attribute is transparent, use window color for brightness comparisons
- if (aBackColor == COL_TRANSPARENT
- || eAutoMode == ScAutoFontColorMode::IgnoreBack
- || eAutoMode == ScAutoFontColorMode::IgnoreAll)
+ // if background color attribute is transparent, use window color for brightness comparisons
+ if (aBackColor == COL_TRANSPARENT
+ || eAutoMode == ScAutoFontColorMode::IgnoreBack
+ || eAutoMode == ScAutoFontColorMode::IgnoreAll)
+ {
+ if (!comphelper::LibreOfficeKit::isActive())
{
- if (!comphelper::LibreOfficeKit::isActive())
+ if ( eAutoMode == ScAutoFontColorMode::Print )
+ aBackColor = COL_WHITE;
+ else if ( pBackConfigColor )
{
- if ( eAutoMode == ScAutoFontColorMode::Print )
- aBackColor = COL_WHITE;
- else if ( pBackConfigColor )
- {
- // pBackConfigColor can be used to avoid repeated lookup of the configured color
- aBackColor = *pBackConfigColor;
- }
- else
- aBackColor = SC_MOD()->GetColorConfig().GetColorValue(svtools::DOCCOLOR).nColor;
+ // pBackConfigColor can be used to avoid repeated lookup of the configured color
+ aBackColor = *pBackConfigColor;
}
else
- {
- // Get document color from current view instead
- SfxViewShell* pSfxViewShell = SfxViewShell::Current();
- ScTabViewShell* pViewShell = dynamic_cast<ScTabViewShell*>(pSfxViewShell);
- if (pViewShell)
- {
- const ScViewData& pViewData = pViewShell->GetViewData();
- const ScViewOptions& aViewOptions = pViewData.GetOptions();
- aBackColor = aViewOptions.GetDocColor();
- }
- }
- }
-
- // get system text color for comparison
- Color aSysTextColor;
- if (eAutoMode == ScAutoFontColorMode::Print)
- {
- aSysTextColor = COL_BLACK;
- }
- else if (pTextConfigColor)
- {
- // pTextConfigColor can be used to avoid repeated lookup of the configured color
- aSysTextColor = *pTextConfigColor;
+ aBackColor = SC_MOD()->GetColorConfig().GetColorValue(svtools::DOCCOLOR).nColor;
}
else
{
- aSysTextColor = SC_MOD()->GetColorConfig().GetColorValue(svtools::FONTCOLOR).nColor;
+ // Get document color from current view instead
+ SfxViewShell* pSfxViewShell = SfxViewShell::Current();
+ ScTabViewShell* pViewShell = dynamic_cast<ScTabViewShell*>(pSfxViewShell);
+ if (pViewShell)
+ {
+ const ScViewData& pViewData = pViewShell->GetViewData();
+ const ScViewOptions& aViewOptions = pViewData.GetOptions();
+ aBackColor = aViewOptions.GetDocColor();
+ }
}
+ }
- // select the resulting color
- if ( aBackColor.IsDark() && aSysTextColor.IsDark() )
- {
- // use white instead of dark on dark
- aColor = COL_WHITE;
- }
- else if ( aBackColor.IsBright() && aSysTextColor.IsBright() )
- {
- // use black instead of bright on bright
- aColor = COL_BLACK;
- }
- else
- {
- // use aSysTextColor (black for ScAutoFontColorMode::Print, from style settings otherwise)
- aColor = aSysTextColor;
- }
+ // get system text color for comparison
+ Color aSysTextColor;
+ if (eAutoMode == ScAutoFontColorMode::Print)
+ {
+ aSysTextColor = COL_BLACK;
+ }
+ else if (pTextConfigColor)
+ {
+ // pTextConfigColor can be used to avoid repeated lookup of the configured color
+ aSysTextColor = *pTextConfigColor;
+ }
+ else
+ {
+ aSysTextColor = SC_MOD()->GetColorConfig().GetColorValue(svtools::FONTCOLOR).nColor;
+ }
+
+ // select the resulting color
+ if ( aBackColor.IsDark() && aSysTextColor.IsDark() )
+ {
+ // use white instead of dark on dark
+ aColor = COL_WHITE;
+ }
+ else if ( aBackColor.IsBright() && aSysTextColor.IsBright() )
+ {
+ // use black instead of bright on bright
+ aColor = COL_BLACK;
+ }
+ else
+ {
+ // use aSysTextColor (black for ScAutoFontColorMode::Print, from style settings otherwise)
+ aColor = aSysTextColor;
}
}
aComplexColor.setFinalColor(aColor);