2007-02-14

在Eclipse RCP中实现I18N的思考与疑问

关键字: RCP I18N
在RCP产品中实现国际化,一般是两种方式。

方式一:

  1. public class Messages {  
  2.   private static final String BUNDLE_NAME = "test.messages";  
  3.   
  4.   private static final ResourceBundle RESOURCE_BUNDLE = ResourceBundle  
  5.         .getBundle(BUNDLE_NAME);  
  6.   
  7.   private Messages() {  
  8.   }    
  9.     ......  
  10.     ...... 
  11.   
  12.   public static String getString(String key) {  
  13.     try {  
  14.         return RESOURCE_BUNDLE.getString(key);  
  15.     } catch (MissingResourceException e) {  
  16.         return '!' + key + '!';  
  17.     }  
  18.   }  
  19. }  


方式二:

  1. public class Message extends NLS {  
  2.   // bundle name, refer to message properties  
  3.   private static final String BUNDLE_NAME = "test.messages";   
  4.     ......  
  5.     ......     
  6.   static {  
  7.     NLS.initializeMessages(BUNDLE_NAME, MessageTest.class);  
  8.   }  
  9. }  


Eclipse平台和LumaQQ用的都是方式二,其实现机制用到了OSGI,与一相比的优点是什么?

此外,这两种方式所支持的I18N并不是动态的,也就是说,当用户从控制面板中更改了语言以后,需要重启应用才能发现改变,但是要做到像Skype那样,提供菜单选项来更改语言,应该如何处理呢?

对于商业化的产品而言,为了改变产品的语言而重启肯定是不可取的,
也许有个办法可以做到,就是在一个地方集中处理所有的UI组件中的文字,当用户通过应用程序改变locale,就去刷新所有的UI组件,但还是没想好应该怎么做到这一点...

不知道谁有过这方面的经验,盼指教!
评论
dearwolf 2007-02-28   回复
多谢楼上的兄台,我苦恼的就是根据新的Locale加载字符资源,重绘所有界面这一点,还好目前项目出于下阶段开发的调研阶段,而且动态改变I18N也不是下个版本所需要考虑的。不过,有没有RCP的大牛出来指点一下啊~~
titan 2007-02-28   回复
如果要实现改变语言,而无需重启,可以考虑借鉴LookAndFeel的机制。
1. 所有的字符资源不能使用静态方式加载。
2. 当Locale改变时,根据新的Locale加载字符资源,要求所有界面重绘(重绘时重新根据key获取字符)
不知Swt是否有类似机制
dearwolf 2007-02-27   回复
但是在产品中,哪个用户愿意看到因为改变语言而导致软件重启啊.....
小疯子 2007-02-26   回复
我们在eclipse中[File]->[Switch Workspace]时,eclipse有一个save的restart的过程,LZ是不是可以参考一下。
dearwolf 2007-02-18   回复
谢谢

大概也只能这样子作了...
tiyi 2007-02-15   回复
动态修改。肯定要对所有的界面控件都有一个刷新方法,在刷新方法中重设文本。
发表评论

该博客是同时发布到论坛的,无法评论在论坛已被锁定的帖子

dearwolf
搜索本博客
我的相册
E4ad347d-0c94-3e1b-b11c-cd60a6dbc8cc-thumb
sina
共 3 张
最近加入圈子
存档
最新评论