我在显示/显示Windows窗体的显示和 ShowDialog 方法之间挣扎。
我通常使用show方法而不是ShowDialog
方法。当我不想在 ALT + TAB ToolWindow上显示表单时使用ShowDialog
方法。
ShowDialog
方法显示模型窗口格式,其访问权限比普通窗口格式有限。模型窗口窗体不访问控件的值和已在正常窗口窗体上传递的对象。因此,我们必须在新的表格实例的每次或每次提供新值时,这是一个真实的例子。
//Purchase_Entry having a public method which is calling from form30 as under:
public partial class purchase_Entry : Form
{
public purchase_Entry()
{
InitializeComponent();
}
public void Purchase_Binding()
{
mydgv.Location = new Point(0, 110);
mydgv.RowHeadersVisible = false;
mydgv.Width = panel2.Width;
mydgv.Height = panel2.Height - 220;
mydgv.TabIndex = 4;
string connstr = "server=.;initial catalog=maa;uid=mah;pwd=mah";
SqlConnection con = new SqlConnection(connstr);
con.Open();
string sql = @"select billno,date=convert(varchar,date,103),ledgeraccount,totcts,rround,grosspurchase,taxes,taxamt,totdb,narrat" +
" from depurchasea where companyID=@companyID" +
" and transID=@transID" +
" group by billno,date,ledgeraccount,totcts,rround,grosspurchase,taxes,taxamt,totdb,narrat" +
" order by date,billno";
SqlCommand cmd = new SqlCommand(sql, con);
cmd.Parameters.AddWithValue("companyID", label6.Text);
cmd.Parameters.AddWithValue("transID", textBox5.Text);
SqlDataAdapter dap = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
dap.Fill(ds);
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
textBox2.Text = Convert.ToString(ds.Tables[0].Rows[i]["billno"]);
maskedTextBox1.Text = Convert.ToString(ds.Tables[0].Rows[i]["date"]);
textBox1.Text = Convert.ToString(ds.Tables[0].Rows[i]["ledgeraccount"]);
textBox9.Text = Convert.ToString(ds.Tables[0].Rows[i]["totcts"]);
textBox7.Text = Convert.ToString(ds.Tables[0].Rows[i]["rround"]);
textBox13.Text = Convert.ToString(ds.Tables[0].Rows[i]["grosspurchase"]);
comboBox1.Text = Convert.ToString(ds.Tables[0].Rows[i]["taxes"]);
textBox8.Text = Convert.ToString(ds.Tables[0].Rows[i]["taxamt"]);
textBox6.Text = Convert.ToString(ds.Tables[0].Rows[i]["totdb"]);
textBox3.Text = Convert.ToString(ds.Tables[0].Rows[i]["narrat"]);
}
//mydgv.Columns.Clear();
string mysql = "select srno,particulars,carats,rate,debit from depurchasea" +
" where companyID=@companyID" +
" and transID=@transID";
SqlCommand mycmd = new SqlCommand(mysql, con);
mycmd.Parameters.AddWithValue("companyID", label6.Text);
mycmd.Parameters.AddWithValue("transID", textBox5.Text);
SqlDataAdapter mydap = new SqlDataAdapter(mycmd);
DataSet myds = new DataSet();
mydap.Fill(myds);
mybinding = new BindingSource();
mybinding.DataSource = myds;
mybinding.DataMember = myds.Tables[0].TableName;
mydgv.DataSource = mybinding;
mydgv.Columns[0].HeaderText = "Sr.No.";
mydgv.Columns[1].HeaderText = "Particulars";
mydgv.Columns[2].HeaderText = "Carats";
mydgv.Columns[3].HeaderText = "Rate";
mydgv.Columns[4].HeaderText = "Amount";
mydgv.Columns[0].Width = 50;
mydgv.Columns[1].Width = 500;
mydgv.Columns[4].Width = 100;
mydgv.Columns[2].Width = 100;
mydgv.Columns[3].Width = 100;
mydgv.Columns[2].DefaultCellStyle.Alignment = DataGridViewContentAlignment.BottomRight;
mydgv.Columns[3].DefaultCellStyle.Alignment = DataGridViewContentAlignment.BottomRight;
mydgv.Columns[4].DefaultCellStyle.Alignment = DataGridViewContentAlignment.BottomRight;
mydgv.Columns[2].DefaultCellStyle.Format = "f2";
mydgv.Columns[3].DefaultCellStyle.Format = "f2";
mydgv.Columns[4].DefaultCellStyle.Format = "f2";
mydgv.Columns[4].ReadOnly = true;
int dgvsize = mydgv.Width / 17;
mydgv.Columns[0].Width = dgvsize;
mydgv.Columns[1].Width = dgvsize * 10;
mydgv.Columns[2].Width = dgvsize * 2;
mydgv.Columns[3].Width = dgvsize * 2;
mydgv.Columns[4].Width = dgvsize * 2;
mydgv.Refresh();
if (textBox13.Text != "")
{
decimal res = Convert.ToDecimal(textBox13.Text);
textBox13.Text = res.ToString("f2");
}
}
public partial class Form30 : Form
{
public Form30()
{
InitializeComponent();
}
private void listView1_KeyPress(object sender, KeyPressEventArgs e)
{
else if (textBox2.Text == "Purchase")
{
purchase_Entry pc = new purchase_Entry();
pc.lbl6.Text = pp.Form1.IDD.Text; //companyID
pc.Purchase_Binding() //Calling public method of purchase_entry Class
pc.ShowDialog(this);
pc.textboxKeypress += new purchase_Entry.Action(pc_textboxKeypress);
pc.purkeydown += new purchase_Entry.Action(pc_purkeydown);
}
}
来自 buy_Entry 表单 Show()方法的调用 Purchase_Binding()方法效果非常好,但如果我在 ShowDialog()方法然后它将显示记录但控件的对齐方式已更改。这意味着我必须在 ShowDialog()方法显示的实例上发出每个控件大小,高度,宽度和companyID的新值。
如果是这样,那么驴会为我工作,因为我必须在ShowDialog()
方法上重新设计purchase_Entry。
最好的方法是什么?如果我处理 Show()方法,那么表单将显示在 ALT + TAB ToolWindow ,我不想允许在 ALT + TAB ToolWindow 中显示它。这就是我使用 ShowDialog()方法的原因,它将显示为模型窗口形式,不会在ALT + TAB ToolWindow上显示。
如果我使用ShowDialog()
方法,那么我必须准备好像驴工作一样重新设计它。不是吗?
答案 0 :(得分:1)
尝试更改通话顺序。
private void button1_Click(object sender, EventArgs e)
{
Form2 f2 = new Form2();
f2.moto();
f2.ShowDialog();
}
使用ShowDialog时没有看到moto调用的效果的原因是,ShowDialog会阻止当前正在执行的线程,直到表单关闭,这意味着在表单关闭之前不会调用方法moto。
答案 1 :(得分:0)
Form.ShowDialog以模态模式显示表单。这意味着在打开Form时,Form.ShowDialog下面的代码将永远不会执行。
在您的情况下,如果您的方法取决于ID,则必须在调用f2.moto()之前初始化ID 之前的,例如在ShowDialog之前。
public partial class Form2 : Form
{
public Form2(int id)
{
InitializeComponent();
label1.Text = id.ToString();
}
public void moto()
{
textBox1.Text = "MAHESH";
}
}
private void button1_Click(object sender, EventArgs e)
{
Form2 f2 = new Form2(101);
f2.moto();
f2.ShowDialog();
}
修改强>
如果不使用参数化表单构造函数,则在调用ShowDialog之前还必须初始化Id。
使用Form2类中的公共属性Id:
public partial class Form2 : Form
{
public Form2()
{
InitializeComponent();
}
public void moto()
{
textBox1.Text = "MAHESH";
}
public int Id
{
set {label1.Text = value.ToString();}
}
}
private void button1_Click(object sender, EventArgs e)
{
Form2 f2 = new Form2();
f2.Id = 101;
f2.moto();
f2.ShowDialog();
}
答案 2 :(得分:0)
我希望这可以帮到你
这是你的默认构造函数,根据输入做出更多
public Form2()
{
InitializeComponent();
}
public Form2(int id)
{
InitializeComponent();
if(id == 101)
textBox1.Text = "MAHESH";
}
public Form2(string name)
{
InitializeComponent();
textBox1.Text = name;
}
根据需要拨打电话并传入值,您可以用不同的方法封装进一步处理并拨打电话。
新表单的加载仅在ShowDialog()