Datagirdview and tabcontrol issue
本文关键字:issue tabcontrol and Datagirdview | 更新日期: 2023-09-27 18:25:10
我在winforms.net4应用程序中遇到了一个奇怪的行为。我有一个带有两个选项卡页的选项卡控件的表单,用户在选项卡页1上选择数据并单击GO按钮,有一个dataGridView控件绑定到用户选择的结果(一个数据表)。在我设置datagridview的数据源之后,我在网格数据源的顶部(0索引)添加一行,然后在该行上应用一些格式(datagridview.rows[0])。
我可以在调试器中看到我的格式应用于行,但一旦选项卡选择代码运行,我的行格式(isFrozen、BackColor等)就消失了。
当我首先选择选项卡页面,然后绑定网格和格式化的集合数据源时,它工作得很好。
只有新添加的行失去了格式,我有一个类似的应用程序,我在其中添加了这样的行,但它运行得很好,在当前应用程序中,我使用的是backgroundWorker,并从RunWorkerCompleted运行此代码,而在上一个应用程序中我没有使用backgroundWorker。
以下是代码
void bw_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (!e.Cancelled && e.Error == null)
{
if (((DataTable)e.Result).Rows.Count > 0)
{
//tabControl1.SelectTab(tabPage2); if I call from here then row formatting retains
grdDistProcessing.DataSource = ((DataTable)e.Result);
formatGrid();
loadStoresGrid();
AddTotalsRowInEnd();
SetTotalsOfTotalRow();
tabControl1.SelectTab(tabPage2);
}
}
this.tsStatus.Text = string.Empty;
}
这里是AddTotalsRowInEnd方法:
private void AddTotalsRowInEnd()
{
Font f = new System.Drawing.Font("Arial", 8, FontStyle.Bold);
DataRow dr = ((DataTable)grdDistProcessing.DataSource).NewRow();
dr.ItemArray = ((DataTable)grdDistProcessing.DataSource).Rows[0].ItemArray;
dr["Itemlookupcode"] = "Grand Totals";
dr["Size"] = "";
dr["COLORS"] = "";
dr["DESCRIPTIONS"] = "";
((DataTable)grdDistProcessing.DataSource).Rows.InsertAt(dr, 0);
grdDistProcessing.Rows[0].Frozen = true;
grdDistProcessing.Rows[0].DefaultCellStyle.BackColor = Color.BurlyWood;
grdDistProcessing.Rows[0].DefaultCellStyle.ForeColor = Color.Black;
grdDistProcessing.Rows[0].DefaultCellStyle.Font = f;
grdDistProcessing.Rows[0].ReadOnly = true;
grdDistProcessing.Refresh();
}
这是我的DoWork:
void bw_DoWork(object sender, DoWorkEventArgs e)
{
try
{
BackgroundWorker bWorkder = sender as BackgroundWorker;
DistVariablesTransfer dtr = e.Argument as DistVariablesTransfer;
bWorkder.ReportProgress(10);
cProcess pro = new cProcess();
e.Result = pro.loadDistribution(dtr.pWarehouseID, dtr.pStores, dtr.pStyle, dtr.pColor, dtr.pSize, dtr.pDateFrom, dtr.pDateTo, dtr.pIncOrdQtyForSrc, dtr.PCheckDestinationTranferOut);
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, this.Text, MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
不用做:
grdDistProcessing.Rows[0].DefaultCellStyle.BackColor = Color.BurlyWood;
grdDistProcessing.Rows[0].DefaultCellStyle.ForeColor = Color.Black;
将CellFormatting事件(显示类别)用于grdDistProcessing,如下所示:
private void grdDistProcessing_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
{
e.CellStyle.BackColor = Color.BurlyWood;
e.CellStyle.ForeColor = Color.Black;
}
它也应该渲染得更快。