提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|使用教程|编辑:龚雪|2014-03-18 11:50:36.000|阅读 7289 次
概述:本文讲解的是把DevExpress GridControl中的数据行拖拽到richEditControl里,DevExpress其他控件的拖拽操作也可以类似的进行处理。
#慧都22周年庆大促·界面/图表报表/文档/IDE/IOT/测试等千款热门软控件火热促销中>>
GridControl的数据源只有两列的DataTable,列分别为Code和Caption。
开始拖拽的思路是:在GridControl的MouseDown以及MoseMove里处理开始拖拽,在richEditControl里执行并且结束拖拽。
以下为GridControl的MouseDown以及MouseMove方法:
DevExpress.XtraGrid.Views.Grid.ViewInfo.GridHitInfo m_DownHitInfo_TuXing = null;
private void gv_TuXing_MouseDown(object sender, MouseEventArgs e)
{
DevExpress.XtraGrid.Views.Grid.ViewInfo.GridHitInfo hi = this.gv_TuXing.CalcHitInfo(new Point(e.X, e.Y));
int iMouseRowHandle = hi.RowHandle;
if (iMouseRowHandle >= 0 && e.Button == MouseButtons.Left)
{
m_DownHitInfo_TuXing = hi;
}
}
private void gv_TuXing_MouseMove(object sender, MouseEventArgs e)
{
GridView view = sender as GridView;
if (e.Button == MouseButtons.Left && m_DownHitInfo_TuXing != null)
{
Size dragSize = SystemInformation.DragSize;
Rectangle dragRect = new Rectangle(new Point(m_DownHitInfo_TuXing.HitPoint.X - dragSize.Width / 2, m_DownHitInfo_TuXing.HitPoint.Y - dragSize.Height / 2), dragSize);
//当鼠标离开原来的控件区域之后才显示拖拽效果
if (!dragRect.Contains(new Point(e.X, e.Y)))
{
m_TmrDragDropCanRun = true;
tmr_DragDrop.Start();
DataRow row = view.GetDataRow(m_DownHitInfo_TuXing.RowHandle);
Model.DragDropData modelData = new Model.DragDropData();
modelData.Sender = gc_TuXing;
modelData.Data = row;
view.GridControl.DoDragDrop(modelData, DragDropEffects.Move);
m_DownHitInfo_TuXing = null;
DevExpress.Utils.DXMouseEventArgs.GetMouseArgs(e).Handled = true;
}
}
}
下面这个判断保证了只有当鼠标移出GridControl的范围之后才会触发GridControl的DoDragDrop。
if (!dragRect.Contains(new Point(e.X, e.Y)))
如果你按住鼠标左键不放,都是处于DragDrop状态,这时候有个神奇的事情,所有控件的MouseMove方法都失效了。
我们来处理一下richEditControl的接收,这里要处理两个方法DragOver以及DragDrop,DragOver在鼠标进入richEditControl区域时改变鼠标样式,DragDrop处理在richEditControl上释放鼠标时处理以及结束拖拽。
private void rec_EMR_DragOver(object sender, DragEventArgs e)
{
rec_EMR.Select();
if (e.Data.GetDataPresent(typeof(Model.DragDropData)))
e.Effect = DragDropEffects.Move;
else
e.Effect = DragDropEffects.None;
}
private void rec_EMR_DragDrop(object sender, DragEventArgs e)
{
try
{
m_TmrDragDropCanRun = false;
tmr_DragDrop.Stop();
Model.DragDropData modelData = (Model.DragDropData)e.Data.GetData(typeof(Model.DragDropData));
switch (modelData.Sender.Name)
{
case "gc_TuXing":
//插入图形
string strImageID = ((DataRow)modelData.Data)["Code"].ToString();
Image imgInsert = m_EMR_BLL.EMR_Image_Get_By_Id(strImageID);
rec_EMR.Document.InsertImage(rec_EMR.Document.CaretPosition, imgInsert);
break;
default:
break;
}
}
catch (Exception ex)
{
XtraMessageBox.Show(ex.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
finally
{
}
}
其中的Model.DragDropData是我自行封装的数据类,两个属性分别对应数据的发送者以及数据:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ElectronicMedicalRecords.Model
{
public class DragDropData
{
public System.Windows.Forms.Control Sender { get; set; }
public object Data { get; set; }
}
}
那么通过数据的发送者就可以判断接收的是什么类型的数据以便对具体的情况进行具体的处理。
最后因为拖拽事件过程中所有MouseMove事件都失效,为了解决在richEditControl中不能进行插入符跟随鼠标定位的问题,在界面上添加了一个Timer,每0.5秒进行一次插入符定位处理以实现控制拖拽数据插入位置的问题,代码如下:
private bool m_TmrDragDropCanRun = false;
private void tmr_DragDrop_Tick(object sender, EventArgs e)
{
//在拖拽时定位鼠标坐标
if (m_TmrDragDropCanRun)
{
tmr_DragDrop.Stop();
Point pMouse = Cursor.Position;
Point pEMR_Edit = this.rec_EMR.PointToScreen(rec_EMR.Location);
Point pTruePoint = new Point(pMouse.X - pEMR_Edit.X, pMouse.Y - pEMR_Edit.Y);
Point docPoint = Units.PixelsToDocuments(pTruePoint,
rec_EMR.DpiX, rec_EMR.DpiY);
DevExpress.XtraRichEdit.API.Native.DocumentPosition pos = rec_EMR.GetPositionFromPoint(docPoint);
if (pos != null)
{
bsi_BianJiLeiXing.Caption = pos.ToString();
rec_EMR.Document.CaretPosition = pos;
}
else bsi_BianJiLeiXing.Caption = "Mouse:(" + pMouse.X + "|" + pMouse.Y + " E:(" + pTruePoint.X + "|" + pTruePoint.Y + ")";
if (m_TmrDragDropCanRun)
{
tmr_DragDrop.Start();
}
}
else
{
tmr_DragDrop.Stop();
}
}
转载自//blog.csdn.net/a237428367/article/details/7888776
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@hmdbvip.cn
文章转载自:慧都控件网



在嵌入式软件测试领域,对交叉编译代码进行单元测试是一大挑战。Parasoft C/C++test作为专业的C/C++测试工具,能够与劳特巴赫Trace32调试器深度集成。下面会详细介绍如何在C++test中配置Trace32调试器,实现对PowerPC架构程序的单元测试,涵盖环境设置、项目导入到测试执行的全过程。
本文将为大家介绍如何使用DevExpress WinForms数据网格控件实现摘要文本的格式化,欢迎下载最新版组件体验!
Parasoft C/C++test作为一款功能强大的自动化测试工具,为嵌入式开发提供了全面的测试解决方案。特别是在CCS开发环境中,C++test能够无缝集成,为F2812等DSP项目提供专业的单元测试支持。下面将介绍如何在CCS3环境下配置和使用C++test进行F2812项目的单元测试。
在嵌入式开发中,尤其是基于ARM架构的安全关键领域,单元测试是验证代码在目标硬件上运行时行为正确性的关键环节,对于保障最终产品的可靠性至关重要。下面将介绍如何利用Parasoft C/C++test开展单元测试,包括配置、执行及解决可能遇到的许可证问题,完成从静态检查到动态运行的完整测试闭环。
相关产品
优秀的界面控件开发包,帮助企业构建卓越应用!
DevExpress WinForms Subscription为Windows Forms平台创建具有影响力的业务解决方案,高性价比WinForms界面控件套包。
DevExpress DXperience Subscription高性价比的企业级.NET用户界面套包,助力企业创建卓越应用!
DevExpress ASP.NET Controls多款重量级ASP.NET用户界面组件套包,让您快速开发出完美、强大的应用程序!
最新文章 MORE
永利最大(官方)网站相关的文章 MORE
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@hmdbvip.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
永利最大(官方)网站