跨平台GUI开发库(转)

这篇内容有点专业,不搞开发的的可以飘过。

作为一个跨平台的GUI库,Qt算是老前辈了(据说tk是第一个真正的跨平台的GUI开发包,不知道有没有人验证过,但是用脚本写界面,这个好像不是主流吧)。网上搜索“跨平台GUI开发”应该可以得到不少对各个开发包进行比较的文章,这里说说我的感受:

Qt(http://www.trolltech.com/
我最喜欢的东西,毕竟是商业的东西,没什么bug,文档详细,API接口也做得通俗易懂,对windows、Linux、MacOS的支持都堪称完美。在MFC的世界摸爬滚打之后,发现Qt对程序员来说真是一片空气清新的世外桃源——就是舒服。准确的说,Qt是一个完整的应用程序开发库,而不仅仅是GUI。比如线程、数据库、socket这些东西都有对应的封装。第一次接触Qt是在PDA上的Qtopia环境,Qtopia其实就是在Qt Embeded(不用Xwindows的Linux版Qt)系统中集成了很多应用软件,打成一个包,就像Windows mobile,主要的应用程序都有了,用户还可以再在上面装点自己的小程序。现在Qt都出到4.4版本了,据说相对于版本3主要的改动是矢量图形的支持,我没有用过。Google Earth就是用的Qt,可以看到qt-mt338.dll这个dll文件,说明它用的是3.3.8版本的带多线程支持的Qt。

Moto曾经在高端的Linux手机上都用Qtopia环境,如A600、A680什么的,那个时候Qtopia也是唯一在嵌入式GUI领域可以商业的Linux方案,GTK on Framebuffer还不那么稳定,后来Moto和一帮日本公司搞了那个Limo基金会,专门用GTK/Framebuffer做Linux方案。今年年初Trolltech被收购的时候,moto说Qt已经对它们不那么重要了,我也相信这是事实。


GTK(http://www.gtk.org/
这个现在应该是应用最广的了,LGPL发布。说实话,我不喜欢这个东西,从封装和API上看没有Qt做的好,而且做程序还必须要atk和pango的一系列依赖的包。Wireshark(原来的ethereal)就是用GTK开发的,所以移植到windows上也是用的windows版的gtk,看看Wireshark安装目录下的dll文件就知道gtk要依赖多少东西了。开发起来不爽。说了这么多GTK的坏话,再说点好的,gtkmm是一个gtk的C++封装,做的不错,一看代码风格也知道要现代一些,不知这个mm是什么意思;以gtk为基础的gnome桌面环境现在有Sun和Redhat、Ubuntu的人的商业化支持,所以是原来稳定性越好了。不像Qt为基础的KDE,好像一直没什么商业化的支持,在桌面环境中的日渐式微就不足为奇了,我怀疑商业公司都不是真的喜欢GPL的东西,GTK是LGPL的,商业公司很喜欢,基于GTK的软件哪天它不想开源了也可以。Qt从QPL转到GPL之后,也没有多少商业的支持。这些大公司如果做了一个基础构架,就GPL了一把,让别人都用我的东西,提高自己的影响力,而且用了的公司还也得开源。如果是一个业务层面的软件,大公司的产品就没有一个是开源的。好了,扯远了,GTK也是个不错的东西,FireFox都用它,我从来没有用它做过有点规模的开发还说了这么多坏话,估计rp值有所下降。


wxWidgets(http://wxwidgets.org/
原名叫wxwindows,这个也不错,从API和编程风格上,模仿MFC的痕迹比较重,但是封装的很多类比MFC更高级。作为一个开源社区维护的产品,文档写的相当不错。从MFC转到这个上面很容易,开发社区一直比较活跃,还有一个xrc扩展可以用xml来定义界面。这个应该是跨的平台最多的一个开发包了。不过wxwidgets的代码质量和Qt相比应该还是有差距,我在开发中就发现了其中的两个bug(好像那个时候还是2.4版本),但是瑕不掩瑜,总体来说wx做的相当不错,连Apple的MacOS中默认安装都自带wx的运行环境,可见其影响力。另外要说的是,wx从以开始就做了很好的python绑定,叫做wxPython,和wx本身同步更新,基本上现在是python做界面开发的首选GUI库。比如原版的BitTorrent,界面就是用wxPython写的。尽管PyQt和PyGTK都在发展,都有人用,但是在Python的名下,风头似乎不及wxwidgets。上面说用脚本写界面似乎不是主流,但是在Python崛起之后,这个也不好说了。另外要说一点是:在X11上的wxwidgets有三个版本,一是直接用X库的wxX11,一个是基于GTK的wxGTK,还有基于Motif的wxMotif(开发不太活跃)。wxGTK要稳定一些。


Fox Toolkits(http://www.fox-toolkit.org/
说实话,没有真正用过,好像一直也还比较活跃,毕竟能撑到现在的GUI库都是有些实力的。

 

下面是我的比较:

Qt is the best one. 稳定,一个开发包搞定所有,不好的一点是编译很慢,相当慢,C++的通病啊。Qt Embedded应该是第一个不用Xwindow的linux图形环境吧,赞一个。想学习Linux下的GUI开发,应该从这个入手。甚至可以在VC用Qt的插件开发,做完程序到Linux下重新编译一下就OK了。
GTK,API相对有点复杂,但是在内存占用上相对而言有优势,说道这里再骂两句Xwindow,一个工具栏上的Applet就要驻留10M内存,太烂了吧。GTKmm封装的不错。在windows下开发GTK程序没有Qt那么方便,搭环境就比较复杂,还是在Linux下开发吧。
wxWidgets,移植MFC的程序到Linux下的话当然是用它了。或者你在给Python写界面程序,那就用Ulipad,用wxPython写的一个python集成环境。
 

你可能感兴趣的:(linux,python,qt,wxPython,跨平台,gtk)