最近在做一个鼠标经过弹出 TreeView  面板功能 , 要求鼠标离开TreeView区域,隐藏面板。 功能如期开发,其中当TreeView 出现滚动条时,鼠标经过TreeView中的滚动条时,提前隐藏。 原因: TreeView 中将 滚动区域视为非已部份。因此鼠标经过该区域,触发  MouseLeave 事件,但滚动区域没有显示声明 MouseEnter , MouseLeave 的入口 , 因此无法在触发MouseLeave(隐藏动作) 后即时触发 滚动区域的MouseEnter(显示面版)事件。

 

因此禁用TreeView Scroll 功能,外层使用Panel, Panel 同时禁用Scroll 功能(只做容器), Scroll 功能由 VScrollBar 实现滚动功能,通过设置 TreeView.Top 值。

因此,需要做如下工作:

1. 手动计算TreeView 内容高度,并将高度值赋给 TreeView.Height.

2.将VScrollBar Maxnum 值设为 TreeView.Height - Panel.Height

3. 设置VScrollBar 中的ValueChange 事件,将 value 赋给 TreeView.top 

 

private void vScrollBar1_Scroll(object sender, ScrollEventArgs e)
        {
            //e.NewValue 值达不到 vScrollBar1.Maximum ???
            if (vScrollBar1.Maximum - e.NewValue <= 10)
            {
                treeView1.Top = vScrollBar1.Maximum * -1;
            }
            else {
                treeView1.Top = e.NewValue * -1;
            }
      }

 

 

其中 VScrollBar  Value 值最大时,总是小预设的 Maximum值,因此即使滚动到底部,也总有一部份内容不可视。因此,采用折中方式,如果滚动到底部时,VScrollBar Value  值 与 Maximum之差小于 10 px , 将 当前滚动值视为 Maximum 值

 private void vScrollBar1_Scroll(object sender, ScrollEventArgs e)
        {
            //e.NewValue 值达不到 vScrollBar1.Maximum ???
            if (vScrollBar1.Maximum - e.NewValue <= 10)
            {
                treeView1.Top = vScrollBar1.Maximum * -1;
            }
            else {
                treeView1.Top = e.NewValue * -1;
            }
        }

 

 posted on 2014-10-27 18:49  仰光  阅读(3223)  评论(0编辑  收藏  举报