科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道JavaFX 新WebService客户端脚本语言

JavaFX 新WebService客户端脚本语言

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

 JavaFX还处于开发的早期阶段。虽有一些IDE支持,但我们仍缺少正式文档……

作者: William Brogden 来源:IT专家网 2008年4月24日

关键字: 客户端 WebService JavaFX java

  • 评论
  • 分享微博
  • 分享邮件
在五月份召开的JavaOne大会上,Sun微系统公司宣布了一个新的产品系列JavaFX,由JavaFX脚本和JavaFX Mobile组成。JavaFX脚本语言被用来让使用Java“Swing”用户接口库来创建富用户接口变得更加容易,该用户接口可以在支持Java标准版的任何设备上运行。Sun想要将该语言作为开放源代码项目发布。需要注意人们习惯将JavaFX脚本称为JavaFX或者JFX,但是Sun还是将JavaFX Mobile放到了JavaFX产品线中。我将在这篇文章中使用JFX来指代JavaFX脚本。

  为什么又要一个脚本语言?

  如今脚本语言当然受到了很多的压力。在以前的文章中,我曾经写过Ruby、JavaScript、Python、JavaServer Pages和Linden Scripting Language等Web service客户端。这些不同的语言共同的目的是尝试着通过提供一种连接现有组件的简单方式来让复杂应用的编写变的更加容易。在JFX的情况中,它最关心的组件是Swing用户接口组件,该组件最初出现在Java标准库1.2版以补充相当原始的Java AWT工具。

  JFX基础

  这个语言支持常见的变量类型,比如字符串、整型、浮点型和布尔值。对于list和array的扩展支持的语法,在我看来非常强大。这个语言还提供了异常的创建和处理,并且引入了新的想法,即任何对象可以被抛出,不仅仅是标准的Java Throwable类型。JFX脚本还可以导入Java类、创建Java对象和调用他们的方法。

  JFX对象通过声明的方法来创建。这对于那些为“swing”Java用户接口类提供简化的class非常有用。我们在下面的完整脚本中查看一下JFX对象是如何通过声明的方式来创建的。

  import javafx.ui.*;
  Frame {
  title: "Hello World from JavaFX"
  width: 200
  height: 80
  content: Button {
  text: "Hello World"
  }
  visible: true
  }

  在这个例子中,Frame和Button是用来隐藏将在屏幕上显示出来的JFrame和JButton对象的创建细节的脚本类型。这个Frame类有名为“title”、“width”、“height”、“content”和“visible”的公共“属性”,它们都在声明中被设置了。

  消息处理问题

  JFX也有每一个图形用户接口工具都会遇到的问题。点击按钮之类的用户事件一定不能和需要长时间执行任务的事件处理线程绑定,因为在该任务执行的时候,这个接口会毫无反应。JFX提供了“do”和“do later”原语来处理这个问题。我使用一段脚本来试验JFX显示出从天气预报服务站点检索出来的数据,其中使用了“do later”。首先,我定义了一个叫做WeatherData的JFX类。这个类有两个属性和一个操作。

  import javafx.ui.*;
  import java.net.URL;
  import java.lang.StringBuffer ;
  import java.lang.System;
  import java.io.InputStreamReader;
  import java.io.BufferedReader;
  class WeatherData {
  attribute source: String ;
  attribute text: String ;
  operation update();
  }

 注意这个JFX类的声明只包括了操作的签名,真正的代码分开定义如下:

  operation WeatherData.update(){
  var content = new StringBuffer("");
  do later {
  var url = new URL( source );
  var is = url.openStream();
  var reader = new BufferedReader(new InputStreamReader(is));
  var line;
  while (true) {
  line = reader.readLine();
  if (line == null) { break;
  }
  content.append(line);
  content.append("\n");
  } // end while
  is.close();
  text = content.toString();
  } // end do later
  }

  现在创建窗口来表示用户接口。注意这个Frame被定义成有一个WeatherData类的本地实例。其中的URL是用来获得我所在的县下周的天气预报。

  Frame {
  var wdata = WeatherData {
  text: "initialized"
  source: "http://forecast.weather.gov/MapClick.php?zoneid=TXZ173&TextType=1"
  }
  title: "Weather Forcast"
  width: 400
  height: 400
  background: cyan
  content: BorderPanel {
  border: EmptyBorder{ top: 10 left: 10 bottom: 10 right: 10
  }
  top: Button {
  text: "update"
  action: operation(){ wdata.update();}
  height: 80
  }
  center: TextArea { text: bind wdata.text
  }
  } // close content
  visible: true
  }

  当这个按钮被点击之后,更新操作被调用,创建一个线程来执行“do later”中的后续代码来填充文本变量。注意TextArea的文本内容是通过wdata.text变量的“bind”关键字来定义的。当该变量的内容被更新之后,新的文本将自动的出现在窗口当中。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章