目前Document类的结构已经比较完善了,由于编辑Document涉及到界面,所以先把GUI写出来。
用Java做界面一直是比较麻烦的事情,早期的AWT太慢,现在很少用了,Swing我没用过,但速度也快不了多少,最后发现SWT是一个不错的本地库,速度够快,而且效果和本地平台一样(因为是调用的平台相关API),不仔细看根本看不出是java做的。
不过,考虑到移植性,我决定把Frame分成平台无关和相关两层,这样就有足够的灵活性,将来可以用Swing或者其他GUI库替换SWT,或者移植到linux上时只需改动平台相关的接口(比如Windows中的Font使用了LOGFONT结构,这个在linux中根本没有),上层抽象GUI接口不用改,核心类jexi.core.*只和抽象GUI打交道,不用管底层GUI是怎么实现的。
为了抽象出GUI接口,定义了:
Color , Font , Graphics , Frame , View ,……
等抽象接口或抽象类,对应的平台相关的具体类分别是:
SWTColor , SWTFont , SWTGraphics , SWTFrame , SWTView ,……
为了让上层客户端只和抽象接口打交道,使用Abstract Factory + Singleton + Adapter等模式,如图:
优点是灵活性大大增强,Factory不仅负责创建Product,还可以缓存以便提高效率(要知道像创建字体这些GUI操作是非常费时间的),缺点是引入了更多的类。
比如Font:
由于抽象类FontFactory是一个Singleton,所以写了一个硬编码在里面:
private static FontFactory instance = new SWTFontFactory();
这是唯一有耦合的地方,不过如果用SwingFontFactory替换了SWTFontFactory,只需要改成:
private static FontFactory instance = new SwingFontFactory();
重新编译即可。
一个基本的界面已经可以运行了,如下图:
下一步是增加编辑功能,文件读写,测试,争取下一周发布一个 beta 版! :)