4

グループボックスを動的に作成しようとしていますが、これらの GB はチェックボックスを選択すると作成されます。

つまり、1 番目の CB を選択すると 5 つのチェック ボックスがあり、次に 1 GB と他の動的チェックボックスが作成され、3 番目のチェックを選択すると、別の GB が作成され、他のいくつかのチェックボックスが追加されます。このために、設計時にすでに作成されている固定グループボックスの動的チェックボックスを作成できるこのコードを試しています。

私のシナリオは - 5 つのブランチに複数のバッチがあります。これで、ユーザーは動的にチェックボックスからブランチを選択し、それに基づいて各ブランチのグループボックスに btaches が表示されます。Branch1 Branch2 Branch3 Branch4 Branch5 ユーザーが 3 番目と 5 番目のブランチを選択した場合、GB1 は Branch3 のバッチを表示し、GB2 は Branch5 のバッチを表示します コードは次のとおりです -

private void RO_SelectedIndexChanged(object sender, EventArgs e)
    {
        groupBox1.Controls.Clear();
        String m = RO.SelectedItem.ToString();
        Console.WriteLine(m);
        aCommand2 = new OleDbCommand("select * from branch_tbl,region_tbl where branch_tbl.region_id=region_tbl.region_id and region_tbl.region_name LIKE '"+m +"'", main_connection);
        aAdapter2 = new OleDbDataAdapter(aCommand2);
        ds2 = new DataSet();
        aAdapter2.Fill(ds2, "app_info");
        ds2.Tables[0].Constraints.Add("pk_bno", ds2.Tables[0].Columns[0], true);
        int bran_count = ds2.Tables[0].Rows.Count;
        Console.WriteLine(bran_count);
        checkBox = new System.Windows.Forms.CheckBox[bran_count];
        for (int i = 0; i < bran_count; ++i)
        {
            checkBox[i] = new CheckBox();
            checkBox[i].Name = "radio" + Convert.ToString(i);
            checkBox[i].Text = ds2.Tables[0].Rows[i][2].ToString();
            checkBox[i].Location = new System.Drawing.Point(125 * i, 15);
            groupBox1.Controls.Add(checkBox[i]);
            checkBox[i].CheckStateChanged += new System.EventHandler(CheckBoxCheckedChanged);
        }
    }
    int count = 1;
    int position = 1;
    //Code for handling event when branch check box is selected or unselected
    private void CheckBoxCheckedChanged(object sender, EventArgs e)
    {
        CheckBox c = (CheckBox)sender;
        //Label myLabel;
        String str = null;
        if (c.Checked == true)
        {
            str = c.Text;               
            aCommand3 = new OleDbCommand("select * from batch_tbl where batch_branch LIKE '" + str + "'", main_connection);
            aAdapter3 = new OleDbDataAdapter(aCommand3);
            ds3 = new DataSet();
            aAdapter3.Fill(ds3, "app_info");
            ds3.Tables[0].Constraints.Add("pk_bno", ds3.Tables[0].Columns[0], true);
            int batch_count = ds3.Tables[0].Rows.Count;
            //filling the groupbox with batch code by generating dynamic checkboxes
            for (int i = 0; i < batch_count; ++i)
            {
                checkBox[i] = new CheckBox();
                checkBox[i].Name = "check" + Convert.ToString(i);
                checkBox[i].Text = ds3.Tables[0].Rows[i][1].ToString();
                Console.WriteLine(checkBox[i].Text);
                checkBox[i].Location = new System.Drawing.Point(104*position, 30);
                groupBox2.Text = c.Text; 
                groupBox2.Controls.Add(checkBox[i]);
                position++;
                count++;
            }
        }
        else
        {
            count--;
            this.Controls.RemoveByKey("lbl" + c.Name);
            this.Update();
        }
    } 

このコードは非常に優れていますが、select を使用するブランチ CB の数がわからないので、ブランチ チェックボックスの選択時に実行時に GB を生成する必要があるため、設計時に選択したブランチごとに GB を配置するにはどうすればよいですか。

4

1 に答える 1

2

問題を考えた後、私は問題を解決しました。動的チェックボックスを生成するために行ったことを実行しました。ここにコードがあります

     private void RO_SelectedIndexChanged(object sender, EventArgs e)
    {
        groupBox1.Controls.Clear();
        String m = RO.SelectedItem.ToString();
        Console.WriteLine(m);
        aCommand2 = new OleDbCommand("select * from branch_tbl,region_tbl where branch_tbl.region_id=region_tbl.region_id and region_tbl.region_name LIKE '" + m + "'", main_connection);
        aAdapter2 = new OleDbDataAdapter(aCommand2);
        ds2 = new DataSet();
        aAdapter2.Fill(ds2, "app_info");
        ds2.Tables[0].Constraints.Add("pk_bno", ds2.Tables[0].Columns[0], true);
        int bran_count = ds2.Tables[0].Rows.Count;
        Console.WriteLine(bran_count);
        checkBox = new CheckBox[bran_count];

        for (int i = 0; i < bran_count; ++i)
        {
            checkBox[i] = new CheckBox();
            checkBox[i].Name = "radio" + Convert.ToString(i);
            checkBox[i].Text = ds2.Tables[0].Rows[i][2].ToString();
            checkBox[i].Location = new System.Drawing.Point(125 * i, 15);
            groupBox1.Controls.Add(checkBox[i]);
            checkBox[i].CheckStateChanged += new System.EventHandler(CheckBoxCheckedChanged);
        }
        gpBox=new GroupBox[bran_count];
    }
   String str = null;
   int count = 1;
   int gpcount = 1;
   int position = 1;
   int gpposition = 110;
    //Code for handling event when branch check box is selected or unselected

    private void CheckBoxCheckedChanged(object sender, EventArgs e)
    {
        CheckBox c = (CheckBox)sender;
        //Label myLabel;
        String str = null;
        if (c.Checked == true)
        {
            str = c.Text;
            gpBox[gpcount] = new GroupBox();
            gpBox[gpcount].Name = "gpBox" + Convert.ToString(count);
            gpBox[gpcount].Text = str;
            gpBox[gpcount].Location = new Point(5, gpposition);
            gpBox[gpcount].AutoSize = true;
            this.Controls.Add(gpBox[gpcount]);

            aCommand3 = new OleDbCommand("select * from batch_tbl where batch_branch LIKE '" + str + "'", main_connection);
            aAdapter3 = new OleDbDataAdapter(aCommand3);
            ds3 = new DataSet();
            aAdapter3.Fill(ds3, "app_info");
            ds3.Tables[0].Constraints.Add("pk_bno", ds3.Tables[0].Columns[0], true);
            int batch_count = ds3.Tables[0].Rows.Count;
            //filling the groupbox with batch code by generating dynamic checkboxes
            for (int i = 0; i < batch_count; ++i)
            {
                checkBox[i] = new CheckBox();
                checkBox[i].Name = "check" + Convert.ToString(i);
                checkBox[i].Text = ds3.Tables[0].Rows[i][1].ToString();
                Console.WriteLine(checkBox[i].Text);
                checkBox[i].Location = new System.Drawing.Point(104 * position, 30);
                gpBox[gpcount].Controls.Add(checkBox[i]);
                position++;
                count++;
            }
            position = 1;
            gpposition += 100;
        }
        else
        {
            count--;
            this.Controls.RemoveByKey("lbl" + c.Name);
            this.Update();
        }
    }
于 2013-05-13T04:41:39.910 に答える