Java Swing中JPanel面板宽度/高度或图像自适应JScrollPane滚动窗格

最近在开发一个小应用程序的过程中,遇到了这个问题。在网上找了个遍只发现一个帖,还是没有解决方法的(郁闷啊~~~)。于是靠着网上的一条线索自己摸索,得到了下面的解决方法(有时运行会报错)。如果你有更好的方法,望不吝指教~

问题描述:

在JScrollPane中添加JPanel。在窗体缩小尺寸改变后,JScrollPane出现滚动条(由于JScrollPane自身的特性,其内部的组件并没有随JScrollPane缩小而缩小)。
P.S…若只想出现一条滚动条,可以设置
HorizontalScrollBarPolicy为javax.swing.ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER
或设置
VerticalScrollBarPolicy为javax.swing.ScrollPaneConstants.VERTICAL_SCROLLBAR_NEVER。

思路:

默认状态下,改变窗体大小后各组件会根据不同的布局管理器自动完成布局,而组件中的一个属性对其起到至关重要的作用——PreferredSize(即:setPreferredSize(null))。只需在窗体改变时,通过设置相关动作事件对指定组件进行setPreferredSize操作即可实现自适应。

操作(以自适应宽度为例):

1. 为JScrollPane添加componentResized事件

private javax.swing.JScrollPane jsp = new javax.swing.JScrollPane();
private javax.swing.JPanel panel = new javax.swing.JPanel();
private float dval;    // panel未改变尺寸时的原始长宽比例

jsp.setHorizontalScrollBarPolicy(javax.swing.ScrollPaneConstants.HORIZONTAL_SCROLLBAR_NEVER);
jsp.setViewportView(panel);
jsp.addComponentListener(new java.awt.event.ComponentAdapter() {
    public void componentResized(java.awt.event.ComponentEvent evt) {
        Dimension dim = new Dimension(jsp.getSize().width
		    -jsp.getVerticalScrollBar().getWidth(),    // 尺寸改变后可能会出现垂直滚动条,需减去其宽度
		    (int)(jsp.getSize().width*dval));
		panel.setPreferredSize(dim);     // 不设置该属性,程序会自动计算并设置
		panel.updateUI();
    }
});

至此JPanel面板实现自适应JScrollPane滚动窗格功能。
但是,如果JPanel中的组件含有图像,可能会出现图像大小无法跟随容器尺寸变化而变化的情况,这时需添加2的操作。

2.为JPanel添加componentResized事件

下面操作基于步骤1

private JButton bt = new JButton("按钮", new ImageIcon("./bt.png"));
panel.add(bt);
panel.addComponentListener(new java.awt.event.ComponentAdapter() {
    public void componentResized(java.awt.event.ComponentEvent evt) {
        // 建议用同步线程,防止尺寸改变时出现同步问题和界面卡顿
        new Thread(new Runnable() {
            @Override
            public void run() {
                resizeButtonIcon();
            }
            private synchronized void resizeButtonIcon(){
	            // 根据按钮实际尺寸重置按钮图标大小
				bt.setIcon(new ImageIcon(new ImageIcon("./bt.png").getImage().getScaledInstance(    // 若通过获取按钮图标进行重设置,会导致图标显示效果不佳
                    (int)(bt.getWidth()*0.85), (int)(bt.getHeight()*0.65), Image.SCALE_DEFAULT)));
                });
                panel.updateUI();
            }
        }).start();
    }
});

效果图
修改前(放大再缩小后无法正常显示右边图像,需拉伸窗体才能完整显示,且显示效果过大):
这里写图片描述

修改后(各图像按照缩放比例重置尺寸,实现自适应):
这里写图片描述

  • 7
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值