JSP进度条实例(下)

        三、任务进度

  status.jsp页面利用一个HTML进度条向用户显示任务的执行情况。首先,status.jsp利用<jsp:useBean>标记获得start.jsp页面创建的Bean对象:

 

<jsp:useBean id="task" scope="session" class="test.barBean.TaskBean"/>

 

  为了及时反映任务执行进度,status.jsp会自动刷新。JavaScript代码setTimeout("location='status.jsp'", 1000)将每隔1000毫秒刷新页面,重新请求status.jsp,不需要用户干预。

 

<HTML>

<HEAD>

                  <TITLE>JSP进度条</TITLE>

                  <% if (task.isRunning()) { %>

               <SCRIPT LANGUAGE="JavaScript">

                   setTimeout("location='status.jsp'", 1000);

               </SCRIPT>

                  <% } %>

</HEAD>

<BODY>

 

  进度条实际上是一个HTML表格,包含10个单元——即每个单元代表任务总体的10%进度。

 

<H1 ALIGN="CENTER">JSP进度条</H1>

           <H2 ALIGN="CENTER">

        结果: <%= task.getResult() %><BR>

        <% int percent = task.getPercent(); %>

        <%= percent %>%

           </H2>

           <TABLE WIDTH="60%" ALIGN="CENTER" BORDER=1 CELLPADDING=0 CELLSPACING=2>

               <TR>

                   <% for (int i = 10; i <= percent; i += 10) { %>

                <TD WIDTH="10%" BGCOLOR="#000080">&nbsp;</TD>

                   <% } %>

                   <% for (int i = 100; i > percent; i -= 10) { %>

                <TD WIDTH="10%">&nbsp;</TD>

                   <% } %>

               </TR>

           </TABLE>

 

  任务执行情况分下面几种状态:正在执行,已完成,尚未开始,已停止:

 

<TABLE WIDTH="100%" BORDER=0 CELLPADDING=0 CELLSPACING=0>

               <TR>

                   <TD ALIGN="CENTER">

                <% if (task.isRunning()) { %>

                    正在执行

                <% } else { %>

                    <% if (task.isCompleted()) { %>

                        完成

                    <% } else if (!task.isStarted()) { %>

                        尚未开始

                    <% } else { %>

                        已停止

                    <% } %>

                <% } %>

            </TD>

        </TR>

 

页面底部提供了一个按钮,用户可以用它来停止或重新启动任务:

 

<TR>

              <TD ALIGN="CENTER">

                  <BR>

                  <% if (task.isRunning()) { %>

                    <FORM METHOD="GET" ACTION="stop.jsp">

                        <INPUT TYPE="SUBMIT" VALUE="停止">

                    </FORM>

                  <% } else { %>

                    <FORM METHOD="GET" ACTION="start.jsp">

                        <INPUT TYPE="SUBMIT" VALUE="开始">

                    </FORM>

                <% } %>

              </TD>

           </TR>

         </TABLE>

</BODY></HTML>

 

  只要不停止任务,约10秒后浏览器将显示出计算结果5050

 

  四、停止任务

 

  stop.jsp页面把running标记设置成false,从而停止当前的计算任务:

 

<jsp:useBean id="task" scope="session" class="test.barBean.TaskBean"/>

<% task.setRunning(false); %>

<jsp:forward page="status.jsp"/>

 

  注意最早的Java版本提供了Thread.stop方法,但JDK1.2版开始已经不赞成使用Thread.stop方法,所以我们不能直接调用Thread.stop()

 

  第一次运行本文程序的时候,你会看到任务的启动有点延迟;同样地,第一次点击“停止”按钮时也可以看到任务并没有立即停止运行(特别是如果机器配置较低的话,延迟的感觉更加明显),这些延迟都是由于编译JSP页面导致的。编译好JSP页面之后,应答速度就要快多了。

 

  五、实际应用

 

  进度条不仅使得用户界面更加友好,而且对服务器的性能也有好处,因为进度条会不断地告诉用户当前的执行进度,用户不会再频繁地停止并重新启动(刷新)当前的任务。另一方面,创建单独的线程来执行后台任务也会消耗不少资源,必要时可考虑通过一个线程池来实现Thread对象的重用。另外,频繁地刷新进度页面也增加了网络通信开销,所以务必保持进度页面简洁短小。

  在实际应用中,后台执行的繁重任务可能不允许停止,或者它不能提供详细的执行进度数据。例如,查找或更新关系数据库时,SQL命令执行期间不允许中途停止——不过如果用户表示他想要停止或中止任务,程序可以在SQL命令执行完毕后回退事务。

  解析XML文档的时候,我们没有办法获知已解析内容精确的百分比。如果用DOM解析XML文档,直到解析完成后才得到整个文档树;如果用SAX,虽然可以知道当前解析的内容,但通常不能确定还有多少内容需要解析。在这些场合,任务的执行进度只能靠估计得到。

估计一个任务需要多少执行时间通常是很困难的,因为它涉及到许多因素,即使用实际测试的办法也无法得到可靠的结论,因为服务器的负载随时都在变化之中。一种简单的办法是测量任务每次执行所需时间,然后根据最后几次执行的平均时间估算。如果要提高估计时间的精确度,应当考虑实现一种针对应用特点的算法,综合考虑多种因素,例如要执行的SQL语句类型、要解析的XML模式的复杂程度,等等。

 

  结束语:本文例子显示出用JSPJavaHTMLJavaScript构造进度条是相当容易的,真正困难的是如何将它用到实际应用之中,特别是获得后台任务的进度信息,但这个问题没有通用的答案,每一种后台执行的任务都有它自己的特点,必须按照具体情况具体分析。

 

Java在窗口上加载显示GIF动画图像,将多个独立的GIF图像串联在一起显示,形成GIF特有的动画形式。主要代码如下:   ImageIcon[] images; //用于动画的图标数组   Timer animationTimer;   int currentImage = 0; //当前图像编号   int delay = 500; //图像切换延迟   int width; //图像宽度   int height; //图像高度   public AnimatorIcon() //构造函数   {    setBackground(Color.white);    images = new ImageIcon[2]; //初始化数组    for (int i=0;i   images[i]=new ImageIcon(getClass().getResource("image" i ".gif")); //实例化图标    width = images[0].getIconWidth(); //初始化宽度值    height = images[0].getIconHeight(); //初始化高度值   }   public void paintComponent(Graphics g) { //重载组件绘制方法    super.paintComponent(g); //调用父类函数    images[currentImage].paintIcon(this,g,70,0); //绘制图标    currentImage=(currentImage 1)%2; //更改当前图像编号   }   public void actionPerformed(ActionEvent actionEvent) {    repaint();   }   public void startAnimation() { //开始动画    if (animationTimer==null) {    currentImage=0;    animationTimer=new Timer(delay, this); //实例化Timer对象    animationTimer.start(); //开始运行    } else if (!animationTimer.isRunning()) //如果没有运行    animationTimer.restart(); //重新运行   }   public void stopAnimation() {    animationTimer.stop(); //停止动画   }   public static void main(String args[]) {    AnimatorIcon animation = new AnimatorIcon(); //实例化动画图标    JFrame frame = new JFrame("动画图标"); //实例化窗口对象    frame.getContentPane().add(animation); //增加组件到窗口上    frame.setSize(200, 100); //设置窗口尺寸    frame.setVisible(true); //设置窗口可视    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); //关闭窗口时退出程序    animation.startAnimation(); //开始动画
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值