1.原理
原理非常简单:就是一个JLabel和JPanel。Jlabel显示标题文字以及标明控件当前是处于展开还是折叠状态的图片;而JPanel主要就一个作用——承载控件的容器。JLabel通过响应鼠标事件来控制JPanel是否显示。这样就可以达到折叠或展开的效果。
下面话不多说了,来一起看看详细的示例代码
2.代码
public class JShrinkablePanel extends JPanel {
private JLabellabel;
private String ="";
private JPanelcontentPanel =null;
private boolean isExpanded =true;
private JListlist =new JList();
private IconiconExpand =null;
private IconiconCollapse =null;
public JShrinkablePanel(String , JPanel contentPanel) {
super();
this. = ;
this.contentPanel = contentPanel;
initComponents();
initComponentsStatus();
initLayout();
initResources();
unRegisterEvents();
registerEvents();
}
private void initComponents() {
this.label =new JLabel();
}
private void initComponentsStatus() {
this.label.setHorizontalAlignment(JLabel.LEFT);
this.label.setVerticalAlignment(JLabel.CENTER);
this.label.setVerticalTextPosition(JLabel.CENTER);
this.label.setBackground(this.list.getSelectionBackground());
this.iconExpand =new ImageIcon("src/Resources/Expand.png");
this.iconCollapse =new ImageIcon("src/Resources/Collapse.png");
}
private void initLayout() {
this.setLayout(new GridBagLayout());
this.add(this.label,new GridBagConstraints(0,0,1,1,1,0, GridBagConstraints.WEST, GridBagConstraints.HORIZONTAL,new Insets(0,0,0,0),0,0));
this.add(this.contentPanel,new GridBagConstraints(0,1,1,1,1,0, GridBagConstraints.WEST, GridBagConstraints.HORIZONTAL,new Insets(0,0,0,0),0,0));
}
private void initResources() {
this.label.setIcon(this.iconExpand);
this.label.setText(this. );
}
private void unRegisterEvents() {
this.label.removeMouseListener(this.mouseListener);
}
private void registerEvents() {
this.label.addMouseListener(this.mouseListener);
}
private MouseListenermouseListener =new MouseAdapter() {
@Override
public void mouseClicked(MouseEvent e) {
isExpanded = !isExpanded;
panelVisible();
}
@Override
public void mouseEntered(MouseEvent e) {
label.setOpaque(true);
label.repaint();
}
@Override
public void mouseExited(MouseEvent e) {
label.setOpaque(false);
label.repaint();
}
};
private void panelVisible() {
this.contentPanel.setVisible(this.isExpanded);
this.label.setIcon(this.isExpanded ?this.iconExpand :this.iconCollapse);
}
public static void main(String[] args) {
J jf =new J ("JShrinkablePanel");
jf.setBounds(400,200,400,300);
jf.setDefaultCloseOperation(J .EXIT_ON_CLOSE);
JPanel panel=new JPanel();
panel.add(new JButton("Just for show"));
panel.setBorder(BorderFactory.create dBorder("Border"));
JShrinkablePanel scrollPane=new JShrinkablePanel("TestJShrinkablePanel",panel);
jf.add(scrollPane);
jf.setVisible(true);
}
}
3.效果

panel展开鼠标在标题Label上

panel展开鼠标没在标题Label上

panel折叠鼠标在标题Label上

panel折叠鼠标没在标题Label上
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
继续阅读与本文标签相同的文章
上一篇 :
腾讯的IP能如何帮助成都塑造城市品牌?
下一篇 :
美国顶尖 AI+教育公司,都在研究些什么?
-
云服务器可以租用吗,价位大概定在多少
2026-05-15栏目: 教程
-
体验未来视界 VR电影酷炫来袭——2019南昌未来影像艺术周暨南昌国际VR电影展开幕侧记
2026-05-15栏目: 教程
-
玩转office只需要这一招!
2026-05-15栏目: 教程
-
1亿人都在用的电商爆发危机
2026-05-15栏目: 教程
-
上海首个保税展示展销场所亮相
2026-05-15栏目: 教程
