У меня есть одна форма, вызывающая метод в другой форме.но метод в другой форме не работает должным образом.
Form2 вызывает main:
private void button1_Click(object sender, EventArgs e)
{
main ma = new main();
ma.AddType(txtName.Text,txtURL.Text,12);
this.Close();
}
main: (добавляет одну строку в xml и перезагружает сетку данныхиз xml)
public void AddType(string name, string url, int interval)
{
string path = Application.StartupPath + @"\sites.xml";
//create new instance of XmlDocument
XmlDocument doc = new XmlDocument();
//load from file
doc.Load(path);
//create node and add value
XmlNode node = doc.CreateNode(XmlNodeType.Element, "site", null);
node.InnerXml = "<Name>"+name+"</Name><URL>"+url+"</URL><Status></Status><Response-Time></Response-Time><Last-Checked></Last-Checked>";
//add to elements collection
doc.DocumentElement.AppendChild(node);
//save back
doc.Save(path);
bwLoadXML.RunWorkerAsync();
}
the bwLoadXML.RunWorkerAsync ();по какой-то причине новый xml не отображается в таблице данных.
Редактировать, вот фоновый рабочий:
/////////////////////////////////
////Populate Grid from XML
/////////////////////////////////
private void bwLoadXML_DoWork(object sender, DoWorkEventArgs e)
{
gridPopulate();
}
private void gridPopulate()
{
DataSet data = new DataSet(); string p = System.IO.Path.Combine(Application.StartupPath, "sites.xml");
data.ReadXml(p);
if (this.dataGrid.InvokeRequired)
{
this.dataGrid.Invoke(new MethodInvoker(delegate
{
this.dataGrid.DataSource = data;
this.dataGrid.DataMember = "site";
}));
}
else
{
this.dataGrid.DataSource = data;
this.dataGrid.DataMember = "site";
}
int i = 0;
foreach (DataGridViewColumn column in this.dataGrid.Columns)
{
if (i != 0)
{
if (column.Name == "Name" || column.Name == "Status" || column.Name == "URL" || column.Name == "Response-Time" || column.Name == "Last-Checked")
{
//column.AutoSizeMode
column.Visible = true;
//column.Width = (int)(dataGrid.Width * .2) + (column.Name.Length / 2)-9;
/*if (column.Name == "URL")
{
ColumnHeader ch = new ColumnHeader();
//ch.
}*/
}
else
{
column.Visible = false;
//dataGrid.Columns[i+1].CellType = new DataGridViewButtonColumn();
//dataGrid.Columns[i+1].HeaderCell.
}
}
i++;
}
if (this.dataGrid.InvokeRequired)
{
this.dataGrid.Invoke(new MethodInvoker(delegate
{
// If column 3 is the checkbox column, we sit it's resize mode to none:
dataGrid.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
// Then we set the width:
dataGrid.Columns[0].Width = 25;
dataGrid.Columns[0].DefaultCellStyle.Padding = System.Windows.Forms.Padding.Empty;
// If column 3 is the checkbox column, we sit it's resize mode to none:
dataGrid.Columns[2].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
// Finally we set the rest of the grid to fill or what ever resizing you need:
dataGrid.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;
}));
}
else
{
// If column 3 is the checkbox column, we sit it's resize mode to none:
dataGrid.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
// Then we set the width:
dataGrid.Columns[0].Width = 25;
dataGrid.Columns[0].DefaultCellStyle.Padding = System.Windows.Forms.Padding.Empty;
// If column 3 is the checkbox column, we sit it's resize mode to none:
dataGrid.Columns[2].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
// Finally we set the rest of the grid to fill or what ever resizing you need:
dataGrid.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;
}
}