Category Archives: fcitx development
Why Fcitx?
(伪调查用意……) 这是一个我难以回答的问题,我无法向别人很好的回答这个问题。 在我看来,缺少一个feature或者多一个feature无法成为这个问题永恒的答案。(当然这可能是你们的答案 🙂 ) 每个有兴趣选择开发Fcitx的人(虽然也没几个)在最开始的时候,都无一例外的被我问了这个问题。为什么选择Fcitx而不是其他的输入法? 这个问题的答案也许没有理由,但对我来说也是一个值得思考的问题。 我也想从其他人那里知道答案。 因为对于我来说最终的答案可能只是我对它投入了精力而已。剩下的都只是附属产物。
破坏性与创造性
我从 2010年1月15日给 fcitx 做了第一次提交,到现在也经过了不长不短的一段时间。选择fcitx的原因很简单,因为当初它在KDE下面没啥问题。 当然现在也是了。 选择fcitx是一个偶然的决定,不过至少到现在我没有觉得我的选择是错误的。 由于比较长的一段时间其实一直只有我一个人写代码,于是经常会出现一些巨大改动,大部分的时候都是当初写这段代码的时候考虑不足造成的。 破坏性的事情其实我没少干,ABI和API的兼容其实是我后来才学到的东西,比如说有些事情也是才学会的(struct的padding),不过学习这些的过程也很有意思。这两年来,写的最多的代码就是C的代码了(除了fcitx之外的代码也大部分是C的)。虽然说我写过的Code,按语言算也有一些,不过还是对C的代码最有感情。每每在深夜里面,写出的每一段fcitx的代码都让我心情愉悦。近期宿舍的人有去面试,回来提到的一些问题我比较容易就回答出来了,其实都是开发fcitx过程中学习到的 🙂 其实我是个很爱操心的人,操心这个操心那个。开发fcitx的时候,经常会因为某个功能不知道如何实现而辗转反侧,因为某个引入的bug而总想急切的发布下个修复了这个bug的版本。(当然还经常操心混蛋的GNOME又要把fcitx怎么样了,我讨厌GNOME的原因全是因为fcitx) 对所有使用fcitx的人来说,从3.6到现在的4.1.2,应该也经历了不少的功能变化。在这期间我不断破坏……比如说 GBK -> UTF-8,Xft->Cairo,配置文件格式以及布局的变化,引入DBus等等,其实我非常非常不想给你们带来麻烦,其实在你们没有看到的地方还是有一些向下兼容的事情,比如 ~/.config/fcitx 下面的拼音数据,现在其实在 ~/.config/fcitx/pinyin 下面,这里有个硬连接过去的操作,比如这个Issue,为了保持老的配置里面写了不少冗余的代码。 每一个向下兼容的操作背后都会意味着代码的膨胀,有个笑话是说“在我写这段代码的时候,只有上帝和我知道它在干什么,现在只有上帝知道了”。fcitx虽然是个历史悠久的项目(2002的gWubi 0.1),不过现在它还处于一个很年轻的阶段。由于我个人的水平限制,一些破坏性的事情是不可避免的(比如时不时的ABI就break需要重新编译下)……我非常感谢所有支持Fcitx用户。 为了避免你们的这种麻烦,建议不要手动编译,ppa,obs,官方软件源都是你们的好朋友。另外请尽量编译最新的稳定版,至少我会尽量做到提示而不是crash(比如fcitx内置的ABI检测和so version bump)。 其实到目前为止,我还没有来得及在fcitx创造什么呢,老实说我不是一个有什么创造性的人,不过目前还是有一些有意思的想法想要在fcitx上实现(这个想法倒是短期内难以实现的……希望libpinyin大能把多词库支持做好)。希望fcitx能坚持到那一天呢 🙂 顺便一提下面的计划。这次的两个部分都不是我孤军奋战了哦 🙂 非常感谢 ELizabeth HONG:名字已经解释了内容了,不过才刚刚起步,不要尝试(啥都没有呢还) https://github.com/fcitx/fcitx-anthy/ Raven Dark:(通过DBus开发输入法的支持) http://code.google.com/p/fcitx/source/browse/?name=dbus-bridge 非常感谢二位忍耐我的啰嗦,唠叨,不讲道理,非常感谢。 另外有些朋友问到的移植问题,最主要的问题就是人员以及设备(设备还在其次……),近期可能我就会入手N9一台,看看能不能在上面搞出点什么来(原生程序比Android的JNI,或者是iOS的ObjC要简单多了,更别提我不会ObjC了),当然我觉得也没啥人会去玩N9啦,不过给Plasma Active做输入法我还是有着相当的兴趣的呢,而且在我看来水已经在那里了 🙂
Fcitx 4.1.2
fcitx 4.1.2 1、增加ABI检查。 2、支持状态分组,可以按程序或者全局使用同一个状态。FreeBSD下采用libkvm检测进程名称。 3、支持默认设置为开启或英文状态 4、修复码表的排序和连打问题 5、支持双击安装后缀为.fskin的皮肤 6、增加一个DBus的属性,可以在线修改输入法的启用状态 7、配置文件保存时枚举类型写入可选值的注释。 8、API修改,隐藏一些Struct,为了今后更容易保持ABI的兼容,输入法在注册时可以提供所属语言。区分在fcitx界面显示的预编辑字符串和在程序中显示的预编辑字符串。 9、拼音输入时程序中显示的预输入文本显示中文,以及固定光标位置。码表也固定光标位置以使得输入框不随输入立即移动。 fcitx-sunpinyin 0.3.2 1、支持用CTRL ALT 数字删除曾经输入的候选词。 2、修复双拼方案问题 3、程序中显示的预输入文本显示中文,以及固定光标位置。 fcitx-googlepinyin 0.1.3 1、和fcitx的API修改同步 2、程序中显示的预输入文本显示中文,以及固定光标位置。 fcitx-cloudpinyin 0.1.2 1、增加百度的云输入法的作为一个新的来源 2、fcitx自带的拼音可以记忆云拼音输入过的内容。(sunpinyin由于sunpinyin自己的api原因暂时无法实现) fcitx-ui-light 0.1.2 和主干API同步。 kcm-fcitx 0.2.0 1、支持fcitx 4.1.2增加的DBus接口,用于动态启用和禁用输入法。(演示) 2、增加皮肤管理的界面,支持在线下载kde-look.org 的皮肤。(演示) 3、修复重置操作的bug (没有更新的组件可以recompile后和此版本一起使用)
KCM Fcitx 的皮肤管理器
http://blip.tv/file/get/Csslayer-FcitxSkinManager310.mp4 老实说虽然有段时间自己不用皮肤功能了(用自己重写的kimpanel去了),不过还是把这个功能做出来了。 不久之后的更新4.1.2那批更新之后就能看到了哦。 感谢Ukyoi的Qt皮肤绘制部分的代码。直接拿来用了,不好意思 😀
运行时移除和添加输入法
还是直接贴视频好了。其实是困扰人民群众多年的问题吧…… 通过一个DBus的Property实现的。查询这个属性可以获得当前的输入法列表(包括禁用的和可用的)。设置这个值就可以调整顺序以及启用或者禁用了。 和以前古老的把“优先级设置为0”那个禁用方式不冲突,只不过用那种方式禁用的将不会出现在可用列表里面。