- 
    Bug 
- 
    Resolution: Fixed
- 
     P3 P3
- 
    1.4.0
- 
        b27
- 
        generic, x86
- 
        generic, linux_redhat_9.0
- 
        Verified
On Windows with virtual screen, the window is getting placed at the center of the primary display.
On Linux with xinerama (virtual screen), the window is getting placed at the center of the virtual screen. The specification does not say anything about how this would work on a virtual screen setup.
This behavioral difference is due to the code given below:
setLocation((screenSize.width - paneSize.width) / 2,
(screenSize.height - paneSize.height) / 2);
Here the screen size is obtained by calling Toolkit.getScreenSize(). This method behaves differently on win32 and xinerama. on Win32, it returns the size of the prim display but on xinerama it returns the size of the virtual screen. Hence the window also gets centered accordingly. (A bug is filed against this method: 5100801 which is evaluated as a doc bug)
What i am expecting here is to have a uniform approach across all virtual screen setups, be it xinerama or win32.
1. If the intention is to place with window at the center of the virtual screen, it must be done for both the cases - win32 as well as xinerama.
2. Alternatively setLocationRelativeTo() can use Window centering APIs (GraphicsEnv.getCenterPoint()) to center the window within the primary display. This method works consistently across all setups.
3. Another option is, the 2 cases such as component being null and component being invisible can be handled differently. When the component is null, it can use option-2. If the component is invisible, GraphicsConfig can be obtained from the invisible component and the window can be centered within the monitor where the invisible component is located.
The specification must be enhanced to clarify this for a multi-monitor scenario (virtual screen as well as independent screens).
I have attached a sample test which shows a message dialog using JOptionPane. It covers both the cases where the component is null and the component is invisible. Run it on a win32 - virtual screen setup as well as on a linux-xinerama setup. If the window is placed at the center of the virtual screen on xinerama, the bug is reproduced.
###@###.### 10/12/04 06:45 GMT
- duplicates
- 
                    JDK-4487771 Window.setLocationRelativeTo() doesn't center Windows correctly -           
- Closed
 
-         
- relates to
- 
                    JDK-6211719 Window.setLocationRelativeTo() does not work properly for multi-monitor virtual screen configs -           
- Closed
 
-         
- 
                    JDK-5096679 PIT:PrintDialog is not positioned properly on multi-mon, when coords are invalid -           
- Closed
 
-         
- 
                    JDK-5100801 Toolkit.getScreenSize() does not return the correct dimension on multimon, linux -           
- Closed
 
-         
- 
                    JDK-6431730 Window.setRelativeTo Snaps to Wrong Top/Left Window Bound -           
- Closed
 
-         
- 
                    JDK-6232687 Window.SetLocationRelativeTo: treat the given null and invisible component separately -           
- Closed
 
-