为PB的TreeView实现同步选择

时间:2021-05-02

TreeView是Powerbuilder中非常重要的一个控件,在很多地方使用起来非常方便,但同步选择问题困扰了很多人,本文就给出了实现TreeView控件同步选择的一个方法。

TreeView控件能够清晰地表示层次关系,因而赢得了众多程序员的喜爱。在TreeView编程中,常见的一个问题是同步选择(即选择一个节点时,同时选择该节点的所有子节点;不选一个节点,同时去除该节点的祖先节点选择标志)。

要实现这种效果,本来不难,只需要在检测到节点选择状态变化时,遍历节点的祖先或者后代节点进行同步即可。但是PB并没有提供检测节点选择状态变化的事件。怎么办呢?

让我们来看看PB中TreeView节点选择状态的表示。当TreeView的CheckBoxes属性为True时,每个节点包含一个复选框。选中复选框时,StatePictureIndex属性为2,未选中则为1。当选择某个节点时,首先触发TreeView的Clicked事件,处理完Clicked事件后再对StatePictureIndex进行设置。显然,如果我们能够将Clicked事件前后节点的StatePictureIndex属性值进行比较,我们就可以判断节点的选择状态是否发生了变化。按照这个思路,疏理PB的事件模型,发现采用Post的调用事件方法,可以实现将一个事件加入控件消息序列,在处理完当前事件后再对新加入的事件进行处理。至此,我们得到了如下的解决方案:

(1)为TreeView控件添加一个用户事件ue_synchronizechildren(long handle, integer state),代码如下:

long childitemtreeviewitem tvitemgetitem(handle, tvitem)tvitem.statepictureindex=statesetitem(handle, tvitem)childitem=this.finditem(ChildTreeItem!, handle) do while(childitem<>-1)this.Event ue_synchronizechildren(childitem, state) //递归遍历后代结点childitem=this.finditem(NextTreeItem!, childitem)loop添加一个用户事件ue_synchronizeparent(long handle, integer state),如下:long parentitemtreeviewitem tvitemgetitem(handle, tvitem)tvitem.statepictureindex=statesetitem(handle, tvitem)parentitem=this.finditem(ParentTreeItem!, handle)if parentitem<>-1 thenthis.Event ue_synchronizeparent(parentitem, state)end if

(2)添加一个用户事件ue_statechanged(long handle, integer prevstate)检测节点的选择状态, 如果发生了变化则调用ue_synchronizechildren同步后代节点,并根据需要通过ue_synchronizeparent同步祖先节点。代码如下:

treeviewitem tvitemgetitem(handle, tvitem)if tvitem.statepictureindex=prevstate thenreturnelsethis.Event ue_synchronizechildren(handle, tvitem.statepictureindex)if tvitem.statepictureindex=1 then //如需实现文末提及的功能,可在此处添加代码。this.Event ue_synchronizeparent(handle, tvitem.statepictureindex)end ifend if

(3)在Clicked事件中,添加如下调用:

treeviewitem tvitemgetitem(handle, tvitem)post event ue_statechanged(handle, tvitem.statepictureindex)

为了简单起见,上面的代码并没有考虑当选上一个结点时,它的所有兄弟已被选择,因此父结点也应该被选择的情况,如有需要,请读者自己完成。广州中山大学信息管理系2001级 梁冠超(510275)

翔宇亭IT乐园提醒您:本文来自于互联网,版权归原作者和各发布网站所有,本站收集这些文章仅供学习参考之用。任何人都不能将这些文章用于商业或者其他目的。()

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章