进度条(JProgressBar)是一种以可视化形式显示某些任务进度的组件。JProgressBar 类实现了一个用于为长时间的操作提供可视化指示器的 GUI 进度条。在任务的完成进度中,进度条显示该任务完成的百分比。此百分比通常由一个矩形以可视化形式表示,该矩形开始是空的,随着任务的完成逐渐被填充。此外,进度条可显示此百分比的文本表示形式。
JProgressBar 类的常用构造方法和 JSlider 类的常用构造方法一样,这里不再重复。如下示例代码演示了如何创建一个 JProgressBar 类实例。
//创建一个最小值是0,最大值是100的进度条
JProgressBar pgbar=new JProgressBar(0,100);
//创建一个最小值是0,最大值是60,当前值是20的进度条
JProgressBar pgbar=new JProgressBar(0,60,20);
JProgressBar 类的常用方法如表 1 所示。
方法名称 | 说明 |
---|---|
getMaximum() | 返回进度条的最大值 |
getMinimum() | 返回进度条的最小值 |
getPercentComplete() | 返回进度条的完成百分比 |
getString() | 返回当前进度的 String 表示形式 |
getValue() | 返回进度条的当前 value |
setBorderPainted(boolean b) | 设置 borderPainted 属性,如果进度条应该绘制其边框,则此属性为 true |
setIndeterminate(booleannewValue) | 设置进度条的 indeterminate 属性,该属性确定进度条处于确定模式中还是处于不确定模式中 |
setMaximum(int n) | 将进度条的最大值设置为 n |
setMinimum(int n) | 将进度条的最小值设置为 n |
setOrientation(int newOrientation) | 将进度条的方向设置为 newOrientation |
setString(String s) | 设置进度字符串的值 |
setStringPainted(boolean b) | 设置 stringPainted 属性的值,该属性确定进度条是否应该呈现进度字符串 |
setValue(int n) | 将进度条的当前值设置为 n |
updateUI() | 将 UI 属性重置为当前外观对应的值 |
其中,setOrientation() 方法的参数值必须为 SwingConstants.VERTICAL 或 SwingConstants.HORIZONTAL。JProgressBar 使用 BoundedRangeModel 作为其数据模型,以 value 属性表示该任务的“当前”状态,minimum 和 maximum 属性分别表示开始点和结束点。
技巧:如果要执行一个未知长度的任务,可以调用 setlndeterminate(true) 将进度条设置为不确定模式。不确定模式的进度条将持续地显示动画来表示正进行的操作。一旦可以确定任务长度和进度量,则应该更新进度条的值,将其切换到确定模式。
使用 JProgressBar 类创建一个进度条模拟程序升级过程,实现过程如下。
(1) 创建一个继承自 JFrame 的 JProgressBarDemo 类。
(2) 在构造方法中添加一个空的进度条,然后设置它的显示属性。主要代码如下:
package ch18;
import java.awt.Container;
import java.awt.FlowLayout;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JProgressBar;
public class JProgressBarDemo extends JFrame
{
//static JProgressBarDemo frame;
public JProgressBarDemo()
{
setTitle("使用进度条");
JLabel label=new JLabel("欢迎使用在线升级功能!");
//创建一个进度条
JProgressBar progressBar=new JProgressBar();
JButton button=new JButton("完成");
button.setEnabled(false);
Container container=getContentPane();
container.setLayout(new GridLayout(3,1));
JPanel panel1=new JPanel(new FlowLayout(FlowLayout.LEFT));
JPanel panel2=new JPanel(new FlowLayout(FlowLayout.CENTER));
JPanel panel3=new JPanel(new FlowLayout(FlowLayout.RIGHT));
panel1.add(label); //添加标签
panel2.add(progressBar); //添加进度条
panel3.add(button); //添加按钮
container.add(panel1);
container.add(panel2);
container.add(panel3);
progressBar.setStringPainted(true);
//如果不需要进度上显示“升级进行中...”,可注释此行
progressBar.setString("升级进行中...");
//如果需要使用不确定模式,可使用此行
//progressBar.setIndeterminate(true);
//开启一个线程处理进度
new Progress(progressBar, button).start();
//单机“完成”按钮结束程序
button.addActionListener(new ActionListener()
{
@Override
public void actionPerformed(ActionEvent e)
{
dispose();
System.exit(0);
}
});
}
/**
* @param args
*/
public static void main(String[] args)
{
// TODO Auto-generated method stub
JProgressBarDemo frame=new JProgressBarDemo();
//frame.setBounds(300,200,300,150); //设置容器的大小
frame.setVisible(true);
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.pack();
}
}
(3) 创建 Progress 线程并实现对进度条进度的控制,实现代码如下。
private class Progress extends Thread
{
JProgressBar progressBar;
JButton button;
//进度条上的数字
int[] progressValues={6,18,27,39,51,66,81,100};
Progress(JProgressBar progressBar,JButton button)
{
this.progressBar=progressBar;
this.button=button;
}
public void run()
{
for(int i=0;i<progressValues.length;i++)
{
try
{
Thread.sleep(3000);
}
catch(InterruptedException e)
{
e.printStackTrace();
}
//设置进度条的值
progressBar.setValue(progressValues[i]);
}
progressBar.setIndeterminate(false);
progressBar.setString("升级完成!");
button.setEnabled(true);
}
}
上述代码定义了一个进度条的进度数组 progressValues。线程每隔 1000 毫秒从数组中取一个数字作为当前进度,并使用 JProgressBar 类的 setValue() 方法更新到进度条。最后使进度条显示“升级完成!”字符串,并使“完成”按钮可用。
图 1 为程序的运行效果。图 2 为调用 Setlndeterminate(true) 方法后进度条使用不确定模式的运行效果。图 3 为默认的数字进度条运行效果。