H5W3
当前位置:H5W3 > 其他技术问题 > 正文

Java SE 6.0 桌面API编程

 在默认GUI外观、打印和运行性能方面,Java平台一直在努力缩小本机应用程序和Java应用程序程序是之间的差距。随着Java SE 6(代码名为Mustang)的问世,一些新的功能又被加入,包括新的系统托盘功能,更好的打印支持和桌面API(java.awt.Desktop API),从而进一步缩小以上差距。本文中描述的这些新型桌面API允许Java应用程序与主机平台上的特定文件类型的默认应用程序进行交互。为了更有效地描述这些API,本文还将向你展示一个简单的示例应用程序DesktopDemo。  一、 桌面概述  这种新功能是由java.awt.Desktop类所提供的。这种API来源于JDesktop集成组件(JDIC)工程。该工程的目的是,使得基于Java技术的应用程序成为桌面平台上的"第一等公民",并实现与桌面API的无缝集成。具体地说,这种新型桌面API允许你的Java应用程序实现如下功能:  · 使用一个特定的统一资源标志符(URI)启动主机系统的默认浏览器  · 启动主机系统的默认电子邮件客户端  · 启动特定的应用程序以打开、编辑或打印与之相关联的文件  这些桌面API使用你的主机操作系统的文件关联以启动与特定文件类型相关联的应用程序。例如,如果开放文档文本(.odt)文件扩展名与OpenOffice书写器应用程序相关联,那么你的Java应用程序就可以启动OpenOffice书写器以打开、编辑或打印与这种关联相关的文件。根据你的主机系统的不同,不同的应用程序可能关联不同的行为。  二、 运行DesktopDemo应用程序  DesktopDemo是一个简单Java应用程序-它使用了Mustang的桌面API。该应用程序提供了一个主窗口,允许你实现如下三项功能:  1. 以一个特定的URI启动默认浏览器。  2. 用一个邮件接收者启动默认电子邮件客户端。  3. 启动一个相关联的应用程序以打开、编辑或打印文件。  图1显示了这个用户接口(UI)。

  你可以通过下载应用程序源代码及相关的JAR文件来运行这个应用程序-把你的控制台的活动目录改变为该应用程序工程的dist目录,并且使用一个Mustang JDK执行下列命令:java -jar DesktopDemo.jar  三、 确定是否支持Desktop API  在启动浏览器、电子邮件客户端或任何应用程序之前,DesktopDemo必须确定是否你的平台支持这种API。然而,DesktopDemo首先停用所有的图形化的文本域和按钮。在确定该平台支持它们之后它该程序才启用这些图形组件。  在实例化这些UI后,该应用程序的构造器快速停用这个应用程序的少数几个组件,如下列代码所示:

public DesktopDemo() { //初始化所有的GUI组件. initComponents(); // 停用启动浏览器和电子邮件客户端的按钮 // 停用打开,编辑和打印文件的按钮 disableActions(); …}/*** 停用所有的图形组件,直到我们了解* 是否支持它们的功能.*/private void disableActions() { txtBrowserURI.setEnabled(false); btnLaunchBrowser.setEnabled(false); txtMailTo.setEnabled(false); btnLaunchEmail.setEnabled(false); rbEdit.setEnabled(false); rbOpen.setEnabled(false); rbPrint.setEnabled(false); txtFile.setEnabled(false); btnLaunchApplication.setEnabled(false); }…public javax.swing.JTextField txtBrowserURI;public javax.swing.JButton btnLaunchBrowser;public javax.swing.JTextField txtMailTo;public javax.swing.JButton btnLaunchEmail;public javax.swing.JRadioButton rbEdit;public javax.swing.JRadioButton rbOpen;public javax.swing.JRadioButton rbPrint;public javax.swing.JTextField txtFile;public javax.swing.JButton btnLaunchApplication;

  使用Desktop.isDesktopSupported()方法来确定是否桌面API可用。在Solaris操作系统和Linux平台上,这种API是依赖于Gnome库的。如果这些库不可用,那么这个方法将返回false。在确定支持这种API(也就是说,isDesktopSupported()返回true)之后,该应用程序就可以使用静态方法getDesktop()来检索一个Desktop实例。

Desktop desktop = null;//在使用更多的Desktop API前,首先检查//是否这种API为该特定主机上的特别的虚拟机所支持。if (Desktop.isDesktopSupported()) {desktop = Desktop.getDesktop();…

  如果你的应用程序在调用getDesktop()之前不使用isDesktopSupported()进行API支持检查,那么它必须准备捕获一个UnsupportedOperationException异常-当你的应用程序在一个不支持这种特性的平台上请求一个Desktop实例时将抛出这种异常。另外,如果你的应用程序运行于一种无键盘、鼠标和监视器环境下,该getDesktop()方法将抛出一个java.awt.HeadlessException异常。  一旦检索完毕,该Desktop实例即允许你的应用程序浏览、邮寄、打开、编辑或甚至打印一个文件或URI,但是只有在被检索的Desktop实例支持这些活动的前提下才行。每个这些活动被称为一个行为(Action),并且每一个行为被描述为一个Desktop.Action枚举实例:  · BROWSE-描述主机的默认浏览器执行的一种浏览行为  · MAIL-描述主机的默认电子邮件客户端执行的一种邮件行为  · OPEN-描述一种与打开一特定的文件类型相关联的应用程序执行的打开行为  · EDIT-描述一种与编辑一特定的文件类型相关联的应用程序执行的编辑行为  · PRINT-描述一种与打印一特定的文件类型相关联的应用程序执行的打印行为

在调用任何这些行为之前,一个应用程序必须确定是否该Desktop实例支持它们。这与确定是否一个Desktop实例可用是有所不同的。这个Desktop.isDesktopSupported()方法告诉你是否能够创建一个实例。一旦获得一个Desktop对象,你就可以查询该对象来确定支持哪些特定类型的行为。如果该Desktop对象不支持特定的行为,或如果该桌面API本身并不被支持,那么DesktopDemo简单地停用那些受影响的图形组件。如图2所示,在停用状态下,不能使用这些组件来调用桌面特性。

 

 

  通过使用一个新的Desktop实例,下列代码检查负责是否支持Desktop.Action并且启用适当的图形组件:

public DesktopDemo() { …  //在使用更多的桌面API前,首先检查 //是否这种API为该特定主机上的特别的虚拟机所支持。 if (Desktop.isDesktopSupported()) {  desktop = Desktop.getDesktop();  // 现在,启用按钮以实现被支持的行为  enableSupportedActions(); }  …}/***启用在该主机上被支持的行为。*这些行为有:打开浏览器,*打开电子邮件客户端,和使用它们相关联的应用程序打开,编辑与打印文件。*/private void enableSupportedActions() { if (desktop.isSupported(Desktop.Action.BROWSE)) {  txtBrowserURI.setEnabled(true);  btnLaunchBrowser.setEnabled(true); } if (desktop.isSupported(Desktop.Action.MAIL)) {  txtMailTo.setEnabled(true);  btnLaunchEmail.setEnabled(true); }  if (desktop.isSupported(Desktop.Action.OPEN)) {  rbOpen.setEnabled(true); } if (desktop.isSupported(Desktop.Action.EDIT)) {  rbEdit.setEnabled(true); } if (desktop.isSupported(Desktop.Action.PRINT)) {  rbPrint.setEnabled(true); } if (rbEdit.isEnabled() || rbOpen.isEnabled() || rbPrint.isEnabled()) {  txtFile.setEnabled(true);  btnLaunchApplication.setEnabled(true); }}

  一旦该应用程序确定了被支持的行为,它即启用适当的图形组件。如果所有的组件都被启用,那么相应的UI应该看上去如图3所示。

  四、 打开浏览器  调用下列实例方法将打开你的主机的默认浏览器:

public void browse(URI uri) throws IOException

  因为仅当支持相关联的Desktop.ActionDesktopDemo时,UI组件才被启用,所以,在实际调用browse()方法之前,这个简单的演示应用程序不需要进行行为支持检查。然而,在每一种调用之前检查行为支持在实际中将增加程序的健壮性:

if (desktop.isSupported(Desktop.Action.BROWSE)) { //启动浏览器 …}

  DesktopDemo把一个java.awt.event.ActionListener添加到每一个按钮上。当被启用时,"Launch Browser"按钮通过它的ActionListener调用下列方法:

private void onLaunchBrowser(java.awt.event.ActionEvent evt) { URI uri = null; try {  uri = new URI(txtBrowserURI.getText());  desktop.browse(uri); } catch(IOException ioe) {  ioe.printStackTrace(); } catch(URISyntaxException use) {  use.printStackTrace(); } …}

  这个browse()方法可能抛出各种类型的异常,这包括:当该URI为null时抛出一个NullPointerException异常;如果不支持BROWSE行为将抛出一个UnsupportedOperationException异常;如果不能发现或启动一个缺省的浏览器或应用程序则抛出一个IOException异常;如果一个安全管理器否定一次调用则抛出一个SecurityException异常。  然而,如果一切顺利,那么听取器(Listener)将从图4中相联系的文本域中检索文本,创建一个URI并且调用browse()方法。上面的代码将启动你的系统的默认浏览器并且指示该浏览器装载该URI,如图5所示。

 

本文地址:H5W3 » Java SE 6.0 桌面API编程

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址