Register Guidelines E-Books Today's Posts Search

Go Back   MobileRead Forums > E-Book Software > Sigil

Notices

Reply
 
Thread Tools Search this Thread
Old 04-15-2024, 03:11 AM   #61
BeckyEbook
Guru
BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.
 
BeckyEbook's Avatar
 
Posts: 695
Karma: 2180740
Join Date: Jan 2017
Location: Poland
Device: Misc
Windows 10.
When the SIGIL_DOUBLE_TEXTCURSOR_WIDTH environment variable is set, in addition to the width of the cursor, the sizes of the close and dock icons also change. This only happens in light mode, as in dark mode we override this with the appropriate styling from the win-dark-style.qss file
Attached Thumbnails
Click image for larger version

Name:	sigil-210-release-close-dock.png
Views:	36
Size:	31.1 KB
ID:	207592   Click image for larger version

Name:	sigil-210-double-cursor-env-close-dock.png
Views:	34
Size:	28.8 KB
ID:	207593  
BeckyEbook is offline   Reply With Quote
Old 04-15-2024, 08:11 AM   #62
KevinH
Sigil Developer
KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.
 
Posts: 7,671
Karma: 5433388
Join Date: Nov 2009
Device: many
@BeckyEbook,
Yes I have noticed that QDockWidget titlebar buttons seem to be broken on macOS as well but only under dark mode. This happens with or without a stylesheet used.

I tried to add the CaretStyle last to not interfere with your QProxyStyle set for dark mode.

If the pixelmetric changes for cursor width change are part of the problem (icons are okay but not positioned properly or not properly sized, I can ifdef in platform specific additions/changes to CaretStyle.cpp if you can tell me what to add for Windows.

Or alternatively, include the required stylesheet changes.

Last edited by KevinH; 04-15-2024 at 08:31 AM.
KevinH is online now   Reply With Quote
Advert
Old 04-15-2024, 08:39 AM   #63
KevinH
Sigil Developer
KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.
 
Posts: 7,671
Karma: 5433388
Join Date: Nov 2009
Device: many
@DiapDealer, @BeckyEbook

Why does Windows not use a windows style or new windows style but instead use "fusion"?

If in light mode, does the application style ever get set directly to "fusion" in our main.cpp?

If so, that style should be passed through into CaretStyle as app.style() for use with QProxyStyle.

Perhaps we need to reorganize main.cpp to explicitly set style first before passing it through any QProxyStyles?

Also, the macStyle makes dark-light theming work more fully than fusion. Perhaps a Windows specific style would do the same for Windows leaving the hard coded dark mode changes only used by Linux?

Does using a Windows style on windows and Qt allow auto dark-light theme switches without having to restart Sigil work like it does for Qt and macOS with the macOS style?

Last edited by KevinH; 04-15-2024 at 09:18 AM.
KevinH is online now   Reply With Quote
Old 04-15-2024, 09:01 AM   #64
DiapDealer
Grand Sorcerer
DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.
 
DiapDealer's Avatar
 
Posts: 27,563
Karma: 193191846
Join Date: Jan 2010
Device: Nexus 7, Kindle Fire HD
Qt light/dark on Windows is getting better, but it's still quite the crap-shoot. Fusion is still the recommended base for style changes.

I can do some experimenting to see if going with a fully Windows/user-chosen dark mode is feasible (I'm not sure if Windows on-the-fly switches are supported yet where Qt is concerned, to be honest. The lack of a Qt api to detect theme changes). There's also differences between Windows 10 and Windows 11 behavior. We should have some options since moving to Qt6.6, but there's no guarantee that whatever dark theme is automatically chosen by Windows/Qt will be compatible with the default colors/highlighting for Code View.

Some good (and by good I mean confusing and self-contradicting!) reading on the subject here: https://www.qt.io/blog/dark-mode-on-...11-with-qt-6.5

Most Linux users rely on platform themes and qtct/kvantuum to style their Qt applications. The dark mode we currently make available to Linux (same as the Windows one) if they set an environments variable, should be considered a last resort, in my opinion

Last edited by DiapDealer; 04-15-2024 at 09:40 AM.
DiapDealer is offline   Reply With Quote
Old 04-15-2024, 10:18 AM   #65
KevinH
Sigil Developer
KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.
 
Posts: 7,671
Karma: 5433388
Join Date: Nov 2009
Device: many
Okay, I fired up and updated my Manjaro Linux Box which uses KDE Plasma as my desktop.

I then git pulled from Sigil master and rebuilt and installed it.

It seems to work just fine with no visible changes in the size or the location of the DockWidget Close or and Float Buttons with and without the double width textcursor on.

That said, the native native highlight color for showing focus is not "red" and instead appears to be a blue-green of some sort.

Update: It seems this native highlight color is chosen from palette().color(QPalette::Highlight) so we can use that instead of red. So no need for a color picker!!!

I exited from Sigil and went to the KDE SystemSettings and changed from Breath Light to Breath Dark by simply clicking on an image of the two themes (just like in macOS).

Then I started up Sigil and it fired up in dark mode just fine with no issues I could detect.

So on Manjaro Linux, all appears to just work.

I agree if we just want to move the Tweak Drag Distance to an environment variable, that will free up space for the Double Cursor Width setting with no extra changes.

@DiapDealer, if you agree, and get a free moment would you move the tweak drag distance to an environment variable and add the double width cursor (and SettingsStore stuff)?

Thanks.

Last edited by KevinH; 04-15-2024 at 11:03 AM. Reason: Changed it to simpler set of changes
KevinH is online now   Reply With Quote
Advert
Old 04-15-2024, 11:52 AM   #66
DiapDealer
Grand Sorcerer
DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.
 
DiapDealer's Avatar
 
Posts: 27,563
Karma: 193191846
Join Date: Jan 2010
Device: Nexus 7, Kindle Fire HD
Quote:
Originally Posted by KevinH View Post
@DiapDealer, if you agree, and get a free moment would you move the tweak drag distance to an environment variable and add the double width cursor (and SettingsStore stuff)?
Will do. I might be a little busy this week, but I will see what I can do.

For the record, I made some quick changes to see what the default windows qt dark mode would like like (starting with Qt6.5). It doesn't actually completely suck!

If anyone would like to play, I'm including the down and dirty patch (only a handful of lines changed) to main.cpp to allow it to work. There's a mass of nasty nested ifdefs there that I didn't feel like untangling just to test it out.

Note that it's required to launch sigil with the "-style fusion" command line option to get it to work. Might be that a few color tweaks here and there would make it go.

Code:
--- a/src/main.cpp	Mon Apr 15 11:32:45 2024
+++ b/src/main.cpp	Mon Apr 15 11:17:06 2024
@@ -481,7 +481,7 @@
             }
         }
         if (!darkmode_arg_exists) {
-            current_platform_args.append("darkmode=1");
+            current_platform_args.append("darkmode=2");
         }
     }
 #endif
@@ -599,12 +599,14 @@
 #else
         if (Utility::WindowsShouldUseDarkMode()) {
             // Apply custom dark style
-            app.setStyle(new SigilDarkStyle);
+            //app.setStyle(new SigilDarkStyle);
+            ;
 #if QT_VERSION <= QT_VERSION_CHECK(5, 15, 0) || QT_VERSION >= QT_VERSION_CHECK(6, 5, 0)
             // At this point, I have no idea where along the 5.15.x series this
             // being present will break dark mode. I only know the first official
             // official windows version that uses 5.15.9 needs it to be gone.
-            app.setPalette(QApplication::style()->standardPalette());
+            // app.setPalette(QApplication::style()->standardPalette());
+            ;
 #endif
         }
 #endif

Last edited by DiapDealer; 04-15-2024 at 12:52 PM.
DiapDealer is offline   Reply With Quote
Old 04-15-2024, 12:21 PM   #67
BeckyEbook
Guru
BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.
 
BeckyEbook's Avatar
 
Posts: 695
Karma: 2180740
Join Date: Jan 2017
Location: Poland
Device: Misc
Lightbulb

Indeed – it is not tragic.
However, a few elements in dark mode are still annoying (e.g. those bright lines under toolbars, not clear dock/close icons, overly bright controls, and widget backgrounds, this is especially noticeable in Preferences).

Of course, someone might consider this too subjective.

Just the dark default background in fusion mode is probably acceptable, and if it doesn't suit someone, it can be tweaked via qt_styles.qss

Quote:
Might be that a few color tweaks here and there would make it go.
I am of the same opinion.
We can simply slim down the current win-dark-style.qss file a bit.

Edit: qt_styles.qss not working?
Attached Thumbnails
Click image for larger version

Name:	sigil-dark-theme-qt6.png
Views:	26
Size:	89.5 KB
ID:	207603   Click image for larger version

Name:	sigil-dark-theme-qt6-preferences.png
Views:	34
Size:	32.4 KB
ID:	207604  

Last edited by BeckyEbook; 04-15-2024 at 12:30 PM.
BeckyEbook is offline   Reply With Quote
Old 04-15-2024, 12:49 PM   #68
DiapDealer
Grand Sorcerer
DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.
 
DiapDealer's Avatar
 
Posts: 27,563
Karma: 193191846
Join Date: Jan 2010
Device: Nexus 7, Kindle Fire HD
Quote:
Originally Posted by BeckyEbook View Post
Edit: qt_styles.qss not working?
Not sure. I really haven't had a chance to explore much. I don't think anything in my patch shouldn't have affected that, but I could be wrong. Setting the fusion style on the command line might change the order of things, compared to where our Sigil SigilDarkStyle did it.

Last edited by DiapDealer; 04-15-2024 at 12:52 PM.
DiapDealer is offline   Reply With Quote
Old 04-15-2024, 12:58 PM   #69
BeckyEbook
Guru
BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.BeckyEbook ought to be getting tired of karma fortunes by now.
 
BeckyEbook's Avatar
 
Posts: 695
Karma: 2180740
Join Date: Jan 2017
Location: Poland
Device: Misc
I played with it for a while.
Overall – our implementation of dark mode a few years ago was done very well aesthetically and I just enjoy working in Sigil every day.

This test build somehow doesn't support qt_styles.qss (your guess about the -style fusion parameter overriding the order in which styles are applied may be true), and it looks like we're going back to a time before the dark mode implementation.

If we are aiming for Windows to use automatic system mode detection and automatic switching then OK, but once dark mode or 'auto' mode (apply system style) is detected it is best to keep our tweaks for dark mode (if possible).
BeckyEbook is offline   Reply With Quote
Old 04-15-2024, 01:12 PM   #70
DiapDealer
Grand Sorcerer
DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.
 
DiapDealer's Avatar
 
Posts: 27,563
Karma: 193191846
Join Date: Jan 2010
Device: Nexus 7, Kindle Fire HD
I like ours a lot better too. I'm just not sure If we can keep it AND do automatic switching at the same time. To even consider letting Qt handle everything, I'd want to make sure overrides via qt_styles.qss can still work. Losing that customization ability just isn't an option in my opinion.

But it's early days. I'm also very accustomed to the look of the current Windows dark mode. I'm not sure I could ever abandon supporting it in some form or another.
DiapDealer is offline   Reply With Quote
Old 04-15-2024, 01:20 PM   #71
KevinH
Sigil Developer
KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.
 
Posts: 7,671
Karma: 5433388
Join Date: Nov 2009
Device: many
The issue with stylesheet may be caused by Sigil/src/Misc/SigilDarkStyle.cpp which does the following:

Code:
void SigilDarkStyle::polish(QApplication *app) {
    if (!app) return;

    // loadstylesheet
    QFile qfDarkstyle(QStringLiteral(":/dark/win-dark-style.qss"));
    if (qfDarkstyle.open(QIODevice::ReadOnly | QIODevice::Text)) {
        // set stylesheet
        QString qsStylesheet = QString::fromLatin1(qfDarkstyle.readAll());
        app->setStyleSheet(qsStylesheet);
        qfDarkstyle.close();
    }
}
Everywhere else we effectively do:

app.setStyleSheet(app.styleSheet().append(NEW_STYL E_INFO))

which prevent overwriting of any earlier stylesheet info at the application level.

We should probably change that to be safe to prevent overwrites of stylesheet contents.
KevinH is online now   Reply With Quote
Old 04-15-2024, 01:36 PM   #72
DiapDealer
Grand Sorcerer
DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.
 
DiapDealer's Avatar
 
Posts: 27,563
Karma: 193191846
Join Date: Jan 2010
Device: Nexus 7, Kindle Fire HD
Noted. That's a good idea. But I'm currently bypassing SigilDarkStyle entirely with my testing patch. So still not sure why our built-in qt_styles.qss (automatically loaded from the user preferences location at Sigil start) is not working after my patch.
DiapDealer is offline   Reply With Quote
Old 04-15-2024, 02:20 PM   #73
DiapDealer
Grand Sorcerer
DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.DiapDealer ought to be getting tired of karma fortunes by now.
 
DiapDealer's Avatar
 
Posts: 27,563
Karma: 193191846
Join Date: Jan 2010
Device: Nexus 7, Kindle Fire HD
Hmmm... when launched without the "-style fusion" command line option, the qt_styles.qss feature is also not working. So either my patch breaks it some way I cannot fathom, or it was broken before I patched.

Last edited by DiapDealer; 04-15-2024 at 02:25 PM.
DiapDealer is offline   Reply With Quote
Old 04-15-2024, 02:25 PM   #74
KevinH
Sigil Developer
KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.
 
Posts: 7,671
Karma: 5433388
Join Date: Nov 2009
Device: many
Not good. Maybe I broke it with my last push.

I will test it on my machine.
KevinH is online now   Reply With Quote
Old 04-15-2024, 02:31 PM   #75
KevinH
Sigil Developer
KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.KevinH ought to be getting tired of karma fortunes by now.
 
Posts: 7,671
Karma: 5433388
Join Date: Nov 2009
Device: many
Okay tested it with a red focus highlight done only via qt)styles.qss and it worked on my Linux Manjaro machine.

So it should work on yours unless an ifdef or endif was changed.
KevinH is online now   Reply With Quote
Reply


Forum Jump

Similar Threads
Thread Thread Starter Forum Replies Last Post
Icon Redesign for future 1.0 Release of Sigil shorshe Sigil 38 06-06-2016 11:29 PM
Kindle Software Preview Release and calibre 'Fetch News' items tomsem Devices 25 07-20-2011 08:02 AM
Will amazon release another cheaper version of DX in the near future CalvinL Amazon Kindle 6 07-31-2010 05:01 PM
Suggestion For Future Release Of Calibre clambert Calibre 5 07-10-2010 01:45 PM
dotReader alpha release next month with future iLiad support possible Alexander Turcic News 7 09-28-2006 12:24 PM


All times are GMT -4. The time now is 10:53 AM.


MobileRead.com is a privately owned, operated and funded community.