Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7332657
  • 博文数量: 5645
  • 博客积分: 9880
  • 博客等级: 中将
  • 技术积分: 68080
  • 用 户 组: 普通用户
  • 注册时间: 2008-04-28 13:35
文章分类

全部博文(5645)

文章存档

2008年(5645)

我的朋友

分类:

2008-04-28 21:47:04

下载本文示例代码
  下载本文源代码  在默认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)。 图1:DesktopDemo用户接口  你可以通过下载应用程序源代码及相关的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-描述一种与打印一特定的文件类型相关联的应用程序执行的打印行为共3页。 1 2 3 8 :   下载本文源代码  在默认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)。 图1:DesktopDemo用户接口  你可以通过下载应用程序源代码及相关的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-描述一种与打印一特定的文件类型相关联的应用程序执行的打印行为共3页。 1 2 3 8 : 下载本文示例代码


Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨Java SE 6.0 桌面API编程探讨
阅读(133) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~