分享
 
 
 

在Pocket PC应用程序中使用DataGrid控件

王朝c#·作者佚名  2006-01-08
窄屏简体版  字體: |||超大  

在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

Conclusion

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的窍门。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有