-
Notifications
You must be signed in to change notification settings - Fork 866
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Small improvements to the “Show parent folder name in tab title” option #7930
base: master
Are you sure you want to change the base?
Small improvements to the “Show parent folder name in tab title” option #7930
Conversation
I think visually distinguishing file name from path could be useful, but it will be probably tricky to find a color which works on active/inactive tabs for both light and dark themes. (e.g the FlatLaf light screenshot is a bit hard to read for me at least) The test output window reduces the contrast for less important stack frames for example (#6695 has screenshots). This is how it computes the color: netbeans/java/junit.ui/src/org/netbeans/modules/junit/ui/api/JUnitCallstackFrameNode.java Lines 63 to 73 in 7d89336
It does also use the colors from the actual component as input instead of using a hardcoded value. |
btw If you can't access the actual tab component, this might help to figure out what the key is - if it has one: UIManager.getLookAndFeelDefaults().entrySet().stream()
.filter( t -> t.getValue() instanceof Color)
.sorted((o1, o2) -> o1.getKey().toString().compareTo(o2.getKey().toString()))
.forEach(t -> System.out.println(t.getKey()+ ": " + t.getValue())); |
1591db6
to
7136c44
Compare
@mbien thanks for the example. Made the changes and updated the screenshots. |
what you see here is the html renderer noticing that the contrast is too low and trying to fix it to set the color to the complementary white or black. This is the opposite of what the intention is since it is now highlighting the folder instead of the file. As previously mentioned the tricky part is to make it work on different background / foregrounds - its used on different components and component states. I reduced the fade value to 0.7f and computed it for the tabs and tabs-switcher separately, since both have different colors. Tested on all supported themes and it looks ok I think. The "same background color for same projects" mode is still not working very well, esp on dark themes, but making both decorators work well together won't be easy. here the commit c4ea291, feel free to squash it with your PR |
7136c44
to
8fa82e7
Compare
@mbien, thank you so much for your help! |
@troizet not a problem with me. But you can add co-authors to commits by appending this to the commit message:
|
8fa82e7
to
913d29c
Compare
@mbien, thank you! |
@troizet while looking through other code, I noticed NB has a boolean property for dark themes, we can use that for having a different blend value based on dark/light themes: diff --git a/platform/core.multitabs/src/org/netbeans/core/multitabs/impl/FolderNameTabDecorator.java b/platform/core.multitabs/src/org/netbeans/core/multitabs/impl/FolderNameTabDecorator.java
index 421cdc9..f1a64fd 100644
--- a/platform/core.multitabs/src/org/netbeans/core/multitabs/impl/FolderNameTabDecorator.java
+++ b/platform/core.multitabs/src/org/netbeans/core/multitabs/impl/FolderNameTabDecorator.java
@@ -124,10 +124,14 @@
}
private String fadeColor(Color f, Color b) {
- float a = 0.7f;
+ float a = isDarkLaF() ? 0.7f : 0.6f;
return String.format("#%02x%02x%02x", //NOI18N
(int)(b.getRed() + a * (f.getRed() - b.getRed())),
(int)(b.getGreen() + a * (f.getGreen() - b.getGreen())),
(int)(b.getBlue() + a * (f.getBlue() - b.getBlue())));
}
+
+ private static boolean isDarkLaF() {
+ return UIManager.getBoolean("nb.dark.theme"); //NOI18N
+ }
} I could force push into this PR if you want since I have it locally already anyway. |
Yes, please do. Thank you! |
- parent folder name is displayed in opened documents list; - parent folder name is displayed in a different color from the file name. Co-authored-by: Michael Bien <[email protected]>
913d29c
to
2a6a4f0
Compare
I do like this, however, the main reason I am reluctant to approve this is because this might make the "colored tabs" situation worse (#8029). we probably should wait with this until we have an idea how to fix the colored tabs? cc @neilcsmith-net @eirikbakke edit: or we could simply not apply the contrast reduction to the parent folder if colored tabs are enabled? |
You can usually make text blend in with any background color by using transparency (alpha channel) instead of reduced saturation. For example, to make 50% "grey" text, you would use black with 50% transparency on light themes, and white with 50% transparency on dark themes. I.e. use (If that works, we don't have to wait for improvements in the background color before making improvements to the text color.) |
@eirikbakke I don't think the html renderer supports alpha. It seems to ignore the fourth value even if I set it to 0. (the underlying issue is that the contrast is already so low, that blending it will make it hard to read on some components, esp when features like colored tabs come in and swap out the background without adjusting the foreground color - but using alpha would be still nice) |
@mbien Alpha blending might be useful enough to make HtmlRenderer.findColor aware of it. It saves clients from having to query and blend background colors themselves. |
Small improvements to the “Show parent folder name in tab title” option:
Before:
After:
After dark theme: