13

我正在编写一个旨在在双显示器设置上运行的应用程序,其中一个显示器上的“显示”JFrame 全屏显示,另一台显示器上的“控制”JFrame 向显示器发送指令。我尝试了两种设置全屏显示的不同方法;每个人的成功似乎都取决于操作系统。

display.setUndecorated(true);
display.setExtendedState(JFrame.MAXIMIZED_BOTH);

在 Windows 中工作,但 JFrame 隐藏在 OS X 和 Linux 的扩展坞/面板下。

我的另一种方法,利用

GraphicsDevice.setFullScreenWindow(display);

适用于我尝试过的所有三种操作系统,但在 Windows 中,将控制窗口聚焦在另一台显示器上会使显示窗口隐藏,并调用

display.setAlwaysOnTop(true);

不能解决问题。我有点偏爱这种GraphicsDevice方法,因为我不必处理 OS X 或 Linux 中的问题,我希望 Windows 问题是一个简单的解决方法。是吗?

4

2 回答 2

10

试试这个...

多屏

GraphicsEnvironment ge = GraphicsEnvironment.getLocalGraphicsEnvironment();
GraphicsDevice[] gs = ge.getScreenDevices();


// Get size of each screen

for (int i=0; i<gs.length; i++) {
    DisplayMode dm = gs[i].getDisplayMode();
    int screenWidth = dm.getWidth();
    int screenHeight = dm.getHeight();
}

用于public final void setAlwaysOnTop(boolean alwaysOnTop)将窗口放在顶部,如果窗口是可见的,这包括带上 window toFront,然后将其“粘贴”到最顶部的位置。

于 2012-07-16T06:29:43.117 回答
4

我遇到了同样的问题。我解决它的方法是覆盖show()jframe 中的函数,并使用缓冲区策略永远不会退出 show 函数。因此是这样的:

 @override
 public void show(){
        super.show();
        //Create a double buffering strategy
        createBufferStrategy(2);
        BufferStrategy bs = getBufferStrategy();
        while(true){
              //draw our frame
              Graphics g = bs.getGraphics();
              paint(g);
              //dispose of our graphics
              g.dispose();
              //Show our frame
              bs.show();
              try{
                  //Don't use all our cpu-power
                  Thread.sleep(10);
              }catch(Exception e){
                  //Do something (this probably will never happen)
              }
        }
 }

如果使用setVisible(boolean)而不是show()(show已弃用) 实际上会更好。该窗口不会总是在顶部(您仍然可以在其上拖动另一个窗口),但是当您将焦点放在另一个窗口时它不会自动隐藏。我猜这就是你想要的行为。

注意:不要调用show事件队列,因为这会使事件队列无用,并使 jframe 忽略所有事件。该函数show应在新线程中调用,然后仍将处理所有事件。

于 2012-12-04T23:00:45.133 回答