#c_sharp #инспекция_кода
Имеется код C# Он полностью выполняет свои требования но проблема в том что dataGridView сильно тормозит private void dataGridView1_RowPrePaint(object sender, DataGridViewRowPrePaintEventArgs e) { if (e.RowIndex < 0 || dataGridView1.Rows[e.RowIndex].IsNewRow) return; var now = DateTime.Now; var s = Regex.CacheSize; now = new DateTime(now.Year, now.Month, now.Day, 0, 0, 0); if (dataGridView1.Rows[e.RowIndex].Cells["Срок до"].Value != null && ((DateTime)dataGridView1.Rows[e.RowIndex].Cells["Срок до"].Value).CompareTo(now) < 0) dataGridView1.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.Red; for (var i = 0; i < dataGridView1.Rows.Count; i++) for (var j = 0; j < dataGridView1.Columns.Count; j++) { var formattedValue = dataGridView1.Rows[i].Cells[j].FormattedValue; if (formattedValue != null && formattedValue.ToString().ToLower() == "удален") { dataGridView1.Rows[i].DefaultCellStyle.BackColor = Color.Gray; } } for (var i = 0; i < dataGridView1.Rows.Count; i++) for (var j = 0; j < dataGridView1.Columns.Count; j++) { var formattedValue = dataGridView1.Rows[i].Cells[j].FormattedValue; if (formattedValue != null && formattedValue.ToString().ToLower() == "неограничен") { dataGridView1.Rows[i].DefaultCellStyle.BackColor = Color.Yellow; } } } прошу помощи с оптимизацией так как пока не силён в этом деле
Ответы
Ответ 1
я бы попробовал для начала переписать так: var currentRowIndex = e.RowIndex; for (var j = 0; j < dataGridView1.Columns.Count; j++) { var formattedValue = dataGridView1.Rows[currentRowIndex].Cells[j].FormattedValue; var stringValue = formattedValue.ToString().ToLower().Trim(); switch(stringValue) { case "удален": { dataGridView1.Rows[currentRowIndex].DefaultCellStyle.BackColor = Color.Gray; break; } case "неограничен": { dataGridView1.Rows[currentRowIndex].DefaultCellStyle.BackColor = Color.Yellow; break; } default: { //действие по умолчанию break; } } } можно использовать и условный оператор if но мне больше нравится switchОтвет 2
Какую технологию вы используете? Если WinForms, то DataGridView сам по себе очень долго отрисовывается. Для обхода этой проблемы нужно создать свой контрол, унаследованный от DataGridView, и задать в нем оптимизацию буфера. public class ucGridControl : DataGridView { public ucGridControl ( ) : base ( ) { SetStyle ( ControlStyles.OptimizedDoubleBuffer | ControlStyles.AllPaintingInWmPaint, true ); } } Соответственно в форме создавайте уже экземпляр своего класса.
Комментариев нет:
Отправить комментарий