在网上查到的代码
1.为TreeView控件添加一个用户事件ue_synchronizechildren(long handle, integer state),代码如下:
long childitem
treeviewitem tvitem
getitem(handle, tvitem)
tvitem.statepictureindex=state
setitem(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 parentitem
treeviewitem tvitem
getitem(handle, tvitem)
tvitem.statepictureindex=state
setitem(handle, tvitem)
parentitem=this.finditem(ParentTreeItem!, handle)
if parentitem-1 then
this.Event ue_synchronizeparent(parentitem, state)
end if
2.添加一个用户事件ue_statechanged(long handle, integer prevstate)检测节点的选择状态, 如果发生了变化则调用ue_synchronizechildren同步后代节点,并根据需要通过ue_synchronizeparent同步祖先节点。代码如下:
treeviewitem tvitem
getitem(handle, tvitem)
if tvitem.statepictureindex=prevstate then
return
else
this.Event ue_synchronizechildren(handle, tvitem.statepictureindex)
if tvitem.statepictureindex=1 then //如需实现文末提及的功能,可在此处添加代码。
this.Event ue_synchronizeparent(handle, tvitem.statepictureindex)
end if
end if
3.在Clicked事件中,添加如下调用:
treeviewitem tvitem
getitem(handle, tvitem)
post event ue_statechanged(handle, tvitem.statepictureindex)
为了简单起见,上面的代码并没有考虑当选上一个结点时,它的所有兄弟已被选择,因此父结点也应该被选择的情况,如有需要,请读者自己完成。
///////////////////////////////////////
试了一下好用,但正如文中说的,没有实现:选中一个子节点,它的所有兄弟已被选择,因此父结点也应该被选择,请问该怎么改啊?立马给分!
------解决方案--------------------
上面的代码中都有啊,试几下也出来了!
long nextitem
treeviewitem ntvitem
if tvitem.statepictureindex=1 then //如需实现文末提及的功能,可在此处添加代码。
//现在是选择一个子项就修改父项,如果要所有子项都选择,再修改父项,那就参考上面的同级循环的代码,循环判断一下它的同级项的状态
nextitem=this.finditem(nexttreeItem!, handle) //同层下一项
do while(nextitem<>-1)
getitem(handle, ntvitem)
if ntvitem.statepictureindex=1 then return //有没选中,就返回!
nextditem=this.finditem(NextTreeItem!, nextitem)
loop
nextitem=this.finditem(previoustreeItem!, handle) //同层上一项
do while(nextitem<>-1)
getitem(handle, ntvitem)
if ntvitem.statepictureindex=1 then return //有没选中,就返回!
nextditem=this.finditem(previoustreeItem!,nextitem)
loop
this.Event ue_synchronizeparent(handle, tvitem.statepictureindex)
end if
大概这意思,自己试试吧