当前位置:天才代写 > tutorial > JAVA 教程 > 用Java Swing建造接待屏幕

用Java Swing建造接待屏幕

2017-11-10 08:00 星期五 所属: JAVA 教程 浏览:417

副标题#e#

险些所有时髦的应用都有一个接待屏幕。接待屏幕既是宣传产物的要领之一,并且在长时间的应用启动进程中,接待屏幕还用来暗示应用正在筹备进程中。

下面是一个最简朴的接待屏幕实现:

class SplashWindow1 extends JWindow
{
  public SplashWindow1(String filename, Frame f)
  {
   super(f);
   JLabel l = new JLabel(new ImageIcon(filename));
   getContentPane().add(l, BorderLayout.CENTER);
   pack();
   Dimension screenSize =Toolkit.getDefaultToolkit().getScreenSize();
   Dimension labelSize = l.getPreferredSize();
   setLocation(screenSize.width/2 - (labelSize.width/2),
   screenSize.height/2 - (labelSize.height/2));
   setVisible(true);
   screenSize = null;
   labelSize = null;
  }
}

SplashWindow1类从Swing的JWindow派生。JWindow是一个容器,它没有其他窗口所具有的各类窗口元素,如标题条、窗口打点按钮,甚至连突出显示的边框也没有。因此,JWindow对付建造接待屏幕来说长短常符合的。上面的代码假定图形文件在当前目次。图形通过ImageIcon装入内存,然后它就被放到了JWindow的中心。接着,窗口被pack(),这使得Swing把窗口调解到适当的巨细,最后窗口被移到了屏幕的中心。

假如我们运行上面的措施,可以发明固然接待画面确实呈此刻屏幕中央,但遗憾的,它却不会封锁!要封锁接待画面,我们需要插手更多的代码:

class SplashWindow2 extends JWindow
{
  public SplashWindow2(String filename, Frame f)
  {
   super(f);
   JLabel l = new JLabel(new ImageIcon(filename));
   getContentPane().add(l, BorderLayout.CENTER);
   pack();
   Dimension screenSize =Toolkit.getDefaultToolkit().getScreenSize();
   Dimension labelSize = l.getPreferredSize();
   setLocation(screenSize.width/2 - (labelSize.width/2),
   screenSize.height/2 - (labelSize.height/2));
   addMouseListener(new MouseAdapter()
   {  
    public void mousePressed(MouseEvent e)
    {
     setVisible(false);
     dispose();
    }
   });
   setVisible(true);
  }
}


#p#副标题#e#

和原先的SplashWindow1类对比,这个SplashWindow2类独一的区别在于多出了一个安装到JWindow上的匿名MouseListener。颠末这个窜改之后,用户可以点击接待屏幕封锁它。

此刻我们有了一个很不错的接待屏幕,它可以通过点击的要领封锁,但它不会本身消失。接下来我们要插手代码,使得接待屏幕在显示必然的时间之后自动消失。这里我们要思量到运用线程。

class SplashWindow3 extends JWindow
{
  public SplashWindow3(String filename, Frame f, int waitTime)
  {
   super(f);
   JLabel l = new JLabel(new ImageIcon(filename));
   getContentPane().add(l, BorderLayout.CENTER);
   pack();
   Dimension screenSize =Toolkit.getDefaultToolkit().getScreenSize();
   Dimension labelSize = l.getPreferredSize();
   setLocation(screenSize.width/2 - (labelSize.width/2),
   screenSize.height/2 - (labelSize.height/2));
   addMouseListener(new MouseAdapter()
   {
    public void mousePressed(MouseEvent e)
    {
     setVisible(false);
     dispose();
    }
   });
   final int pause = waitTime;
   final Runnable closerRunner = new Runnable()
   {
    public void run()
    {
     setVisible(false);
     dispose();
    }
   };
   Runnable waitRunner = new Runnable()
   {
    public void run()
    {
     try
     {
      Thread.sleep(pause);
      SwingUtilities.invokeAndWait(closerRunner);
     }
     catch(Exception e)
     {
      e.printStackTrace();
      // 可以或许捕捉InvocationTargetException
      // 可以或许捕捉InterruptedException
     }
    }
   };
   setVisible(true);
   Thread splashThread = new Thread(waitRunner, "SplashThread");
   splashThread.start();
  }
}

这里的根基思路是操作一个在一按时间内暂停期待的Thread工具。在上面的代码中,线程的暂停时间是4秒。当这个线程叫醒时,它将封锁接待屏幕。由于Swing长短线程安详的,除非代码在事件分配线程上执行,不然它就不该该影响任何UI组件的状态。所谓事件分配线程,就是Swing中认真画图和事件处理惩罚的线程。

#p#分页标题#e#

为了办理这个问题,Swing设计者赋予我们安详地把Runnable工具插手UI事件行列的本领。在本例中,我们用可运行工具closerRunner完成最要害的事情。我们把可运行工具传入SwingUtilities.invokeAndWait()静态要领,然后wingUtilities.invokeAndWait()举办所有未完成的UI操纵,并执行通报给该要领的可运行工具closerRunner的run要领。通过运用一个独立的线程认真接待屏幕的封锁操纵,应用担负起了显示和封锁接待屏幕之间的所有操纵。

假如要让接待屏幕老是显示且用户不能封锁它,你必需删除那些埋没接待屏幕的代码。假如要让接待屏幕只能由用户手工封锁,你可以象利用任何其他JWindow工具一样挪用SplashWindow3工具上的setVisible(false)和dispose()要领。

 

    关键字:

天才代写-代写联系方式