J'essaie de créer un éditeur SQL graphique de sortes - mais je n'aime pas les visuels d'une table et j'essaie d'ajouter plus interactivité (glisser/déposer, etc).C# Formulaire Windows: Boucle dans TextBoxes dynamiquement créé et vérifier si le texte a changé
J'ai parcouru et créé des panneaux basés sur chaque enregistrement et ajouté des zones de texte à chaque panneau en fonction de chaque enregistrement de ma table. Ce que je suis bloqué maintenant est le concept de bouclage à travers les contrôles créés dynamiquement et de vérifier leur état ou d'interagir avec eux.
S'il vous plaît laissez-moi savoir si vous voyez des problèmes avec la façon dont je structurer cela.
Mon code est le suivant:
code qui génère les panneaux:
private void comboBox1_SelectedIndexChanged_1(object sender, EventArgs e)
{
groupBox1.Controls.Clear();
string pDBString = null;
SqlConnection cnn;
pDBString = "Data Source=localhost\\" + Form1.host + ";Initial Catalog=" + Form1.db + ";Integrated Security=SSPI;";
cnn = new SqlConnection(pDBString);
string sqlForProps = "select * from PROPS where user_id_txt ='" + comboBox1.SelectedItem.ToString() + "'";
try
{
using (cnn)
{
cnn.Open();
SqlCommand cmd = new SqlCommand(sqlForProps, cnn);
SqlDataReader sqlReader = cmd.ExecuteReader();
int x = 0;
int count = 0;
while (sqlReader.Read())
{
Panel panel = new System.Windows.Forms.Panel();
panel.BorderStyle = System.Windows.Forms.BorderStyle.Fixed3D;
x += 30;
panel.Location = new System.Drawing.Point(3, x);
panel.Name = "panel" + count;
panel.Size = new System.Drawing.Size(519, 30);
panel.TabIndex = 3;
PropsPanels.Add(panel);
groupBox1.Controls.Add(panel);
TextBox textbox = new System.Windows.Forms.TextBox();
panel.Controls.Add(textbox);
textbox.Location = new System.Drawing.Point(1, 3);
textbox.Name = "textBox" + count;
textbox.Size = new System.Drawing.Size(100, 20);
textbox.TabIndex = 4;
textbox.Text = sqlReader["USER_ID_TXT"].ToString();
TextBox textboxAM = new System.Windows.Forms.TextBox();
panel.Controls.Add(textboxAM);
textboxAM.Location = new System.Drawing.Point(126, 3);
textboxAM.Name = "textBoxAM" + count;
textboxAM.Size = new System.Drawing.Size(100, 20);
textboxAM.TabIndex = 4;
textboxAM.Text = sqlReader["PROP_TXT"].ToString();
TextBox textboxAMSet = new System.Windows.Forms.TextBox();
panel.Controls.Add(textboxAMSet);
textboxAMSet.Location = new System.Drawing.Point(232, 3);
textboxAMSet.Name = "textBoxAM" + count;
textboxAMSet.Size = new System.Drawing.Size(100, 20);
textboxAMSet.TabIndex = 4;
textboxAMSet.Text = sqlReader["VAL_TXT"].ToString();
count++;
}
sqlReader.Close();
cnn.Close();
}
}
catch (Exception ex)
{
MessageBox.Show("Can not open connection !");
}
}
Le code qui est censé être vérifier les panneaux:
public AMMain()
{
InitializeComponent();
string pDBString = null;
SqlConnection cnn;
pDBString = "Data Source=US7-AHACKETT\\SQLEXPRESS;Initial Catalog=OrchestroConfigurationDB;Integrated Security=SSPI;";
MessageBox.Show(pDBString);
cnn = new SqlConnection(pDBString);
try
{
using (cnn)
{
SqlCommand sqlForUserList = new SqlCommand("select UserName from users a join Company b on a.CompanyID = b.CompanyID where CompanyCode='" + Form1.company + "'", cnn);
cnn.Open();
MessageBox.Show("Connection Open !");
SqlDataReader sqlReader = sqlForUserList.ExecuteReader();
while (sqlReader.Read())
{
comboBox1.Items.Add(sqlReader["UserName"].ToString());
}
sqlReader.Close();
cnn.Close();
}
}
catch (Exception ex)
{
MessageBox.Show("Can not open connection !");
}
foreach (Panel p in PropsPanels)
{
foreach (Control c in p.Controls)
{
if(c is TextBox)
{
object sender = new object();
EventArgs e = new EventArgs();
if(c.TextChanged()??????)
{
//DOSOMETHING
}
}
}
}
}
Par exemple: si je voulu vérifier si le texte a changé pour une zone de texte que j'ai mis sur le formulaire que je le ferais:
private void textBox1_TextChanged(object sender, EventArgs e)
{
}
Donc je suppose que je ne peux pas comprendre comment je vérifierais cela au moment de l'exécution puisque je crée les Textbox à l'exécution.
Merci pour toute aide!
Lors de la création dans votre méthode Encadrés 'comboBox1_SelectedIndexChanged_1', attribuez un gestionnaire d'événements au paramètre TextChanged de cette zone de texte. I.E: 'textbox.TextChanged + = myEventHandler;' –