当前位置: 首页 > 编程笔记 >

Java如何实现可折叠Panel方法示例

东门深
2023-03-14
本文向大家介绍Java如何实现可折叠Panel方法示例,包括了Java如何实现可折叠Panel方法示例的使用技巧和注意事项,需要的朋友参考一下

1.原理

原理非常简单:就是一个JLabel和JPanel。Jlabel显示标题文字以及标明控件当前是处于展开还是折叠状态的图片;而JPanel主要就一个作用——承载控件的容器。JLabel通过响应鼠标事件来控制JPanel是否显示。这样就可以达到折叠或展开的效果。

下面话不多说了,来一起看看详细的示例代码

2.代码

public class JShrinkablePanel extends JPanel {
private JLabellabel;
private Stringtitle ="";
private JPanelcontentPanel =null;
private boolean isExpanded =true;
private JListlist =new JList();
private IconiconExpand =null;
private IconiconCollapse =null;
public JShrinkablePanel(String title, JPanel contentPanel) {
super();
this.title = title;
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.title);
}

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) {
JFrame jf =new JFrame("JShrinkablePanel");
jf.setBounds(400,200,400,300);
jf.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
JPanel panel=new JPanel();
panel.add(new JButton("Just for show"));
panel.setBorder(BorderFactory.createTitledBorder("Border"));
JShrinkablePanel scrollPane=new JShrinkablePanel("TestJShrinkablePanel",panel);
jf.add(scrollPane);
jf.setVisible(true);
}
}

3.效果

panel展开鼠标在标题Label上

panel展开鼠标没在标题Label上

panel折叠鼠标在标题Label上

panel折叠鼠标没在标题Label上

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。

 类似资料:
  • 本文向大家介绍AngularJS折叠菜单实现方法示例,包括了AngularJS折叠菜单实现方法示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了AngularJS折叠菜单实现方法。分享给大家供大家参考,具体如下: 更多关于AngularJS相关内容感兴趣的读者可查看本站专题:《AngularJS指令操作技巧总结》、《AngularJS入门与进阶教程》及《AngularJS MVC架构总结

  • 本文向大家介绍jQuery实现表格展开与折叠的方法,包括了jQuery实现表格展开与折叠的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery实现表格展开与折叠的方法。分享给大家供大家参考。具体分析如下: 这是很人性化的一款特效代码,实现点击其中一个父级,另一个之前打开的父级会自动关闭 希望本文所述对大家的jQuery程序设计有所帮助。

  • 使用本教程实现灵活的空间模式(具有折叠工具栏的模式)。 我正在尝试实现与Lollipop联系人活动类似的效果,在开始进入活动时,视图只是图像标题的一部分: 然后,用户可以向下滚动图像下方的布局,以显示更多内容,直到达到最大值: 在我的应用程序中,我无法让它工作。 发生的情况是,在进入活动时,图像标题以它的最大大小(AppBarLayout 的大小)显示,就像上面的布局一样,并且与 Lollipop

  • 本文向大家介绍js实现简单折叠、展开菜单的方法,包括了js实现简单折叠、展开菜单的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js实现简单折叠、展开菜单的方法。分享给大家供大家参考。具体如下: 这里介绍的是意乱会折叠、展开的菜单导航栏,很老时候写的,CSS没有做美化,如果想用的朋友就自己美化吧。 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js

  • 本文向大家介绍jquery mobile实现可折叠的导航按钮,包括了jquery mobile实现可折叠的导航按钮的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了jquery实现可折叠的导航按钮的具体代码,供大家参考,具体内容如下 功能: 当功能较多时,创建可折叠分组导航按钮。只需指定 data-role=" collapsible "创建可折叠面板   代码分析:        

  • 问题内容: 自从我更新了intelliJ的版本(从14.x到15.x)后,它开始自动在编辑器中折叠单行方法: 先前版本: 最新版本: 有办法防止这种情况吗?我发现原始版本容易上手! 谢谢。 问题答案: 从“文件”菜单中打开“设置”。在“编辑器”->“常规”->“代码折叠”下,您会找到“默认折叠”部分。 只需取消选中“单行方法”,然后单击“确定”。