`
mmdev
  • 浏览: 13301481 次
  • 性别: Icon_minigender_1
  • 来自: 大连
文章分类
社区版块
存档分类
最新评论

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

阅读更多

<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

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组成:

<?xml:namespace prefix = v ns = "urn:schemas-microsoft-com:vml" /><shapetype id="_x0000_t75" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75" coordsize="21600,21600"><stroke joinstyle="miter"></stroke><formulas><f eqn="if lineDrawn pixelLineWidth 0"></f><f eqn="sum @0 1 0"></f><f eqn="sum 0 0 @1"></f><f eqn="prod @2 1 2"></f><f eqn="prod @3 21600 pixelWidth"></f><f eqn="prod @3 21600 pixelHeight"></f><f eqn="sum @0 0 1"></f><f eqn="prod @6 1 2"></f><f eqn="prod @7 21600 pixelWidth"></f><f eqn="sum @8 21600 0"></f><f eqn="prod @7 21600 pixelHeight"></f><f eqn="sum @10 21600 0"></f></formulas><path o:connecttype="rect" gradientshapeok="t" o:extrusionok="f"></path><lock aspectratio="t" v:ext="edit"></lock></shapetype><shape id="_x0000_i1025" style="WIDTH: 180pt; HEIGHT: 240pt" alt="" type="#_x0000_t75"><img o:href="http://msdn.microsoft.com/library/en-us/dnppc2k3/html/datagrid_control-fig.gif" src="/Develop/ArticleImages/21/21844/CSDN_Dev_Image_2003-10-291436460.gif"><font face="宋体"></font></shape>

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 featuresgrid中可以被支持。编辑就是其中之一。但编辑在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被点击(inEditModeinUpdate被设置为false)时,当前的cell被保存(editCell)。然后,隐藏的TextBox(txtEdit)得到当前cell的内容,重新设置到当前cell的位置,并使其可见(在当前的cell上边)。当编辑完成、其他cell被选择时,事件代码不可用(inUpdateMode设置成true),当被编辑的cellTextBox控件得到后,将新的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的窍门。

分享到:
评论

相关推荐

    vb中datagrid控件的详细使用方法

    总的来说,`DataGrid`控件在VB中提供了强大的数据展示和操作能力,理解并熟练运用它的各种特性,可以极大地提升你的应用程序用户体验和功能性。通过实践和学习,你将能够灵活地应对各种数据呈现和交互的需求。

    VC++中DataGrid控件的使用

    ### VC++中DataGrid控件的使用 #### 一、引言 Microsoft ADODataControl 控件是 ActiveX ...通过这种方式,开发人员可以根据具体的应用场景灵活地控制 DataGrid 控件中列的显示效果,从而提高应用程序的用户体验。

    DataGrid控件用法详解

    在Windows编程领域,DataGrid控件是一个非常关键的组件,特别是在使用VC++进行开发时。这个控件允许程序员创建和展示结构化的数据,通常与数据库交互,为用户提供一种直观的方式来查看和编辑表格形式的数据。本篇...

    MFC DataGrid控件用法详解

    要显示查询结果,首先需要将数据查询结果存储在 Recordset 对象中,然后将其设置为 DataGrid 控件的数据源。代码示例如下: ```cpp CADODatabase m_DBCn; CADORecordset m_Rs; CDataGrid m_ctrlDG; CString ...

    vb DataGrid 控件的使用

    VB中的DataGrid控件是一个非常实用的工具,用于在用户界面中展示和操作数据库...通过理解和掌握这些知识点,开发者能够有效地利用VB中的DataGrid控件创建功能丰富的数据库应用程序,提供用户友好的数据浏览和编辑体验。

    ASP.NET中DataGrid控件应用技巧简述

    ASP.NET中的DataGrid控件是开发Web应用程序时用于展示数据的关键组件,特别是在处理与数据库相关的数据展示场景。熟练掌握DataGrid控件的应用技巧对于任何Web开发者来说都是至关重要的。 DataGrid控件允许以表格的...

    在DataGrid控件中设置单元格的数据显示格式.

    在.NET框架中,DataGrid控件是一个常用的组件,用于显示数据源中的表格数据。它广泛应用于Windows Forms和ASP.NET应用程序中。本节我们将深入探讨如何在DataGrid控件中设置单元格的数据显示格式,以便更好地呈现和...

    Datagrid 控件 及注册 MSDATGRD.OCX

    总的来说,这个压缩包提供了解决方案来在开发环境中使用Datagrid控件。用户只需解压文件,运行注册.bat,就可以在VC或VB项目中使用MSDATGRD.OCX,从而创建具备强大数据管理能力的用户界面。同时,msstdfmt.dll确保了...

    DataGrid控件

    这个控件允许用户在Windows Forms应用程序中显示表格形式的数据,并且提供了多种交互功能,如排序、选择和编辑。本篇文章将深入探讨DataGrid控件的使用、特点以及常见应用场景。 1. **DataGrid控件的创建与绑定** ...

    VC使用ADO Data和DataGrid控件实现遍历、修改、删除、添加.rar

    在VC++中,DataGrid控件通常与ADO结合使用,可以方便地展示数据集中的记录,并允许用户进行交互式的数据操作。 下面我们将逐一探讨如何使用ADO和DataGrid控件实现数据库的基本操作: 1. **遍历数据**:通过创建ADO...

    DataGrid和ADO Data控件的使用

    总结来说,DataGrid和ADO Data控件是Windows应用程序开发中处理数据库数据的关键组件。正确配置和使用这些控件,可以实现灵活的数据展示、筛选和交互,极大地提高了用户体验。通过深入理解它们的工作原理和使用方法...

    VB6.0中DataGrid的应用.doc

    VB6.0中DataGrid的应用详解 DataGrid控件是VB6.0中的一种强大且灵活的控件,能够显示一个Recordset对象的...开发者可以使用DataGrid控件来创建一个数据库应用程序,快速地配置控件,编辑数据和修改控件的外观和行为。

    强化DataGrid控件功能代码

    Windows窗体DataGrid控件是NET 1.0/1.1推出的控件,在VS2005中亦可以继续使用,虽然它在功效方面不如NET 2.0新增的控件DataGridView,但它仍有用武之处,特别是对于已完成的项目中使用了该组件时,没有必要更换它,...

    Microsoft DataGrid控件

    在Windows系统中,ActiveX控件需要注册才能在应用程序中使用。注册过程通常通过命令行工具`regsvr32.exe`完成,这个工具可以将控件注册到系统注册表中,使得其他程序能够识别并调用它。因此,用户需要以管理员权限...

    VC++ DataGrid控件操作TEST源码

    首先,DataGrid控件是Microsoft Visual C++中的一种可视化组件,常用于MFC(Microsoft Foundation Classes)应用程序,用于在窗口上创建一个可滚动的数据表格,以便用户可以查看、编辑和交互与数据库相关的数据。在...

    asp.net-datagrid控件实例

    在ASP.NET中,`DataGrid`控件是一个强大的数据展示工具,它允许开发者以表格的形式展示来自数据库或其他数据源的数据。本实例将深入讲解如何使用`DataGrid`控件连接数据库并展示数据。 1. **DataGrid控件简介** `...

    DataGrid 控件的使用

    本文将详细介绍如何在 VB 中使用 DataGrid 控件,并结合实例说明其与数据库的连接方式。 #### 二、DataGrid 控件的基本概念 DataGrid 控件是一种表格形式的数据展示工具,它可以用来显示记录集(Recordset)中的...

Global site tag (gtag.js) - Google Analytics