真正的SelectionChanged事件

最近闲来无事写个Eclipse RCP小程序,需要用到一个特性,就是窗口内有两个视图,其中一个视图内有一个TreeView控件,要求点击TreeView控件上的不同节点,另外一个视图能够收到的SelectionChanged事件,并且进行处理。

这是一个很简单的功能,到网上查了一下,基本上都是一个模式:把左边的TreeView注册为SelectionProvidor,右边的视图注册为SelectionListener,并且在SelectionChanged()接口内编写代码,这样就实现了所谓的SelectionChanged事件了。

但是,嗯,凡事都怕这个但是,一旦领导跟你说话时在表扬了你半天之后,话锋一转说了个但是,你就准备等着挨骂吧。

接着来,但是,这网上的例子都是讲到上面就为止了,意思是这样就实现了SelectionChanged事件了。那么这样做真的就是对的吗?

我按照网上的说法做了一下,发现这个方法是有问题的。SelectionChanged事件,顾名思义,就是当选择了TreeView上不同的节点才会触发,可实际的效果是如果没有切换节点,多次点击在同一个节点上,该事件依然会触发。这算哪门子SelectionChanged事件啊,简直就是Clicked事件嘛。

解决这个问题,实现真正的SelectionChanged事件的方法也很简单,有两个方案,一个是继承TreeView类,重载其fireSelectionChanged()接口,判断确实是不同的Selection后,再触发SelectionChanged事件,另一个方案是在SelectionListener的SelectionChanged事件内判断Selection是否确实发生了变化,然后再进行相应的处理。这两个方案实现起来也很简单,这里就不贴代码了。

最后再说句自己的感慨,这网上的东西的确是多,可是大部分都是人云亦云,转来转去,没有经过自己的思索和判断,以为转了几篇文章,自己就成了技术专家了。唉,搞技术还是得老老实实,没有经过自己验证和确认的东西,最好不要乱转,免得贴出来被人笑话。

你可能感兴趣的:(java,职场,事件,休闲)