我正在编写一个简单的应用程序,一个方程系统求解器。 它背后的基本思想是从用户获取系统中的变量数量,并动态创建许多JTextField,然后按一个按钮来解决系统。
在我努力实现它的过程中,我正在努力设置垂直滚动条。
发生的情况是,在使用JScrollPane之后,布局会全部搞乱。
我已经使用this作为指南并尝试这样做,使用VERTICAL_ALWAYS和HORIZONTAL_NEVER,但它不起作用。
控件放在一边,而不是从上到下一个接一个地放置。
如何实现这一目标?
public class SolverUserInterface implements ActionListener{
private JFrame solverUI;
private JPanel panel;
private JLabel lbl[];
private JTextField eq_Fields[];
public SolverUserInterface(int Count) {
// TODO Auto-generated constructor stub
solverUI = new JFrame("Solver");
solverUI.setSize(405, 137);
solverUI.setResizable(false);
Dimension dim = Toolkit.getDefaultToolkit().getScreenSize();
solverUI.setLocation(dim.width/2-solverUI.getSize().width/2, dim.height/2-solverUI.getSize().height/2);
solverUI.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
panel = new JPanel();
panel.setLayout(new FlowLayout());
lbl = new JLabel[Count];
eq_Fields = new JTextField[Count];
for(int i = 0; i < Count; i++){
lbl[i] = new JLabel("Equation "+(i+1)+" : ");
eq_Fields[i] = new JTextField(26);
panel.add(lbl[i]);
panel.add(eq_Fields[i]);
}
JButton btnSolve = new JButton("Solve Equations!");
panel.add(btnSolve);
btnSolve.addActionListener(this);
/*This is the part concerned*/
JScrollPane jp = new JScrollPane(panel, JScrollPane.VERTICAL_SCROLLBAR_ALWAYS, JScrollPane.HORIZONTAL_SCROLLBAR_NEVER);
solverUI.add(jp);
solverUI.revalidate();
}
public void ShowUserInterface(){
solverUI.setVisible(true);
}
@Override
public void actionPerformed(ActionEvent arg0) {
// TODO Auto-generated method stub
}
}
答案 0 :(得分:3)
这是一个更合理,更实用的GUI,基于您的尝试。仔细看看。
import java.awt.*;
import javax.swing.*;
public class SolverUserInterface {
private JFrame solverUI;
private JPanel panel;
private JLabel lbl[];
private JTextField eq_Fields[];
public SolverUserInterface(int Count) {
solverUI = new JFrame("Solver");
solverUI.setLocationByPlatform(true);
solverUI.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
panel = new JPanel(new BorderLayout());
JPanel labels = new JPanel(new GridLayout(0,1,5,5));
JPanel fields = new JPanel(new GridLayout(0,1,5,5));
lbl = new JLabel[Count];
panel.add(labels, BorderLayout.LINE_START);
panel.add(fields, BorderLayout.CENTER);
eq_Fields = new JTextField[Count];
for(int i = 0; i < Count; i++){
lbl[i] = new JLabel("Equation "+(i+1)+" : ");
eq_Fields[i] = new JTextField(26);
labels.add(lbl[i]);
fields.add(eq_Fields[i]);
}
JButton btnSolve = new JButton("Solve Equations!");
solverUI.add(btnSolve, BorderLayout.PAGE_END);
JScrollPane jp = new JScrollPane(
panel,
JScrollPane.VERTICAL_SCROLLBAR_ALWAYS,
JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);
solverUI.add(jp);
solverUI.pack();
Dimension d = solverUI.getSize();
int w = (int)d.getWidth();
int h = (int)d.getHeight();
h = (h>200 ? 200 : h);
Dimension shrinkHeight = new Dimension(w,h);
solverUI.setSize(shrinkHeight);
}
public void showUserInterface(){
solverUI.setVisible(true);
}
public static void main(String[] args) {
Runnable r = new Runnable() {
@Override
public void run() {
SolverUserInterface sui = new SolverUserInterface(105);
sui.showUserInterface();
}
};
SwingUtilities.invokeLater(r);
}
}
好的,只有一个关于Pack()的澄清。当我使用它时,窗口的大小随着字段数量的增加而增长,但是当我删除Pack()时则不是这样。使用滚动条时似乎使用Pack()是没有意义的。我对此结论是否正确?
一点,但不完全。