使用Borderlayout格式化3个JPanel

时间:2013-11-08 19:15:31

标签: java swing jpanel border-layout

enter image description here

大家好,

上图是我的框架截图,目前看起来如何。我希望第一个标签PlatformTest1在红色条纹后启动。为了清晰起见,我为自己画了红色条纹。 我使用了一个带有3个Janel的Borderlayout,一个位于West,North和Center。我用两个列表中的标签填充了North和West Panels。在Center-Panel中,我想要一个大小为list1.size()* list2.size()的网格。但我只是没有在红色条纹所在的位置添加第一个标签。我尝试添加一个空白标签,但这看起来不太好。

到目前为止,这是我的代码:

public DisplayMapping() {

    final int x = list1.size();
    final int y = list2.size();

    setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    setBounds(100, 100,600, 500);
    contentPane = new JPanel();
    contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
    setContentPane(contentPane);
    contentPane.setLayout(new BorderLayout(0, 0));

    JPanel panelApps = new JPanel();
    panelApps.setBorder(new LineBorder(new Color(0, 0, 0), 2));
    contentPane.add(panelApps, BorderLayout.WEST);
    panelApps.setLayout(new GridLayout(y, 1));


    JPanel panelHW = new JPanel();
    panelHW.setBorder(new LineBorder(new Color(0, 0, 0), 2));
    contentPane.add(panelHW, BorderLayout.NORTH);
    panelHW.setLayout(new GridLayout(1,x));

    JPanel panelGrid = new JPanel();
    contentPane.add(panelGrid, BorderLayout.CENTER);
    panelGrid.setLayout(new GridLayout(1, 0, 0, 0));

    for(String s : list1)
    {
        JLabel lbl = new JLabel();
        lbl.setText(s);
        panelApps.add(lbl);
        panelApps.revalidate();
        panelApps.repaint();
        contentPane.revalidate();
        contentPane.repaint();
    }

    for(String s : XMLParser.HardwareListGUI)
    {
        JLabel lbl = new JLabel();
        lbl.setText(s);
        panelHW.add(lbl);
        panelHW.revalidate();
        panelHW.repaint();
        contentPane.revalidate();
        contentPane.repaint();
    }

我还尝试在x方向上设置PanelApps的Bounds,但是也没有成功。我希望有人可以帮助它。

提前致谢。

1 个答案:

答案 0 :(得分:3)

您可以做的是将当前的North面板和当前的Center面板放在Center中的面板中。所以你会有这样的事情:

 _____________________________________________________
|             | Center Panel (also BorderLayout)      |
|panelApps    |  ___________________________________  |
|             | | panelHW                           | |
|             | |___________________________________| |
|             | | panelGrid                         | |

这样,您的应用程序面板将显示在内容窗格的顶部,您的硬件面板也将显示在顶部,但将位于应用程序面板旁边。

由于面板将延伸到“中心面板”的边缘,因此我在硬件和网格面板周围放置的中心面板的“边框”实际上不会显示。我刚才这样绘制它来显示面板的“层次结构”。