【WinForm+DevExpress】GridView 在两个表格之间拖拽行

效果图

可以将左边的行数据拖拽到右边,或者是将右边的行数据拖拽到左边

实现:

第一步:

新加两个GridControl,为他们设置数据源,并且将两个GridControl的AllowDrop属性设置为True

 private void DragDemo_Load(object sender, EventArgs e)
        {
            FillData();
        }
private void FillData()
        {
            //左边的网格默认查出tb_order表中的所有数据
            string gridView1sql1 = "select orderName from tb_order";
            //右边的网格默认不显示数据
            string gridView1sql2 = "select orderName from tb_order where 1=2";
            gridControl1.DataSource = GetDataSource(gridView1sql1);
            gridControl2.DataSource = GetDataSource(gridView1sql2);}
        }
  private DataTable GetDataSource(string sql)
        {
            SqlDataAdapter da = new SqlDataAdapter(sql, DBConst.DBConnectionString);
            DataTable dt = new System.Data.DataTable();
            da.Fill(dt);
            return dt;
        }

第二步:添加四个方法:

//鼠标拖拽过程事件
        private void gridControl_DragOver(object sender, DragEventArgs e)
        {
            e.Effect = DragDropEffects.Move;
            GridControl grid = sender as GridControl;
            if (grid == null) return;
            GridView view = grid.FocusedView as GridView;
            //GridView如果有分组,则展开所有分组数据
            if (view.GroupCount != 0)
                view.ExpandAllGroups();
        }

        //鼠标按下事件
        private void gridView_MouseDown(object sender, MouseEventArgs e)
        {
            GridView view = sender as GridView;
            downHitInfo = null;
            GridHitInfo hitInfo = view.CalcHitInfo(new Point(e.X, e.Y));//鼠标左键按下去时在GridView中的坐标
            if (Control.ModifierKeys != Keys.None) return;
            if (e.Button == MouseButtons.Left && hitInfo.RowHandle >= 0)
                downHitInfo = hitInfo;
        }

        //鼠标移动事件
        private void gridView_MouseMove(object sender, MouseEventArgs e)
        {
            GridView view = sender as GridView;
            if (e.Button == MouseButtons.Left && downHitInfo != null)//不是左键则无效且鼠标左键按下去时需要在gridview区域中
            {
                Size dragSize = SystemInformation.DragSize;
                Rectangle dragRect = new Rectangle(new Point(downHitInfo.HitPoint.X - dragSize.Width / 2,
                    downHitInfo.HitPoint.Y - dragSize.Height / 2), dragSize);
                if (!dragRect.Contains(new Point(e.X, e.Y)))
                {
                    object row = view.GetRow(downHitInfo.RowHandle);
                    if (row == null) return;
                    view.GridControl.DoDragDrop(row, DragDropEffects.Move);
                    downHitInfo = null;
                    DevExpress.Utils.DXMouseEventArgs.GetMouseArgs(e).Handled = true;
                }
            }
        }
         
        //拖拽完成后事件
        private void gridControl_DragDrop(object sender, DragEventArgs e)
        {
            GridControl grid = sender as GridControl;
            DataTable table = grid.DataSource as DataTable;
            //获取选中行的数据
            DataRow row = ((DataRowView)e.Data.GetData(typeof(DataRowView))).Row;
            if (row != null && table != null && row.Table != table)
            {
                table.ImportRow(row);
                row.Delete();
            }
        }

第三步:为两个GridControl绑定这4个方法

 this.gridControl1.DragDrop += new System.Windows.Forms.DragEventHandler(this.gridControl_DragDrop);
            this.gridControl1.DragOver += new System.Windows.Forms.DragEventHandler(this.gridControl_DragOver);
  this.gridView1.MouseDown += new System.Windows.Forms.MouseEventHandler(this.gridView_MouseDown);
            this.gridView1.MouseMove += new System.Windows.Forms.MouseEventHandler(this.gridView_MouseMove);
  this.gridView2.MouseDown += new System.Windows.Forms.MouseEventHandler(this.gridView_MouseDown);
            this.gridView2.MouseMove += new System.Windows.Forms.MouseEventHandler(this.gridView_MouseMove);
  this.gridControl2.DragDrop += new System.Windows.Forms.DragEventHandler(this.gridControl_DragDrop);
            this.gridControl2.DragOver += new System.Windows.Forms.DragEventHandler(this.gridControl_DragOver);

注意:

如果只需要实现左边的表格向右边的表格拖拽功能,只需要给gridView1添加MouseDown和MouseMove事件,给gridControl2添加DragDrop和DragOver事件

GitHub地址:

https://github.com/xiaoyonglu/DevExpressDemos

### 回答1: Winform+DevExpress分页控件是一种用于Windows桌面应用程序开发的控件,它可以帮助开发者实现数据分页显示的功能。DevExpress是一个知名的UI控件库,它提供了丰富的控件和组件,可以大大提高开发效率和用户体验。分页控件可以帮助用户快速浏览大量数据,同时也可以提高应用程序的性能和响应速度。 ### 回答2: WinForm DevExpress分页控件是一个强大的工具,它使用户能够快速而可靠地管理大量数据。该控件可以在WinForm应用程序中轻松实现常见的数据分页方案,并且具有灵活的布局和样式选项。以下是一些关于这个控件的主要特点和功能: 1. 高度可定制:可以自定义控件的数、页码样式、默认选中颜色等; 2. 支持大数据量:对于海量数据,控件可以极快地将其分页,显示出一页一页数据; 3. 轻松互动和导航:用户可以轻松进分页,并且快速能够找到所需的数据; 4. 灵活的事件和属性:提供了一系列事件和属性,便于用户轻松地自定义控件的为和外观; 5. 查找和过滤功能:控件允许用户按照特定标准进筛选和查找数据; 6. 高度可定制的主题:用户可以自定义主题、颜色和字体等特性,使控件更符合实际的需求。 需要注意的是,WinForm DevExpress分页控件可能会对一些软件开发者提出一些挑战,因此在使用过程中一定要对其进认真学习和测试。不过,如果合理使用,该控件可以大大提高数据管理的效率和质量,为软件开发者带来极大的价值。 ### 回答3: WinForm DevExpress是一种方法,用于创建用户友好的Windows桌面应用程序,包括数据绑定和视觉效果。在WinForm中可以使用许多控件来开发应用程序,例如文本框、按钮、标签、复选框等,这些控件可用于显示数据和收集用户输入。其中一个重要的控件就是分页控件。 分页控件在WinForm应用程序中非常常见,因为它允许用户浏览大量的数据,并按照需要进分页。DevExpress分页控件提供了丰富的功能,可以让用户以非常灵活的方式对分页进定制。 在DevExpress分页控件中,我们可以设置每页显示的记录数,可以选择要显示的页码,还可以自定义分页按钮的外观和为。此外,分页控件还可以根据需要自动调整页面大小,并支持跳转到指定页码。 与其他分页控件相比,DevExpress分页控件具有较高的灵活性和可定制性。通过使用分页控件,我们可以使应用程序更加用户友好,让用户以最高效和最直观的方式来浏览和处理数据
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值