没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|其它|编辑:郝浩|2005-04-05 10:30:00.000|阅读 1568 次
概述:
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
在Pocket PC应用程序中使用DataGrid控件
Christian Forsberg
businessanyplace.net
September 2003
Applies to:
Microsoft® .NET Compact Framework 1.0
Microsoft Visual Studio® .NET 2003
摘要:学习如何在你的Pocket PC应用程序中如何有效地使用DataGrid控件进行数据查看和更新。这篇文章将解释,为什么这是重要的,并向你演示如何做。
Download datagrid_control.exe
Contents
Table Data
The DataGrid Control
DataGrid Sample
Code Walkthrough
Code Walkthrough
Table Data
在实现企业级Pocket
PC应用程序时,几乎总是需要以表格的方式浏览数据。大多数通用的方案是你输入许多查找标准,得到作为一个表的查找结果集,并从中搜索或选择。一个表格是一个非常直接的显示数据的途径,可以被你直接使用与屏幕空间中。
The DataGrid Control
包括在Microsoft® Visual Studio® .NET 2003中的DataGrid控件是一个强大的控件,使你能够以多种方式查看数据。这个控件可以被绑定到一个DataTable,DataView,ArrayList或者任何其他支持IlistSource或者Ilist接口的对象中。
让我们来看DataGrid控件是如何被用于一个Pocket PC应用程序实例的。
DataGrid Sample
这个Pocket PC的应用程序实例使用Visual Studio .NET 2003, C#, 和 Microsoft .NET Compact
Framework 创建。它将演示如何使用DataGrid控件查看并更新数据。这个程序由一个form组成:
Figure 1. DataGrid sample
这个实例开始时载入订单表(一个来自Northwind sample database的原始订单表的子集)到一个grid中,然后使用多种column
style来创建一个好看的界面。点击column header可以对每一个column进行排序,再点击排序后的column header可以在升序和降序间切换。
一个非常好的功能是grid中的每一个cell都是可编辑的。当一个cell被点击并获得输入焦点时,cell中的值可以被更新(见图一)。当其他cell被选择时,被编辑过的cell被更新,新的cell变为可编辑。注意,当一个cell得到输入焦点,软键盘(SIP)是被自动激活(弹出)。一个可能的增进是例子可以拖动被选择的cell到可见,当它被SIP覆盖的时候。
现在,让我们看一下代码是如何实现的。
Code Walkthrough
在实例代码中,DataGrid控件被命名为grdOrders。将订单表(被存成XML文件)加载到DataGrid控件,你只需要下面的代码:
DataSet ds = new DataSet(); ds.ReadXml(@"\Program Files\DGrid\orders.xml"); grdOrders.DataSource = ds.Tables[0]; |
事实上,如果你只做了这些,那么将得到一个非常简单的grid,每个column header上将会显示表字段的名字。为了让grid看上去更好,使用table
styles。一个table style可以包含多种table
styles——你想在grid中查看每个column。在这个例子中,columns包括订购信息和收货人姓名。下面的代码设置状态:
DataGridTableStyle ts = new DataGridTableStyle(); ts.MappingName = "Order"; // Order date column style DataGridColumnStyle orderDate = new DataGridTextBoxColumn(); orderDate.MappingName = "OrderDate"; orderDate.HeaderText = "Date"; ts.GridColumnStyles.Add(orderDate); // Shipping name column style DataGridColumnStyle shipName = new DataGridTextBoxColumn(); shipName.MappingName = "ShipName"; shipName.HeaderText = "Customer"; shipName.Width = this.Width - orderDate.Width - 37; ts.GridColumnStyles.Add(shipName); grdOrders.TableStyles.Add(ts); |
每个column style(DataGridColumnStyle)设置一个表字段名称映射到(MappingName property),header
text用于显示(HeaderText property),并自定义column宽度(Width property)。两个column
styles被加入到table style中,最后将table style加入到DataGrid控件(grdOrders)中。在这个例子里styles是被代码创建的,但是styles同样可以在forms
designer中被创建。
当这个grid看上去很好时,有许多common features在grid中可以被支持。编辑就是其中之一。但编辑在DataGrid控件中不是被自动支持的,这就需要手工实现。一种方法就是使用一个隐藏的TextBox控件,当一个cell被选中时显示,当编辑结束时隐藏。这就需要你声明一些变量:
private DataGridCell editCell; private bool inEditMode = false; private bool inUpdateMode = false; |
我们需要获取哪个cell被编辑激活(editCell),这个cell是否在编辑状态(inEditMode),和我们是否正在更新一个cell(inUpdateMode).
控制编辑代码如下:
private void grdOrders_CurrentCellChanged(object sender, System.EventArgs e) { if (!inUpdateMode) { if (inEditMode && !grdOrders.CurrentCell.Equals(editCell)) { // Update edited cell inUpdateMode = true; grdOrders.Visible = false; DataGridCell currentCell = grdOrders.CurrentCell; grdOrders[editCell.RowNumber, editCell.ColumnNumber] = txtEdit.Text; grdOrders.CurrentCell = currentCell; grdOrders.Visible = true; inUpdateMode = false; txtEdit.Visible = false; inEditMode = false; } // Enter edit mode editCell = grdOrders.CurrentCell; txtEdit.Text = (string)grdOrders[editCell.RowNumber, editCell.ColumnNumber]; Rectangle cellPos = grdOrders.GetCellBounds(editCell.RowNumber, editCell.ColumnNumber); txtEdit.Left = cellPos.Left - 1; txtEdit.Top = cellPos.Top + grdOrders.Top - 1; txtEdit.Width = cellPos.Width + 2; txtEdit.Height = cellPos.Height + 2; txtEdit.Visible = true; inEditMode = true; } } |
当一个cell被点击(inEditMode和inUpdate被设置为false)时,当前的cell被保存(editCell)。然后,隐藏的TextBox(txtEdit)得到当前cell的内容,重新设置到当前cell的位置,并使其可见(在当前的cell上边)。当编辑完成、其他cell被选择时,事件代码不可用(inUpdateMode设置成true),当被编辑的cell从TextBox控件得到后,将新的cell保存(currentCell)。在update过程中,grid没有被update(Visible设置成false),当update完成TextBox被重新隐藏。
其他的common grid feature是通过点击column header进行排序。代码如下:
private void grdOrders_MouseUp(object sender, System.Windows.Forms.MouseEventArgs e) { DataGrid.HitTestInfo hitTest = grdOrders.HitTest(e.X, e.Y); if (hitTest.Type == DataGrid.HitTestType.ColumnHeader) { // Exit edit mode txtEdit.Visible = false; inEditMode = false; // Sort tapped column DataTable dataTable = (DataTable)grdOrders.DataSource; DataView dataView = dataTable.DefaultView; string columnName = dataTable.Columns[hitTest.Column].ColumnName; if (dataView.Sort == columnName) dataView.Sort = columnName + " DESC"; else dataView.Sort = columnName; } } |
如果header被点击,第一件事是确保任何当前cell的编辑被取消。然后一个DataView被创建并通过点击的column排序。如果一个column再次得到点击事件而排序顺序将被改成递减。后来的点击将使排序在递增和递减间切换,直到其他的column被点击。
Conclusion
DataGrid控件是一个查看(然后是编辑)数据的强大工具,用于你的Pocket
PC应用程序。这个控件提供多样性的features,而且这篇文章包含一些有趣的特性:数据绑定,grid内编辑,排序。你的下一步是在这个例子上做一些深层次的开发,探索这个控件中更多更cool的窍门。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号