Для Visual Studio 2012 из панели меню
Символы, которые совершают, перечислены в текстовом поле
Я думаю, что LayeredPane - ваш лучший выбор. Тем не менее, вам понадобится третья панель, которая будет содержать A и B. Эта третья панель будет LayeredPane, а затем панели A и B могут иметь хорошие LayoutManager. Все, что вам нужно сделать, это центрировать B над A, и в трассе Swing есть довольно много примеров того, как это сделать. Учебное пособие по позиционированию без LayoutManager .
public class Main {
private JFrame frame = new JFrame();
private JLayeredPane lpane = new JLayeredPane();
private JPanel panelBlue = new JPanel();
private JPanel panelGreen = new JPanel();
public Main()
{
frame.setPreferredSize(new Dimension(600, 400));
frame.setLayout(new BorderLayout());
frame.add(lpane, BorderLayout.CENTER);
lpane.setBounds(0, 0, 600, 400);
panelBlue.setBackground(Color.BLUE);
panelBlue.setBounds(0, 0, 600, 400);
panelBlue.setOpaque(true);
panelGreen.setBackground(Color.GREEN);
panelGreen.setBounds(200, 100, 100, 100);
panelGreen.setOpaque(true);
lpane.add(panelBlue, new Integer(0), 0);
lpane.add(panelGreen, new Integer(1), 0);
frame.pack();
frame.setVisible(true);
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
new Main();
}
}
Вы используете setBounds для размещения панелей внутри многоуровневой панели, а также для установки их размеров.
Отредактируйте, чтобы отразить изменения в исходном сообщении Вам нужно будет добавить слушателей компонентов, которые обнаруживают, когда размер родительского контейнера изменяется, а затем динамически изменяют границы панелей A и B.
You can add an undecorated JDialog like this:
import java.awt.event.*;
import javax.swing.*;
public class TestSwing {
public static void main(String[] args) throws Exception {
JFrame frame = new JFrame("Parent");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setSize(800, 600);
frame.setVisible(true);
final JDialog dialog = new JDialog(frame, "Child", true);
dialog.setSize(300, 200);
dialog.setLocationRelativeTo(frame);
JButton button = new JButton("Button");
button.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
dialog.dispose();
}
});
dialog.add(button);
dialog.setUndecorated(true);
dialog.setVisible(true);
}
}
JOptionPane.showInternalInputDialog, вероятно, делает то, что вы хотите. Если нет, было бы полезно понять, чего не хватает.
Я просто подумал, что добавлю, что есть понятие Z-порядка в Swing, см. [java.awt.Component # setComponentZOrder] [1]
, который влияет на позиции компонента в массиве его родительских компонентов, который определяет порядок рисования.
Обратите внимание, что вы должны переопределить javax.swing.JComponent #isOptimizedDrawingEnabled , чтобы вернуть false в родительском контейнере, чтобы ваши перекрывающиеся компоненты перерисовывались правильно, в противном случае их перерисовки будут затирать друг друга. (JComponents не предполагают перекрывающихся дочерних элементов, если isOptimizedDrawingEnabled не возвращает false)
[1]: http://java.sun.com/j2se/1.5.0/docs/api/java/awt/Container.html#setComponentZOrder (java. awt.Component , int)
Используйте GridLayout 1 на 1 на существующей панели JPanel, а затем добавьте панель в эту панель JPanel. Единственная проблема с GridLayout 1 на 1 заключается в том, что вы не сможете размещать другие элементы в JPanel. В этом случае вам придется подобрать подходящий макет. Каждая панель, которую вы используете, может использовать свой собственный макет, чтобы не было проблем.
Правильно ли я понял этот вопрос?