今天看了limodou在CU的帖子才知道Google的这个服务 google.com/coop/
limodou创建的是python.cn
google.com/coop/cse?cx=009376466705745340527%3Acpx…
我也创建了一个:Mobile Python,希望搜索Python在移动设备上的开发与应用。
google.com/coop/cse?cx=001459140553769941820%3Alss…
今天看了limodou在CU的帖子才知道Google的这个服务 google.com/coop/
limodou创建的是python.cn
google.com/coop/cse?cx=009376466705745340527%3Acpx…
我也创建了一个:Mobile Python,希望搜索Python在移动设备上的开发与应用。
google.com/coop/cse?cx=001459140553769941820%3Alss…
这几天用pygtk和glade写了一个不大的应用,在ubuntu下开发,然后移植到Maemo平台。
学习的过程中发现了SimpleGladeApp.py这个module,可以更方便地以面向对象的方式使用libgrade。
还记得serverinfo这个例子吗?里面是这样得到一个widget的实例的:
用了SimpleGladeApp.py,直接用self.logwindowview就行了。
下面是改造serverinfo使用SimpleGladeApp.py的步骤:
1. 从 www.gnomefiles.org/app.php/SimpleGladeApp.py 下载SimpleGladeApp.py
2. 解压缩后把tepache这个脚本放到你的PATH环境变量指定的路径下,比如/usr/local/bin,然后加上执行权限。
3. 我们已经有现成的serverinfo.glade文件了,现在要做的是用tepache这个脚本解析glade文件来生成一个Python模块,里面是一些对应window或dialog等顶层widget的class,并实现他们的callback方法。命令如下(-o选项是为了不覆盖原来的serverinfo.py):
可以看到tepache生成了三个文件:serverinfo_new.py, serverinfo_new.py.orig, SimpleGladeApp.py
.orig文件很重要,tepache用这个文件保护你在serverinfo_new.py添加的代码,所以不要删除这个文件。
可以先运行serverinfo_new.py看看效果。
4. serverinfo_new.py的部分代码:
5. 现在就可以添加一些代码来实现serverinfo的功能了。注意不要修改形如#– Demodialog custom methods { 这样的注释,否则如果界面(glade文件)有了改动,tepache就没法做patch了。
把原来的insert_row改成ServerInfo类的一个方法,放在#– Serverinfo custom methods 注释之间。
goUrl方法也放在这里。 注意访问widget实例的方法已经由
变成
main方法里的实例化Demodialog的语句要挪到button2的clicked事件响应方法里,不然程序一运行对话框就出现了,你刚才一定注意到了。
destroy响应方法里加入self.gtk_main_quit()以便窗口销毁时能够退出程序。
6. 现在运行serverinfo_new.py,原来serverinfo.py的功能基本上都有了。但有一个问题,对话框弹出后点击“确定”或“取消”按钮都不能关闭对话框。我的解决办法是不在glade设计这个对话框,完成在程序里用代码实现。
7. 注意每次重新设计了界面,修改了glade文件,都要运行tepache来patch生成的python模块,已做的修改不会被覆盖。
新的代码下载地址: guoyong.org/?dl=pygtk-learning-serverinfo-simplegl…
cvsgraph生成的文件版本图中链接地址不对。
需修改viewcvs的配置文件/etc/viewcvs/viewcvs.conf,把
这行改成
在Scratchbox里用ls命令时遇到一个warning:
在scratchbox-user邮件列表里找到了办法:
www.mail-archive.com/scratchbox-users@lists.scratc…
修改scratchbox里的.bash_profile文件,加入
最近想体验一下用Carbide.j开发J2ME程序。
先从开发环境的搭建开始。J2SDK自然是必不可少,1.4.2或更高的版本都可以。虽然Carbide.j可以独立运行,但也可以和一些流行的IDE集成,我选择了自己比较习惯的Eclipse。但在版本选择上走了弯路:一开始使用的是最新版的Eclipse 3.2,按照Forum Nokia提供的Screencast实现了一个hello world的例子,但没法在emulator里运行。一启动例子程序emulator就退出了。百般试验以后,确定不是程序的问题,而是Eclipse的版本不对,换了3.1.2就ok了。其实Carbide.j的安装说明里要求的Eclipse的版本就是3.0或3.1。
开发环境搭建好了,就可以学习那个screencast了解如何使用Carbide.j开发J2ME程序了。
screencast的下载地址:
forum.nokia.com/info/sw.nokia.com/id/93021595-9c99…
要下载你得有一个Forum Nokia的帐号。
Latest Comments
RSS