pbtreeview:为PB的TreeView实现同步选择

广州中山大学信息管理系2001级 梁冠超(510275)

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

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

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

1.       为TreeViewControl控件添加个用户事件ue_synchronizechildren(long handle, eger state)代码如下:

long childitem

treeviewitem tvitem

getitem(handle, tvitem)

tvitem.statepictureindex=state

item(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, eger state)如下:

long parentitem

treeviewitem tvitem

getitem(handle, tvitem)

tvitem.statepictureindex=state

item(handle, tvitem)

parentitem=this.finditem(ParentTreeItem!, handle)

parentitem<>-1 then

this.Event ue_synchronizeparent(parentitem, state)

      end

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

treeviewitem tvitem

getitem(handle, tvitem)

tvitem.statepictureindex=prevstate then

  



  this.Event ue_synchronizechildren(handle, tvitem.statepictureindex)

     tvitem.statepictureindex=1 then //如需实现文末提及功能可在此处添加代码

           this.Event ue_synchronizeparent(handle, tvitem.statepictureindex)

    end

end





3.       在Clicked事件中添加如下:

treeviewitem tvitem

getitem(handle, tvitem)

post event ue_statechanged(handle, tvitem.statepictureindex)

       为了简单起见上面代码并没有考虑当选上个结点时所有兄弟已被选择因此父结点也应该被选择情况如有需要请读者自己完成
Tags:  pbtreeview选中 pbtreeview实例 pbtreeview刷新 pbtreeview

延伸阅读

最新评论

发表评论