分享
 
 
 

在DataGrid中使用下拉列表框和设置焦点

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

在DataGrid中简单使用下拉列表框

作者:Tushar Ameta

翻译:秋枫

在DataGrid中使用下拉列表问题。这篇文章讲了如何在 System.Windows.Forms.DataGrid中切入使用ComboBox控件。不过原文不全,无法调试,在这里为了说清楚点,对原文作了一些修改,整篇文章主要包括三方面的内容。

1. 在DataGrid中加入ComboBox列;

2. 把在DataGrid中的修改保存到对应的网格;

3. 设置DataGrid中网格的焦点。

下面是整个源代码,一些功能可以看注释。

using System;

using System.Drawing;

using System.Collections;

using System.ComponentModel;

using System.Windows.Forms;

using System.Data;

namespace DataGridTest

{

public class Form1 : System.Windows.Forms.Form

{

private System.Windows.Forms.DataGrid dgdFunctionArea;

private DataTable dtblFunctionalArea;

private System.Windows.Forms.Button buttonFocus;

private System.ComponentModel.Container components = null;

public Form1()

{

InitializeComponent();

PopulateGrid();

}

protected override void Dispose( bool disposing )

{

if( disposing )

{

if (components != null)

{

components.Dispose();

}

}

base.Dispose( disposing );

}

#region Windows 窗体设计器生成的代码

private void InitializeComponent()

{

this.dgdFunctionArea = new System.Windows.Forms.DataGrid();

this.buttonFocus = new System.Windows.Forms.Button();

((System.ComponentModel.ISupportInitialize)(this.dgdFunctionArea)).BeginInit();

this.SuspendLayout();

//

// dgdFunctionArea

//

this.dgdFunctionArea.DataMember = "";

this.dgdFunctionArea.HeaderForeColor = System.Drawing.SystemColors.ControlText;

this.dgdFunctionArea.Location = new System.Drawing.Point(4, 8);

this.dgdFunctionArea.Name = "dgdFunctionArea";

this.dgdFunctionArea.Size = new System.Drawing.Size(316, 168);

this.dgdFunctionArea.TabIndex = 0;

//

// buttonFocus

//

this.buttonFocus.Location = new System.Drawing.Point(232, 188);

this.buttonFocus.Name = "buttonFocus";

this.buttonFocus.Size = new System.Drawing.Size(84, 23);

this.buttonFocus.TabIndex = 1;

this.buttonFocus.Text = "获取焦点";

this.buttonFocus.Click += new System.EventHandler(this.buttonFocus_Click);

//

// Form1

//

this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);

this.ClientSize = new System.Drawing.Size(332, 217);

this.Controls.Add(this.buttonFocus);

this.Controls.Add(this.dgdFunctionArea);

this.Name = "Form1";

this.Text = "Form1";

((System.ComponentModel.ISupportInitialize)(this.dgdFunctionArea)).EndInit();

this.ResumeLayout(false);

}

#endregion

/// <summary>

/// 应用程序的主入口点。

/// </summary>

[STAThread]

static void Main()

{

Application.Run(new Form1());

}

//初始化DataGrid

private void PopulateGrid()

{

//创建一个DataTable对象,包括四列,前三列为String,最后一列为Boolean。

dtblFunctionalArea = new DataTable ("FunctionArea");

string[] arrstrFunctionalArea = new string [3]{"Functional Area","Min","Max"};

DataColumn dtCol = null;

//创建String列

for(int i=0; i< 3;i++)

{

dtCol = new DataColumn(arrstrFunctionalArea[i]);

dtCol.DataType = Type.GetType("System.String");

dtCol.DefaultValue = "";

dtblFunctionalArea.Columns.Add(dtCol);

}

//创建Boolean列,用CheckedBox来显示。

DataColumn dtcCheck = new DataColumn("IsMandatory");

dtcCheck.DataType = System.Type.GetType("System.Boolean");

dtcCheck.DefaultValue = false;

dtblFunctionalArea.Columns.Add(dtcCheck);

//把表绑定到DataGrid

dgdFunctionArea.DataSource = dtblFunctionalArea;

//为DataGrid加载DataGridTableStyle样式

if(!dgdFunctionArea.TableStyles.Contains("FunctionArea"))

{

DataGridTableStyle dgdtblStyle = new DataGridTableStyle();

dgdtblStyle.MappingName = dtblFunctionalArea.TableName;

dgdFunctionArea.TableStyles.Add(dgdtblStyle);

dgdtblStyle.RowHeadersVisible = false;

dgdtblStyle.HeaderBackColor = Color.LightSteelBlue;

dgdtblStyle.AllowSorting = false;

dgdtblStyle.HeaderBackColor = Color.FromArgb(8,36,107);

dgdtblStyle.RowHeadersVisible = false;

dgdtblStyle.HeaderForeColor = Color.White;

dgdtblStyle.HeaderFont = new System.Drawing.Font("Microsoft Sans Serif", 9F,

System.Drawing.FontStyle.Bold,

System.Drawing.GraphicsUnit.Point, ((System.Byte)(0)));

dgdtblStyle.GridLineColor = Color.DarkGray;

dgdtblStyle.PreferredRowHeight = 22;

dgdFunctionArea.BackgroundColor = Color.White;

//设置列的宽度

GridColumnStylesCollection colStyle = dgdFunctionArea.TableStyles[0].GridColumnStyles;

colStyle[0].Width = 100;

colStyle[1].Width = 50;

colStyle[2].Width = 50;

colStyle[3].Width = 80;

}

DataGridTextBoxColumn dgtb = (DataGridTextBoxColumn)dgdFunctionArea.TableStyles[0].GridColumnStyles[0];

ComboBox cmbFunctionArea = new ComboBox();

cmbFunctionArea.Items.AddRange(new object[]{"选项一","选项二","选项三"});

cmbFunctionArea.Cursor = Cursors.Arrow;

cmbFunctionArea.DropDownStyle= ComboBoxStyle.DropDownList;

cmbFunctionArea.Dock = DockStyle.Fill;

//在选定项发生更改并且提交了该更改后发生

cmbFunctionArea.SelectionChangeCommitted += new EventHandler(cmbFunctionArea_SelectionChangeCommitted);

//把ComboBox添加到DataGridTableStyle的第一列

dgtb.TextBox.Controls.Add(cmbFunctionArea);

}

//设置焦点模拟

private void GetFocus(int row,int col)

{

//先把焦点移动到DataGrid

this.dgdFunctionArea.Focus();

//把焦点移动到DataGridCell

DataGridCell dgc = new DataGridCell(row,col);

this.dgdFunctionArea.CurrentCell = dgc;

DataGridTextBoxColumn dgtb = (DataGridTextBoxColumn)dgdFunctionArea.TableStyles[0].GridColumnStyles[col];

//设置焦点

dgtb.TextBox.Focus();

}

//把Combobox上修改的数据提交到当前的网格

private void cmbFunctionArea_SelectionChangeCommitted(object sender, EventArgs e)

{

this.dgdFunctionArea[this.dgdFunctionArea.CurrentCell] = ((ComboBox)sender).SelectedItem.ToString();

}

//设置新的焦点

private void buttonFocus_Click(object sender, System.EventArgs e)

{

//焦点模拟,这里设置第三行第一列

GetFocus(2,0);

}

}

}

下面是测试界面:

总结,这里是通过DataGridTextBoxColumn.TextBox.Controls.Add方法实现在列中添加ComboBox控件;对于数据的保存是使用ComboBox.SelectionChangeCommitted事件来完成;设置焦点是通过DataGridTextBoxColumn.TextBox.Focus方法来实现。另外通过这个方法也可以添加DateTimePicker等类似的控件。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
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- 王朝網路 版權所有