Scala被认为是JVM上的下一代语言的最有潜力的继承者。
Apache Pivot是一个基于RIA的Java GUI框架。
初识 Pivot也就是在其升级到Apache顶级项目的时候,带着好奇心去浏览了一番,发现其在Java GUI框架方便果然是独树一帜,Java很成功,但是在GUI方面确实很失败,从AWT,到Swing,再到现在的JavaFx,很少被Java社区的开发者所接受。而IBM的SWT,虽然在性能和框架体系上声称优越于AWT、Swing等,但是在目前RIA大行其道的情况下,个人觉得有点落伍了,虽然Eclipse e4对SWT新增了不少功能(xwt,databinding),这些功能对于Pivot来说早已经就是天生的了。何况e4现在还是处于不稳定的状态。
上面废话太多,下面的代码演示了如何使用Scala编写一个最简单的Pivot程序。只包含一个PushButton控件和按钮事件处理函数
package cn.dvision.main
import org.apache.pivot.wtk._
import org.apache.pivot.wtkx._
import org.apache.pivot.collections.{Map => PMap} /*重新命名一下,与Predef.Map冲突,带有歧义*/
import cn.dvision.bean._
class PivotWindow extends org.apache.pivot.wtk.Application {
var window : Window = null
var button : PushButton = null
def startup( display :Display, properties : PMap[String, String] ) {
val wtkxSerializer = new WTKXSerializer()
/*从WTKX文件中加载GUI控件对象 并使用 asInstanceOf[T]强制转换为制定的类型的对象
与 Java 的 widow = ( Window) wtkxSerialiser.(...) 相同*/
window = wtkxSerializer.readObject(this,"PivotWindow.wtkx").asInstanceOf[Window]
button = wtkxSerializer.get("button").asInstanceOf[PushButton]
/*监听Button事件,并设置事件监听的执行内容*/
listenTo( button ) { (btn : Button) => {
Alert.alert( "Click " + btn.getButtonData, window)
}
}
window.open(display)
}
def shutdown( optional : Boolean) : Boolean = {
if ( window != null ) window.close
return true;
}
def suspend() {
}
def resume() {
}
/*事件监听辅助函数,向 button增加一个监听函数*/
def listenTo ( button : Button ) ( btnPressedFun : ( Button ) => Unit ) : Unit = {
button.getButtonPressListeners().add( new ButtonPressListener() {
def buttonPressed( button : Button ) : Unit = {
btnPressedFun(button)
}
}
)}
}
object PivotWindow {
def main( args : Array[String] ) {
/*使用classOf获得 class 对象, Java中使用 PivotWindow.class*/
DesktopApplicationContext.main( classOf[PivotWindow],args)
}
}
下面是PivotWindow.wtkx 内容
<Window title="Hello WTKX!" maximized="true"
xmlns:wtkx="http://pivot.apache.org/wtkx"
xmlns="org.apache.pivot.wtk">
<content>
<PushButton wtkx:id="button" buttonData="Click Me"/>
</content>
</Window>
编译:
scalac -classpath pivot-core-1.5.jar;pivot-tools-1.5.jar;pivot-wtk-1.5.jar;pivot-wtk-terra-1.5.jar;. PivotWindow.scala
Scala中,源代码的文件名和类可以不一样,有点类似于C++,而且你可以在同一个源代码文件中放置多个统一等级的类,而不像Java中,需要每个类需要一个独立的文件保存。 PivotWindow.scala 可以使用你喜欢的任何名字命名。
运行:
scala -classpath pivot-core-1.5.jar;pivot-tools-1.5.jar;pivot-wtk-1.5.jar;pivot-wtk-terra-1.5.jar;. cn.dvision.main.PivotWindow
我是把 pviot的jar文件放在和 scala文件相同的目录下的条件下执行 scalac和scala的。
分享到:
相关推荐
读书笔记:使用Scala语言编写的spark程序初学
读书笔记:maven构建scala语言编写的spark测试程序
文档以scala语言编写了sparkSQL查询数据的方式,没有打jar包运行,在spark命令行测试通过
本项目是基于Scala语言开发的Apache Spark学习与实践源码,共包含53个文件。其中,Scala源代码文件21个,文本文件7个,XML文件5个,Markdown文档5个,JSON配置文件3个,Avro Schema文件2个,CSV数据文件2个,...
2. 移动应用程序:Scala 语言可以用于开发移动应用程序,例如使用 Scala Native 开发移动应用程序。 3. 桌面应用程序:Scala 语言可以用于开发桌面应用程序,例如使用 ScalaFX 开发桌面应用程序。 Scala 语言的开发...
7. **Scala与Spark的关系**:Apache Spark是构建在Scala之上的大数据处理框架,它的API主要用Scala编写,因此熟悉Scala语言有助于更好地理解和使用Spark。Spark的DataFrame和DataSet API都是基于Scala的,理解Scala...
在快速入门章节中,给出了使用IDEA开发“hello, world”程序的示例,并介绍了Scala程序的执行流程,还用Java编写了模拟代码,以此帮助初学者理解Scala语言的基本结构和概念。 书中的知识点还包括了Scala语言的转义...
读书笔记:学习使用Scala 来编写程序
spark-recommender, 在 Scala 中使用 Apache Spark 框架,编写了可以扩展的推荐系统 火花推荐采用 Scala 框架编写的可以扩展推荐系统,使用了 Apache Spark 框架。实现的算法包括:k-最近邻居带聚类的k-近邻带簇树的...
spark中用scala编写累加器小程序统计指定文章中的空白行,然后通过split函数通过空格切分文章,输出到指定的目录中。
本源码项目是基于Scala的Apache Spark REST作业服务器设计,包含343个文件,主要使用Scala、Shell、Python、JavaScript、Java、CSS和HTML编程语言。该项目是一个为Apache Spark设计的REST作业服务器,旨在提供一种...
通过编写简单的示例程序,可以快速上手Scala编程。 总的来说,Scala是一门强大且富有创新的语言,它将面向对象和函数式编程的精髓结合在一起,为开发者提供了丰富的工具和概念,以应对现代软件开发的复杂性。学习...
一旦完成以上步骤,开发者就可以开始使用Scala语言编写Spark程序了。Scala作为一种强类型的语言,其语法简洁且功能强大,非常适合进行函数式编程。 - **使用Scala API**:在编写Spark程序时,可以直接调用Scala API...
标题中的“图解,Eclipse+ADT+ScalaIDE用Scala写Android程序”指的是使用Eclipse集成开发环境(IDE),Android Developer Tools (ADT)插件以及ScalaIDE扩展来编写Android应用程序的过程。这个过程涉及了Java语言替代...
Scala是一种多范式编程语言,融合了面向对象和函数式编程的概念。它的设计目标是提供一种更高级别的抽象,使得代码简洁、可读性强,并且能够充分利用并发处理。本教程旨在帮助初学者深入理解Scala语言,并掌握其核心...
通过深入学习“Scala语言规范.pdf”,你将能全面理解Scala的语法特性、编程理念和最佳实践,从而能够编写出高效、可维护的代码,充分利用其与Java的互操作性和强大的并发能力。无论你是Java开发者希望扩展技能树,...
这意味着你可以在Scala程序中直接使用Java类库中的任何类和接口,反之亦然。 ##### 3.1 导入Java类 在Scala中,可以使用`import`语句来导入Java类。例如: ```scala import java.util.{Date, Locale} import java...