From: ggzzzzzzz@gmail.com

To: python-chinese@lists.python.cn

Date: Nov 4, 2005 4:26 PM

Subject: PythonGO开发计划(以James Tauber的PyGo为基础)


我找到一个叫PyGo的open source project,不过好久没有更新了。有兴趣可以看看这个作者的主页:

http://jtauber.com/ PyGo的作者James Tauber是XML领域的大拿

我下载了pygo-0.10.1.tgz,是用Python/Tk做的GUI,仅有两人对弈、sgf播放的基本功能。

这个PyGo很适合我学习:

1、够简单,我应该能看懂。所有代码加起来1600行左右,和我自己写的一个工具行数差不多。

所以我准备以pygo为基础开始开发PythonGO,我觉得PythonGO这个名称够直接、好懂,Igo好像是Korea的叫法。


项目目标

首先实现两人用一台电脑对弈、打谱这两个最基本的功能,然后实现通过某种协议(如GTP)连接现有的GO Server对弈


注:

1、不实现网络对弈的服务器端(降低难度、专心做好一件事)

2、不用过多考虑将来支持其他网络游戏,不想做出复杂、功能众多的游戏大厅,不想做网游平台(我能力有限,还是要降低难度、专心做好一件事)

3、GUI还是和PyGo原来一样使用Python/Tk,首先要能跑起来,要做得漂亮是以后的事情


我不懂软件开发,我想大致按以下次序实现一些功能:

1.显示棋盘、棋子及其他必须显示的内容(最好有个抽象层,允许各种实现,SDL、Pygame、Pythonware Imaging Library等)

2.对局条件的协商,一般是发出对局邀请的一方先选择条件,受邀请一方接受或修改条件(棋盘尺寸、黑白选择、让子、贴子、保留时间、读秒设置)

3.当出现死子时自动提子,当一方想下在禁着点时给予适当的提示,弃权一手、计算胜负的功能

4.将棋局保存为sgf格式文件的功能

5.暂停棋局(封盘)的功能,可以再次加载sgf文件继续对弈

6.打谱功能,最基本的进、退、加注释功能

7.通过网络两人对弈的功能(最好是利用QQ、MSN,无需手工输入IP地址什么的)

8.连接网络服务器的功能,如支持GTP协议,连接KGS, CWS, NNGS的能力


1-3应该是最基本的了,涉及到GUI的实现、一些简单算法(实现两人用一台电脑对弈)

4-6和sgf文件格式有关,可以利用http://gotools.sourceforge.net/的成果(实现最基本的打谱功能)

7-8是和网络编程有关


我的行动计划:

1. 学习pygo的代码,做注释,然后在wiki上发布注释后的版本

2. 完成1后再说,现在什么都不懂

3. 持之以恒,没什么比这更重要的了。不怕做得慢,只怕说得多做得少。如果我一个人做,至少一年后才能连接Go Server对弈:)


附上James Tauber在2002年写下的TODO:

- ability to save territory/score in SGF as node # 将胜负(数子或数目)结果保存到SGF文件中?

- editing and adding of properties (especially comments) # 属于注释、打谱功能

- better display of variations # 更好地显示分支,属于注释、打谱功能

- better display of common properties # 更好地显示常规属性

- optionally show atari # 可选择显示叫吃

- ability to play problems # 死活题功能

- handling of line-break in SGF values

- allow resizing of canvas to scale board # 棋盘大小随着窗口大小变化

- better Tk packing

- ability to create problems # 用什么算法?暂时不考虑

- numbers in showgo need to make mask if not on stone # 某一点没有棋子但是要显示数字

- partial boards in showgo # 刷新棋盘一部分的功能

- user management

- pluggable computer players

- internet server games # 连接Go Server对弈

- point-to-point network games # P2P对弈