Summary: | Regression: Search & Replace background colors hardly visible | ||
---|---|---|---|
Product: | [Applications] kate | Reporter: | Pascal d'Hermilly <pascal> |
Component: | general | Assignee: | KWrite Developers <kwrite-bugs-null> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | cfeck, mwoehlke.floss |
Priority: | NOR | ||
Version: | 3.8.90 | ||
Target Milestone: | --- | ||
Platform: | Ubuntu | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Pascal d'Hermilly
2012-07-19 10:20:47 UTC
Might it be that the highlight is there, but it's very light? You can change the colors in the config dialog. Please check. Indeed. It quite goes against the word highlight eh? :-) I can fix it for me, but we should consider a better default highlight color.. Unfortunately, I don't know how to get a better default highlight color. Currently, I use the color from system settings of the Color Set "View", the background of the "Neutral Text". It is very decent, and on my screen it's visible. Having a color with more contrast would be nice. Is there a better way to calculate the color? The same applies to the replace color. The problem is that there is no real highlight background in the color scheme. Perhaps choosing a contrasty yellow and green that you like is better? You can use KColorScheme to get a suitable background color for the "view". Pick one you like most from System Settings, but I would suggest to use "Positive". I use Positive for replaced text. So for me, the bug report boils down to how to get a better contrast to the background color. Maybe KColorUtils help here, although I don't see how right now: http://api.kde.org/4.8-api/kdelibs-apidocs/kdeui/html/namespaceKColorUtils.html There is KColor::contrastRatio, but this alone won't help. Assuming a: you aren't dealing with some funky syntax-based background colors, and b: your system color scheme is reasonable, then View->{Positive,Neutral} Background (*not* Text) should be adequate colors. Text flavors thereof are going to tend to be illegible, at least on light-on-dark schemes (and are also an a11y violation). For some syntax parts, they'll be the /same/ color as the text. If those don't work, I'd be inclined to consider it a bug in the color scheme system and That said, on my system (KDE 4.8.4, katepart 3.7), katepart seems to be using Qt::yellow and Qt::green? (My positive/neutral colors are indeed shades of yellow and green, but they're clearly distinct from "pure" yellow/green, and the colors I'm actually seeing are definitely not from my color scheme. Also, the replaced text background gives a distinctly illegible result.) So what's the correct solution? Use KColorUtils::contrastRatio, and check whether the ration gets better with lighter or darker and then use this color if we get a ration above a certain threshold? Well... colors are tricky :-). I'd say that's probably the best thing to do, yes. If there's a reasonable way to cache it (and/or if it could be added to the color options in a way that makes sense - the hard part there being that, for Oxygen at least, I notice it needs to be different depending on the role), I'd prefer for KColorScheme to do this when generating the background colors, to ensure a reasonable contrast. Anyway, if you do it in katepart, I'd suggest using KCU::tint (as opposed KCU::mix), which is how the background colors already get generated. And possibly cap the tint amount to 0.7-ish to avoid the problems from using a foreground color as a background color. I've also created bug 303825, which possibly supersedes this. For me, "Text positive" and "Text neutral" doesn't have anything to do searched and replaced text. They would be hints for how to use colors to let user interpret text better. I think if we are going to be using colors different from the color scheme anyway then we might as well just use the effective yellow and green. The color scheme names are meant to be recommendations, i.e. you should choose the one that makes the most sense. In some cases (e.g. coloring the URL line edit for website SSL verification), there is a good correspondence. Other times (e.g. katepart) there is not, but you should still prefer to use the scheme and make the best choice you can. I would argue using Positive for replaced text makes sense... a successful replacement is a reasonable interpretation of "positive". Using neutral for found text is more of a gray area; I could argue for it being a "pending replacement", but I could also argue for using Active instead. However, I would say that is less important than actually using the scheme. Please DO NOT revert to using Qt::yellow and Qt::green; these are illegible with my color scheme (probably most light-on-dark schemes) and that they are non-configurable is an a11y violation. Using the system color scheme is The Right Thing To Do; it's a bug that the system scheme colors are inadequate. Git commit cbbccc36740c31a1e9aecc8cc69cc2889c4fa9ed by Dominik Haumann. Committed on 25/07/2012 at 18:16. Pushed by dhaumann into branch 'KDE/4.9'. last minute fix for KDE 4.9: hard code search&replace colors workaround, until we have a better solution M +2 -2 part/schema/kateschemaconfig.cpp M +2 -2 part/utils/kateconfig.cpp http://commits.kde.org/kate/cbbccc36740c31a1e9aecc8cc69cc2889c4fa9ed Git commit 2356a11a7f4d78f61185d89f25c120af6f90ce1e by Dominik Haumann. Committed on 25/07/2012 at 18:16. Pushed by dhaumann into branch 'master'. last minute fix for KDE 4.9: hard code search&replace colors workaround, until we have a better solution M +2 -2 part/schema/kateschemaconfig.cpp M +2 -2 part/utils/kateconfig.cpp http://commits.kde.org/kate/2356a11a7f4d78f61185d89f25c120af6f90ce1e |