Обновление ListBox
Структура , в кратце, есть форма1, 2, 3
форма 1 - главная на ней два листобокса и кнопки
В листбоксы заносятся инфа с БД Access
Кнопка "Добавить запись" открывает форму3 и после заполнения сохранения все данные попадают в БД и закрывается форма3
НО вопрос
А по каким причинам происходит задержка обновления LISTBOX или считывания данных с БД Access?
т.е. я добавляю сотрудника в компанию в базу данных он попадает, но отображение в листбоксе проходит с задержкой (~ 3 сек)
Вручную обновлять не вариант!
Простите за вопрос, а принципы ООП вам не знакомы?
Пример:
{
for (int idx = 0; idx < 5; idx++)
{
this.listBox1.Items.Add(idx);
}
}
private ListBox listBox;
private Button button;
private Form form;
private void button1_Click(object sender, EventArgs e)
{
form = new Form();
form.ClientSize = new System.Drawing.Size(377, 309);
form.StartPosition = FormStartPosition.CenterScreen;
form.Text = "Form2";
listBox = new ListBox();
listBox.FormattingEnabled = true;
listBox.Location = new System.Drawing.Point(34, 30);
listBox.Name = "listBox";
listBox.Size = new System.Drawing.Size(120, 134);
listBox.TabIndex = 0;
button = new Button();
button.Location = new System.Drawing.Point(177, 30);
button.Name = "button";
button.Size = new System.Drawing.Size(75, 23);
button.TabIndex = 1;
button.Text = "button";
button.UseVisualStyleBackColor = true;
button.Click += new System.EventHandler(this.button_Click);
form.Controls.Add(listBox);
form.Controls.Add(button);
for (int idx = 5; idx < 10; idx++)
{
listBox.Items.Add(idx);
}
form.Show();
}
private void button_Click(object sender, EventArgs e)
{
for (int idx = 0; idx < listBox.Items.Count; idx++)
{
listBox1.Items.Add(listBox.Items[idx]);
form.Close();
}
}
1 форма:
{
for (int idx = 0; idx < 5; idx++)
{
this.listBox1.Items.Add(idx);
}
}
private Form2 form;
private void button1_Click(object sender, EventArgs e)
{
form = new Form2();
form.button1.Click += new EventHandler(form2_button1_Click);
for (int idx = 5; idx < 10; idx++)
{
form.listBox1.Items.Add(idx);
}
form.Show();
}
private void form2_button1_Click(object sender, EventArgs e)
{
for (int idx = 0; idx < form.listBox1.Items.Count; idx++)
{
listBox1.Items.Add(form.listBox1.Items[idx]);
form.Close();
}
}
{
partial class Form2
{
/// <summary>
/// Required designer variable.
/// </summary>
private System.ComponentModel.IContainer components = null;
/// <summary>
/// Clean up any resources being used.
/// </summary>
/// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
protected override void Dispose(bool disposing)
{
if (disposing && (components != null))
{
components.Dispose();
}
base.Dispose(disposing);
}
#region Windows Form Designer generated code
/// <summary>
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
/// </summary>
private void InitializeComponent()
{
this.listBox1 = new System.Windows.Forms.ListBox();
this.button1 = new System.Windows.Forms.Button();
this.SuspendLayout();
//
// listBox1
//
this.listBox1.FormattingEnabled = true;
this.listBox1.Location = new System.Drawing.Point(21, 12);
this.listBox1.Name = "listBox1";
this.listBox1.Size = new System.Drawing.Size(120, 134);
this.listBox1.TabIndex = 1;
//
// button1
//
this.button1.Location = new System.Drawing.Point(157, 12);
this.button1.Name = "button1";
this.button1.Size = new System.Drawing.Size(75, 23);
this.button1.TabIndex = 2;
this.button1.Text = "button1";
this.button1.UseVisualStyleBackColor = true;
//
// Form2
//
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.ClientSize = new System.Drawing.Size(377, 309);
this.Controls.Add(this.button1);
this.Controls.Add(this.listBox1);
this.Name = "Form2";
this.Text = "Form2";
this.ResumeLayout(false);
}
#endregion
public System.Windows.Forms.ListBox listBox1;
public System.Windows.Forms.Button button1;
}
}
т.е. я добавляю сотрудника в компанию в базу данных он попадает, но отображение в листбоксе проходит с задержкой (~ 3 сек)
все зависит от информации в базе и способа обновления listbox, чем больше информации тем дольше идет обновление.
// из Form3
//listBox2.Items.Insert(input_data);
Form1.listBox2.Update();
// OR
Form3.Closing or Form3.Closed
// перед закрытием Form3 or после закрытия Form3
Form1.listBox2.Update();
// из Form3
//listBox2.Items.Insert(input_data);
Form1.listBox2.Update();
// OR
Form3.Closing or Form3.Closed
// перед закрытием Form3 or после закрытия Form3
Form1.listBox2.Update();
возможно я вас не понял, но таким методом вы не сможете получить указатель родительской формы в дочерней. И смысла нету делать Update, после получения фокуса первой формы, когда закрыли 2 форму, так как событие paint в любом случаи вызывается.
событие paint здесь не при делах
Ошибаетесь, если речь идет о Controls.
Автору советовал был попробывать так при добавлении информации в листбокс:
for (int idx=0; idx < 10000; idx++)
{
this.listBox1.Items.Add(idx);
}
this.listBox1.EndUpdate();
А Controls есть почти у всех объектов только не могу понять причём тут Controls
А Controls есть почти у всех объектов только не могу понять причём тут Controls
Control.Paint здесь почитайте
WM_PAINT здесь почитайте
Control.Update и здесь
Если вы до сих пор считаете, что там нету связи, нам с вами разговаривать не о чем...
// из Form3
//listBox2.Items.Insert(input_data);
Form1.listBox2.Update();
// OR
Form3.Closing or Form3.Closed
// перед закрытием Form3 or после закрытия Form3
Form1.listBox2.Update();
Если выборка делается из БД - разумней в таблице сделать столбец типа сорт_ид и при выборке сортировать по этому столбцу в первую очередь. Соответственно при перетаскивании инкрементироватьдекрементировать это значение и записывать в БД.
Что вам мешает сохранить список в нужном порядке в файл, потом загрузить обратно в листбоск.