本例展示了, 左边为标签、右边为文本框的三组,当窗口变化时,其中的文本框跟着变化。
变化前:
变化后:
import java.awt.Container;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JTextField;
import javax.swing.Spring;
import javax.swing.SpringLayout;
/**
* 演示SpringLayout布局管理器的使用。例子,演示有三组由左为表签、右为文本框)的组件<br/>
* 将随着窗口宽度变化 而相应变化。
* 特别说明:当用putConstraint函数设定组件,且对宽与高都不要求随窗口变化时,则会<br/>
* 遇着一些问题。怀疑是Bug。如果要让宽或高 要随窗口变化而变化时,最好用用容器的<br/>
* add方法.把组件及对该组件的"Spring.constraint"约束添加进去。<br/>
* 其约束的设定,是从与相邻组件的四个方向进行设置。另外如果水平有两个及两个以的组件<br>
* 的宽度都要随父容器变化而时,每个文本框的右边约束建议按父容器的宽度的百分比进行设定。
*
* @author cloud
*/
public class SpringDemo1 {
public static void main(String args[]) {
JFrame frame = new JFrame("SpringLayout");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
Container contentPane = frame.getContentPane();
SpringLayout layout = new SpringLayout();
contentPane.setLayout(layout);
JLabel lbl3 = new JLabel("Left3");
JTextField txt3 = new JTextField("text3");
JLabel lbl4 = new JLabel("Left4");
JTextField txt4 = new JTextField("text4");
JLabel lbl5 = new JLabel("Left5");
JTextField txt5 = new JTextField("text5");
contentPane.add(lbl3);
contentPane.add(lbl4);
contentPane.add(lbl5);
contentPane.add(txt3);
contentPane.add(txt4);
contentPane.add(txt5);
//得到父容器当前最右边(东方)的宽度,并除以2. 目的让两组各占一半窗口宽度。
Spring rightC=layout.getConstraint (SpringLayout.EAST, contentPane);
Spring rightC1=Spring.scale(rightC, 0.3f);
Spring rightC2=Spring.scale(rightC, 0.6f);
// 让lbl3标签上边与父容器的上边相距20。即第一个标签 上边距为20
layout.putConstraint(SpringLayout.NORTH, lbl3, 20,
SpringLayout.NORTH, contentPane);
//让lbl3标签的左边与父容器的左边相距10。即第一个标签左边间隔为10
layout.putConstraint(SpringLayout.WEST, lbl3, 10,
SpringLayout.WEST, contentPane);
//获得一个约束对象,以便对组件的四个方向的间隔进行设置。这个约束设定后好
//将由父容器的add方法,把该约束与要束的组件一起添加进去,从而完成组件间隔设置
SpringLayout.Constraints constraint = new SpringLayout.Constraints();
//设定约束上边间距为20
constraint.setConstraint(SpringLayout.NORTH, Spring.constant(20));
//得lbl3标签右边的约束,并增加间隔10
Spring pad=Spring.sum(
layout.getConstraint(SpringLayout.EAST, lbl3),
Spring.constant(10)
);
//设左边的约束为lbl3约束,并间隔10.即设与lbl3标签的水平间隔为10
constraint.setConstraint(SpringLayout.WEST, pad);
//设右边的约束为30%。
constraint.setConstraint(SpringLayout.EAST, rightC1);
//把txt3按前面设好的约束,添加到父容器中。
contentPane.add(txt3, constraint);
//让lbl4标签上边与父容器的上边相距20。即第二个标签 上边距为20
layout.putConstraint(SpringLayout.NORTH, lbl4, 20,
SpringLayout.NORTH, contentPane);
//让lbl4标签左边与txt3的左边相距20。即第一个标签左边与第一组间隔30
layout.putConstraint(SpringLayout.WEST, lbl4, 30,
SpringLayout.EAST, txt3);
//获得一个约束对象,以便对组件的四个方向的间隔进行设置。这个约束设定后好
//将由父容器的add方法,把该约束与要束的组件一起添加进去,从而完成组件间隔设置
constraint = new SpringLayout.Constraints();
//设定约束上边间距为20
constraint.setConstraint(SpringLayout.NORTH, Spring.constant(20));
//得lbl4标签右边的约束,并增加间隔10
pad=Spring.sum(
layout.getConstraint(SpringLayout.EAST, lbl4),
Spring.constant(10)
);
//设左边的约束为lbl4约束,并间隔10.即设与lbl4标签的水平间隔为10
constraint.setConstraint(SpringLayout.WEST, pad);
//设右边的约束为父容器右边的60%,并增加10.
constraint.setConstraint(SpringLayout.EAST,
Spring.sum( rightC2,Spring.constant(10))
);
//把txt4按前面设好的约束,添加到父容器中。
contentPane.add(txt4, constraint);
//设lbl5的上边距为20
layout.putConstraint(SpringLayout.NORTH, lbl5, 20,
SpringLayout.NORTH, contentPane);
//设lbl5的左边与txt4的右边相隔30,即lbl5与txt4的水平间隔为30
layout.putConstraint(SpringLayout.WEST, lbl5, 30,
SpringLayout.EAST, txt4);
//获得一个约束对象,以便对组件的四个方向的间隔进行设置。这个约束设定后好
//将由父容器的add方法,把该约束与要束的组件一起添加进去,从而完成组件间隔设置
constraint = new SpringLayout.Constraints();
//设定约束上边间距为20
constraint.setConstraint(SpringLayout.NORTH, Spring.constant(20));
//得lbl5标签右边的约束,并增加间隔10
pad=Spring.sum(
layout.getConstraint(SpringLayout.EAST, lbl5),
Spring.constant(10)
);
//设左边的约束为lbl5约束,并间隔10.即设与lbl5标签的水平间隔为10
constraint.setConstraint(SpringLayout.WEST, pad);
//设右边的约束为容器的右边约束并减去20,即设成与父容器右边间隔为20.
constraint.setConstraint(SpringLayout.EAST,
Spring.sum(rightC, Spring.constant(-10))
);
//把txt5按前面设好的约束,添加到父容器中。
contentPane.add(txt5, constraint);
frame.setSize(300,100);
frame.setVisible(true);
}
}

- 大小: 8.1 KB

- 大小: 13.8 KB
分享到:
相关推荐
Java Swing SpringLayout 弹性布局的实现代码 Java Swing 是一个功能强大的 GUI 库,提供了多种布局管理器来组织组件的排列方式。其中,SpringLayout 是一种特殊的布局管理器,允许开发者以灵活的方式组织组件的...
1.1: FlowLayo1.1: FlowLayo1.1: FlowLayo1.1: FlowLayo1.1: FlowLayo 1.1: FlowLayo 1.1: FlowLayout (流式布局) (流式布局) (流式布局) (流式布局) ................................ ......................
- **SpringLayout**:弹簧布局,利用弹性模型自动调整组件的位置和大小。 ### 9. 设置标签控件字体大小 - **Font属性**:在编程中,设置标签控件字体大小通常需要设置其`Font`属性,而不是`Height`、`Width`或`...
计算机发展与计算机应用概述.pdf
计算机二级公共基础知识全集合.pdf
计算机机试答案.pdf
内容概要:本文详细介绍了基于STM32F103RCT6的750W全桥逆变器设计方案,涵盖硬件电路设计、软件编程以及保护机制等方面。硬件部分包括主控芯片的选择、PWM配置、Boost升压电路、PCB布局优化等;软件部分涉及并离网切换的状态机设计、过流保护、风扇控制算法、并机功能实现等。文中还分享了许多实战经验和调试技巧,如死区时间配置、电流采样方法、并网同步算法等。 适合人群:具有一定电子电路和嵌入式开发基础的技术人员,尤其是从事逆变器及相关电力电子产品开发的工程师。 使用场景及目标:适用于希望深入了解逆变器工作原理和技术实现的开发者,特别是那些需要掌握并离网切换、高效电源管理及可靠保护机制的人群。目标是帮助读者构建一个稳定可靠的逆变器系统,能够应对各种复杂的工作环境。 其他说明:本文不仅提供了详细的理论讲解,还有丰富的代码片段和实践经验分享,有助于读者更好地理解和应用相关技术。
内容概要:本文详细介绍了如何利用Simulink在MATLAB环境中搭建单相全桥逆变器的仿真模型。首先,通过构建H桥结构,连接直流电源和RL负载,并引入PWM控制器进行开关管的控制。接着,针对仿真过程中遇到的各种问题,如谐波失真、开关管直通等问题,提出了具体的解决方案,包括加入LC滤波器、设置死区时间和优化PWM参数等。此外,还探讨了通过MATLAB脚本自动化测试不同参数组合的方法,以及如何提高电压利用率和降低谐波失真。最终,通过对仿真结果的分析,验证了所提方法的有效性和优越性。 适合人群:电力电子工程师、科研人员、高校学生等对逆变器仿真感兴趣的群体。 使用场景及目标:适用于研究和开发高效、稳定的逆变器系统,旨在通过仿真手段减少实验成本,优化设计方案,提高系统的性能指标。 其他说明:文中提供了详细的建模步骤和技术细节,帮助读者更好地理解和掌握相关技术和方法。同时,强调了仿真参数的选择和优化对于获得理想仿真结果的重要性。
计算机红外通信.pdf
软考考试学习必备资料.md
基于cornerstonejs开发移动端
构建交互式图片画廊
源码
Bosch Rexroth IndraWorks Ds IndraWorks Ds 14V16.310.0
java面向对象 - 类与对象
内容概要:本文详细介绍了基于AT32平台的无感FOC(Field-Oriented Control)控制算法,特别是针对永磁同步电机(PMSM)和无刷直流电机(BLDC)的位置速度观测器实现。文章首先展示了启动策略的独特之处,即跳过传统前馈强拖阶段,直接利用矢量控制环和观测器协同启动。接着深入探讨了磁链观测器的核心算法,包括磁链积分、反正切求角度以及速度估算部分使用的改良版PLL。此外,文中还提到了容差配置模块,用于提高系统的鲁棒性和稳定性。最后,强调了模块间良好的解耦设计,使得各功能模块拥有明确的输入输出接口,增强了代码的可维护性和移植性。 适合人群:从事电机控制系统开发的技术人员,尤其是对无感FOC算法感兴趣的工程师。 使用场景及目标:适用于需要高精度、快速响应的电机控制系统开发项目,旨在提升系统的鲁棒性和稳定性,特别是在电机参数存在偏差的情况下依然能够保持良好性能。 其他说明:文章不仅提供了详细的代码实现,还分享了许多实用的经验和技术细节,如启动策略、磁链观测器的物理本质、速度估算方法等,有助于读者更好地理解和应用无感FOC算法。
计算机机房de设置与维护.pdf
《Java 面试进阶指北 》 质量很高,专为面试打造
内容概要:本文详细介绍了外转子开关磁阻电机(ER-SRM)的多目标优化方法,主要采用NSGA-II算法进行优化。文章首先解释了为什么ER-SRM比传统内转子电机更难以优化,接着展示了如何利用NSGA-II算法解决这一难题。文中提供了详细的Matlab代码,包括种群初始化、交叉变异操作、非支配排序以及目标函数的定义。此外,还讨论了优化过程中的一些注意事项,如初始种群多样性的保持、交叉变异参数的选择、目标函数的设计等。最后,通过具体的案例和图表展示了优化结果及其应用价值。 适合人群:从事电机设计与优化的研究人员和技术人员,尤其是对外转子开关磁阻电机感兴趣的读者。 使用场景及目标:适用于需要同时优化电机效率、转矩波动和制造成本等多种目标的情况。通过NSGA-II算法,可以在多个相互冲突的目标间找到最佳平衡点,从而提高电机的整体性能。 其他说明:文章不仅提供了完整的Matlab代码实现,还分享了许多实践经验,如参数设置的经验公式、常见错误及解决方案等。这对于理解和掌握NSGA-II算法的实际应用非常有帮助。
慢行智远V2.0"是一款专业的串口数据采集与信号分析软件,集成了多通道数据采集、实时波形显示、FFT频谱分析、FIR滤波处理等高级功能。软件提供直观的用户界面,支持亮色/暗色两种主题,具备强大的数据处理与可视化能力。核心功能包括: 全面的串口通信支持(多种波特率、数据位、停止位、校验位配置) 多通道(最多4通道)波形实时显示与分析 高级信号处理(FFT频谱分析、FIR滤波、信号平滑等) 智能数据管理(断行数据处理、大数据量优化) 数据记录与导出(文本、CSV、图像多种格式) 自适应界面设计(支持高DPI显示、暗色主题) 适用人群 嵌入式开发工程师:需要通过串口调试单片机、开发板等嵌入式设备 电子工程师:进行电路测试、信号采集与分析的专业人员 工业自动化技术人员:监测工业设备数据、进行状态分析 科研教育工作者:用于实验数据采集、科学研究与教学演示 医疗设备开发人员:分析生物电信号、开发医疗监测设备 物联网开发者:调试传感器网络、分析传感器数据 硬件测试工程师:进行产品质量检测、性能评估 使用场景及目标 研发调试场景 单片机开发:实时监控传感器数据、调试通信协议、观察系统运行状态等等