在DataGrid中使用下拉式清單方塊和設定焦點

來源:互聯網
上載者:User
datagrid|下拉|下拉式清單 在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等類似的控制項。




相關文章

E-Commerce Solutions

Leverage the same tools powering the Alibaba Ecosystem

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。