我一直在研究有关JInternalFrames的各种问题,并尝试按照建议的方式实现代码,但是我似乎做错了什么。我在此处包含的代码将演示我的问题。创建了三个框架,但是当您单击并移动它们时,它们将不会像预期的那样到达顶部,并且通常看起来像是某种Escher印刷品。
public class IntFrmTest extends JFrame {
private JPanel contentPane;
private JDesktopPane desktop;
private int formHeight=675;
private int formWidth=950;
public IntFrmTest() {
this.setTitle("Desktop");
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setBounds(10, 10, formWidth, formHeight);
this.setMinimumSize(new Dimension(640,480));
this.setResizable(true);
desktop = new JDesktopPane();
contentPane = new JPanel();
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
contentPane.setLayout(null);
setContentPane(contentPane);
this.add(BorderLayout.CENTER, desktop);
this.setVisible(true);
this.setLocationRelativeTo(null);
frmTesting frmTest1=new frmTesting(1);
frmTest1.setVisible(true);
contentPane.add(frmTest1);
frmTest1.setLocation(10,10);
frmTest1.addFocusListener(focusListener);
frmTesting frmTest2=new frmTesting(2);
frmTest2.setVisible(true);
contentPane.add(frmTest2);
frmTest2.setLocation(40,40);
frmTest2.addFocusListener(focusListener);
frmTesting frmTest3=new frmTesting(3);
frmTest3.setVisible(true);
contentPane.add(frmTest3);
frmTest3.setLocation(80,80);
frmTest3.addFocusListener(focusListener);
}
FocusListener focusListener=(new FocusListener(){
@Override
public void focusGained(FocusEvent arg0) {
JInternalFrame f = (JInternalFrame) arg0.getSource();
try {
f.setSelected(true);
f.moveToFront();
} catch (PropertyVetoException e) {
e.printStackTrace();
}
System.out.println("Got Focus "+f.getName());
}
@Override
public void focusLost(FocusEvent arg0) {
JInternalFrame f = (JInternalFrame) arg0.getSource();
try {
f.moveToBack();
f.setSelected(false);
} catch (PropertyVetoException e) {
e.printStackTrace();
}
System.out.println("Lost Focus "+f.getName());
}
});
public class frmTesting extends JInternalFrame {
private int formHeight=375;
private int formWidth=450;
public frmTesting(int frameNo) {
this.setTitle("Internal Frame "+frameNo);
this.setName("frmTest"+frameNo);
this.setClosable(true);
this.setResizable(false);
this.setMaximizable(false);
this.setIconifiable(false);
this.setFocusable(true);
this.setSize(formWidth,formHeight);
JPanel pnlDisplay = new JPanel();
this.setContentPane(pnlDisplay);
pnlDisplay.setLayout(null);
this.setVisible(true);
}
}
public static void main(String[] args) {
IntFrmTest ift=new IntFrmTest();
}
}
我希望窗口在被选择时只会位于最前面,但这在大多数情况下不会发生。单击它们时,它们可能不会显示为选中状态,并且通常不会显示在顶部。
这是一个看起来像的例子: Visually Incorrect Example
任何帮助我解释自己做错事的人将不胜感激。
答案 0 :(得分:0)
和往常一样,我整天试图找出问题并寻求帮助后找到答案...
也许有人可以填写更多详细信息,但是我一直在使用桌面/内容窗格组合创建单个表单,并且按预期工作。我对JInternalFrames的文档没有怀疑的是,它看起来好像JInternalFrame驻留在桌面上,主窗口上没有contentpane。
当我将内部框架放到桌面/内容窗格上时,选择时不允许内部框架出现在顶部。这使我相信我需要手动控制内部框架,因此使用了FocusListener。
从混合中删除contentpane可以解决此问题,并且一切都会按预期进行,这是一种缓解,因为我不明白为什么需要手动完成。更正后的代码如下。
public class IntFrmTest extends JFrame {
private JPanel contentPane;
private JDesktopPane desktop;
private int formHeight=675;
private int formWidth=950;
public IntFrmTest() {
this.setTitle("Desktop");
this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
this.setBounds(10, 10, formWidth, formHeight);
this.setMinimumSize(new Dimension(640,480));
this.setResizable(true);
desktop = new JDesktopPane();
setContentPane(desktop);
this.setVisible(true);
this.setLocationRelativeTo(null);
frmTesting frmTest1=new frmTesting(1);
frmTest1.setVisible(true);
desktop.add(frmTest1);
frmTest1.setVisible(true);
frmTesting frmTest2=new frmTesting(2);
frmTest2.setVisible(true);
desktop.add(frmTest2);
frmTesting frmTest3=new frmTesting(3);
frmTest3.setVisible(true);
desktop.add(frmTest3);
}
public class frmTesting extends JInternalFrame {
private int formHeight=375;
private int formWidth=450;
public frmTesting(int frameNo) {
super("Internal Frame "+frameNo,false,true,false,false);
this.setName("frmTest"+frameNo);
this.setSize(formWidth,formHeight);
JPanel pnlDisplay = new JPanel();
this.setContentPane(pnlDisplay);
pnlDisplay.setLayout(null);
this.setLocation(30*frameNo,30*frameNo);
this.setVisible(true);
}
}
public static void main(String[] args) {
IntFrmTest ift=new IntFrmTest();
}
}
当我开始研究rootpane时,偶然发现了答案。