从 DataGridView 控件 托放数据 到 TreeView控件(二)

简介: 前面已经实现了从 DataGridView 拖放数据到 TreeView.不过拖放是通过 鼠标右键完成的. 根据windows的一般标准,是通过鼠标左键来进行数据拖放操作的.像windows资源管理器,既能处理鼠标左键单机的选择,也能处理左键拖放操作.
前面已经实现了从 DataGridView 拖放数据到 TreeView.
不过拖放是通过 鼠标右键完成的. 根据windows的一般标准,是通过鼠标左键来进行数据拖放操作的.
像windows资源管理器,既能处理鼠标左键单机的选择,也能处理左键拖放操作.
这个怎么实现?
前面我们只处理了 DataGridView 的mousedown事件, 现在要处理 mousedown, mousemove, mouseup这三个事件来完成这个任务.
大致过程如下:

在MouseDown事件里面和之前一样处理,只是不启动拖放操作.
而是保存要拖放的数据, 以及建立一个小的矩形框(根据系统DragSize信息).

然后在 MouseMove 事件里面判断
是否已经准备好拖放了,如果准备好了,就启动拖放操作.
(注:鼠标在小矩形框范围内的移动不启动拖放操作)

MouseUp里面清除哪些标记量.

这样就能处理左键单击的选择和 左键拖放了.
代码如下:
img_a6339ee3e57d1d52bc7d02b338e15a60.gif private   void  dataGridView1_MouseDown( object  sender, MouseEventArgs e)
img_405b18b4b6584ae338e0f6ecaf736533.gifimg_1c53668bcee393edac0d7b3b3daff1ae.gif        
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif {
img_33d02437d135341f0800e3d415312ae8.gif            
if ((e.Button & MouseButtons.Left) == MouseButtons.Left)
img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif            
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
img_33d02437d135341f0800e3d415312ae8.gif                DataGridView.HitTestInfo info 
= dataGridView1.HitTest(e.X, e.Y);
img_33d02437d135341f0800e3d415312ae8.gif                
img_33d02437d135341f0800e3d415312ae8.gif                
if (info.RowIndex >= 0)
img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif                
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
img_33d02437d135341f0800e3d415312ae8.gif                    dragData 
= (DataGridViewRow)
img_33d02437d135341f0800e3d415312ae8.gif                          dataGridView1.Rows[info.RowIndex];
img_33d02437d135341f0800e3d415312ae8.gif
img_33d02437d135341f0800e3d415312ae8.gif                    Size dragSize 
= SystemInformation.DragSize;
img_33d02437d135341f0800e3d415312ae8.gif                    dragBoxFromMouseDown 
= new Rectangle(new Point(e.X - (dragSize.Width / 2),
img_33d02437d135341f0800e3d415312ae8.gif                                                                e.Y 
- (dragSize.Height / 2)), dragSize);
img_33d02437d135341f0800e3d415312ae8.gif
img_105a1e124122b2abcee4ea8e9f5108f3.gif                }

img_105a1e124122b2abcee4ea8e9f5108f3.gif            }

img_33d02437d135341f0800e3d415312ae8.gif
img_05dd8d549cff04457a6366b0a7c9352a.gif        }

img_a6339ee3e57d1d52bc7d02b338e15a60.gif
img_a6339ee3e57d1d52bc7d02b338e15a60.gif        
private   void  dataGridView1_MouseUp( object  sender, MouseEventArgs e)
img_405b18b4b6584ae338e0f6ecaf736533.gifimg_1c53668bcee393edac0d7b3b3daff1ae.gif        
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif {
img_33d02437d135341f0800e3d415312ae8.gif            
//reset
img_33d02437d135341f0800e3d415312ae8.gif
            dragBoxFromMouseDown = Rectangle.Empty;
img_33d02437d135341f0800e3d415312ae8.gif            dragData 
= null;
img_05dd8d549cff04457a6366b0a7c9352a.gif        }

img_a6339ee3e57d1d52bc7d02b338e15a60.gif
img_a6339ee3e57d1d52bc7d02b338e15a60.gif        
private   void  dataGridView1_MouseMove( object  sender, MouseEventArgs e)
img_405b18b4b6584ae338e0f6ecaf736533.gifimg_1c53668bcee393edac0d7b3b3daff1ae.gif        
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif {
img_33d02437d135341f0800e3d415312ae8.gif            
if ((e.Button & MouseButtons.Left) == MouseButtons.Left &&
img_33d02437d135341f0800e3d415312ae8.gif                dragData 
!= null &&
img_33d02437d135341f0800e3d415312ae8.gif                dragBoxFromMouseDown 
!= Rectangle.Empty && 
img_33d02437d135341f0800e3d415312ae8.gif                    
!dragBoxFromMouseDown.Contains(e.X, e.Y)
img_33d02437d135341f0800e3d415312ae8.gif                )
img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif            
img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
img_33d02437d135341f0800e3d415312ae8.gif                
//开始拖放;
img_33d02437d135341f0800e3d415312ae8.gif
                dataGridView1.DoDragDrop(dragData, DragDropEffects.Copy);
img_105a1e124122b2abcee4ea8e9f5108f3.gif            }

img_05dd8d549cff04457a6366b0a7c9352a.gif        }

最后使用中又发现一个问题.
就是不能用鼠标左键圈选单元格了.
这个该怎么处理呢? 这两个操作是有冲突的.

这里我们可以通过时间来控制. 即我们要求按下鼠标左键, 0.5秒之后 拖动鼠标 就启动数据拖放.
否则就按默认的圈选单元格.
即增加一个变量,在 MouseDown里面记录时间,在 MouseMove里面判断时间差.
如果不够 0.5秒就不启动数据拖放.

目录
相关文章
|
6月前
|
C# 数据库
40.c#:TreeView 控件
40.c#:TreeView 控件
66 1
|
6月前
|
C# 数据库 开发者
44.c#:combobox控件
44.c#:combobox控件
79 1
|
5月前
|
索引
详细解读c#ListBox控件
详细解读c#ListBox控件
39 0
|
6月前
|
存储 缓存 C#
46.c#:datagridview控件
46.c#:datagridview控件
87 1
|
6月前
|
C# 数据库 虚拟化
43.c#:listbox控件
43.c#:listbox控件
53 1