[Libreoffice-commits] core.git: Branch 'distro/collabora/co-2021' - sw/source

Miklos Vajna (via logerrit) logerrit at kemper.freedesktop.org
Wed Mar 31 06:30:17 UTC 2021


 sw/source/uibase/uno/unotxdoc.cxx |    4 ++++
 1 file changed, 4 insertions(+)

New commits:
commit 9a8f8719b7a315a0cce213428f50957dfef792af
Author:     Miklos Vajna <vmiklos at collabora.com>
AuthorDate: Mon Feb 1 17:44:39 2021 +0100
Commit:     Miklos Vajna <vmiklos at collabora.com>
CommitDate: Wed Mar 31 08:20:32 2021 +0200

    sw lok: disable field shadings
    
    There are two problems with it:
    
    First, the field shading is rendered behind bullet portions depending on
    the cursor position (if the cursor is before the bullet, then we
    render it; but not if the cursor is after the bullet), and tiled
    rendering assumes that the render result is independent from the cursor
    position.
    
    Second, field shading is always painted directly (not going via
    invalidation), so it's possible to end up with one tile showing field
    shadings and another not, which is inconsistent. And even if it would be
    there consistently, that would mean a lot of unnecessary invalidations.
    
    The alternative would be to disable this from online.git's
    loolconfig.xcu, but the item's path would end with something like
    "ColorScheme['LibreOfficeDev']/WriterFieldShadings", which means it's
    not easy to do this in a way that's independent from the product name.
    
    (cherry picked from commit 876da94619d561e4b4c6c7d12a8d6726eb857df8)
    
    Change-Id: I23c62acc3c15966cfba98fcee99cc96854ba4394

diff --git a/sw/source/uibase/uno/unotxdoc.cxx b/sw/source/uibase/uno/unotxdoc.cxx
index 4362d09044ec..7261aaa79fc1 100644
--- a/sw/source/uibase/uno/unotxdoc.cxx
+++ b/sw/source/uibase/uno/unotxdoc.cxx
@@ -3458,6 +3458,10 @@ void SwXTextDocument::initializeForTiledRendering(const css::uno::Sequence<css::
     // Tiled rendering defaults.
     SwViewOption aViewOption(*pViewShell->GetViewOptions());
     aViewOption.SetHardBlank(false);
+
+    // Disable field shadings: the result would depend on the cursor position.
+    SwViewOption::SetAppearanceFlag(ViewOptFlags::FieldShadings, false);
+
     for (const beans::PropertyValue& rValue : rArguments)
     {
         if (rValue.Name == ".uno:HideWhitespace" && rValue.Value.has<bool>())


More information about the Libreoffice-commits mailing list