-
Notifications
You must be signed in to change notification settings - Fork 280
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
Java d3d causes window components redraw #497
Comments
Thanks for the bug report! Unfortunately I cannot replicate this issue on my machine - despite having almost exactly the same setup (same resolution, same OS, only 4070 instead of 1060). So we will have to find out together what's causing it... Some questions to narrow down the possible causes:
Thank you for your effort in helping improve KSE! |
Oh, I forgot: You seem to be using the "Windows" look&feel instead of the default "FlatLaf". For High DPI screens I really recommend one of the "FlatLaf" options, it probably won't help with this issue, but in general they work much better on High DPI. |
Hi.
Yes I'm quite aware it does not happens to everybody, but I've been having
this issue since a long time with java ui and other tools like Project
Libre and Soap-UI which are java based and have the same problem, although
some of these in the past worked well.
Anyways, regarding to your questions:
1. No virtualization at all.
2. Yes, currently SoapUI have same problem. Also run a lot of Jetbrains
IDEs like IntelliJ, PyCharm..., Eclipse, Netbeans but it never happens with
these. Important to notice, when running Keystore Explorer or SoapUI Nvidia
alert shows up, like when playing a game notifying that in-game options are
enabled for use(those for record, stream, etc)
3. It has been a long time since I crashed into this problem, cannot
remember if it was officially a reported bug, but I can try to find a
source...
4. Yes, I did, and yes it does solve the problem.
I really appreciate the time taken to read my report. Best regards!
JQ
El lun, 20 de may de 2024, 1:01 p. m., Kai Kramer ***@***.***>
escribió:
… Thanks for the bug report! Unfortunately I cannot replicate this issue on
my machine - despite having almost exactly the same setup (same resolution,
same OS, only 4070 instead of 1060). So we will have to find out together
what's causing it...
Some questions to narrow down the possible causes:
1. Is this running in a VM (VirtualBox, VMware, Hyper-V, Parallels)?
2. Are you using other Java-based software? If so, does it have the
same issue?
3. From what source did you get the information that this is a known
bug with Java and HighDPI screens? Do you have a link?
4. Did you actually try to set "-Dsun.java2d.d3d=false"? And did it
help?
Thank you for your effort in helping improve KSE!
—
Reply to this email directly, view it on GitHub
<#497 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/ACQT34275QFTDLOAYTCUISTZDI26HAVCNFSM6AAAAABH7YGFD6VHI2DSMVQWIX3LMV43OSLTON2WKQ3PNVWWK3TUHMZDCMRQHEZTMNZVHE>
.
You are receiving this because you authored the thread.Message ID:
***@***.***>
|
Found something interesting, it seems the problem only happens when using windows look&feel, for other themes cannot reproduce it. For sure we can survive without windows theme... :) |
That's very unfortunate... I am a bit reluctant to set "-Dsun.java2d.d3d=false" for all users, because it seems to have negative side effects - at least for some users. I could make it an preference option and set it programmatically, but I am not sure if I can do this early enough during application start to have an effect. Of course there is always the option to start KSE with "java -Dsun.java2d.d3d=false -jar kse.jar", but this is obviously not very user friendly... I wonder what the actual cause is. I am not getting this Nvidia alert that you've mentioned, maybe I should investigate in this direction. I assumed that you are using the Java runtime that is included in kse553-setup.exe, is that correct? |
This is the nvida alert, it popup as soon as I close the tip of the day By other hand, yes i'm using the jre included with the setup file. Maybe, instead of putting sun.java2d.d3d into nim executable, you can set the options into an external file, like most java apps do (vm.options file...) and load then into the nim executable and then launch jvm with those flags, this will allow end users to provide additional flags if needed... |
@lordleebo have you tried newer Java versions (21 or 22)?
Which Java version does SoapUI run in?
JetBrains IDEs ship with there own JREs. |
Yes, that would also be an option. But then you could just set the environment variable "JDK_JAVA_OPTIONS" instead. In both cases you have to know that you can fix the issue like that. If I add it to the preferences, there could be a description stating that it fixes possible UI issues that can happen in combination with Nvidia graphics. Another option would be to add a FAQ section to the KSE website and suggest setting the env variable JDK_JAVA_OPTIONS to "-Dsun.java2d.d3d=false" as a workaround. Also a good question what @DevCharly asked, maybe a newer Java release has already fixed the issue. |
I did try (21) and the problem still there, especially with windows look and feel it happens 100% of the time, with other themes it does happen but not that often
OpenJDK 16.0.2.0
Currently running netbeans with Java 21(Temurin), and I did find in netbeans java options this parameter -Dsun.java2d.noddraw=true, according to old docs (java 8 ) this is the same like -Dsun.java2d.d3d=false. By other hand also tried -Dsun.java2d.opengl=true which turn off Direct3D and the problem went away. It seems that the problem is related to Direct3D, according to this that's the existence reason of the -Dsun.java2d.d3d=false, I'm currently with DirectX 12, not sure about those faulty drivers they mention 20 years ago... I tried this with Netbeans, went to config, removed -Dsun.java2d.noddraw=true and there is the same problem. |
I have the exact same issue - it's very, very annoying and makes this wonderful application practically useless for many use cases. |
There is a workaround described above (setting the env variable My main problem with this issue is that I cannot replicate it. I have been using 4 different Windows Laptops/PCs and 2 Windows VMs with different versions and setups during the last 2 years and have never seen these drawing issues before. So if someone knows more about the cause of this then please comment here. My suspicion is that some setting in the Nvidia software might be responsible for this, because although OP and I have almost exactly the same setup this popup never shows up on my system: |
This is the exe file including sun.java2d.noddraw=true parameter, I used nim to re-compile it, no icon, not fancy, just paste into kse installation dir, you probably may want to backup original exe file. |
removed by my norton antivirus protection. has your account been hacked? besides, I have tried the command provided above by executing java -jar against the jar file, and providing -D... in the command line. unfortunately, that did not fix the problem. |
Setting the environment variable JDK_JAVA_OPTIONS is probably the better way because it works no matter how you start KSE (especially for the original kse.exe this is the only option): This env variable exists since Java 9: For Java 8 there was an undocumented env variable "_JAVA_OPTIONS" that did the same thing. To check if the Java runtime has received the settings, you can use "Help -> System Information -> Button System Properties": |
- with sun.java2d.noddraw=true - can be changed by editing config file - any property possible - could also overwrite some hardcoded settings
- with sun.java2d.noddraw=true - can be changed by editing config file - any property possible - could also overwrite some hardcoded settings
Describe the bug
Under specific screen/hardware conditions UI redraw fails overlapping components making it difficult for user to see properly the information and/or to use software, this is a known bug with java and high dpi screens, commonly solved by passing -Dsun.java2d.d3d=false property to JVM
To Reproduce
Steps to reproduce the behavior:
Expected behavior
To propely show UI
Screenshots
Environment
The text was updated successfully, but these errors were encountered: