У меня есть CheckedListBox
, в котором есть X элементов. Эти элементы помещаются туда во время выполнения. Предполагается, что эти элементы представляют собой отчеты, которые могут отображаться в файле DataGridView
. Теперь мне нужно отобразить количество записей для каждого отчета в круглых скобках рядом с именем отчета. Я пытался, не так уж долго, редактировать фактическое имя элемента, но не мог найти, как это сделать. Итак, я грубо заставил его. Сохранил элементы в массив, очистил элементы, добавил количество записей к каждому элементу в массиве, создал новые элементы. Что ж, это вызвало проблемы, потому что теперь он не сохраняет мои чеки, и причина этого в том, что всякий раз, когда я генерирую отчеты, я очищаю элементы и воссоздаю их. Ну, вместо того, чтобы делать еще один цикл foreach
для сохранения проверенного статуса, кто-нибудь знает способ изменить текст существующих элементов в CheckedListBox
?
Вот код, который у меня сейчас есть:
В MainForm.Designer.cs:
this.clbReports.Items.AddRange(new object[] {
"Report 1",
"Report 2",
"Report 3",
"Report 4",
"Report 5",
"Report 6",
"Report 7",
"Report 8",
"Report 9",
"Report 10",
"Report 11"});
И это выглядит так:
И я хочу, чтобы это выглядело так (но не все будут 0):
Вот функция SelectedIndexChanged:
private void clbReports_SelectedIndexChanged(object sender, EventArgs e)
{
string strCheckBox = clbReports.SelectedItem.ToString();
bool bShowAllIsChecked = clbReports.GetItemChecked(clbReports.FindString("Show All Error Reports"));
bool bSelected = clbReports.GetItemChecked(clbReports.FindString(strCheckBox));
int nIndex = -1;
if (strCheckBox.Contains("Show All Error Reports"))
{
foreach (string str in _strReports)
{
if (!str.Contains("Show All Error Reports") && !str.Contains("Show Tagged Records"))
{
nIndex = clbReports.FindString(str);
if (nIndex > -1)
{
clbReports.SetItemChecked(nIndex, bSelected);
}
}
}
}
else
{
if (strCheckBox.Contains("Show All Error Reports") || bShowAllIsChecked)
{
foreach (string str in _strReports)
{
nIndex = clbReports.FindString(str);
if (nIndex > -1)
{
clbReports.SetItemChecked(nIndex, false);
}
}
}
nIndex = clbReports.FindString(strCheckBox);
if (nIndex > -1)
{
clbReports.SetItemChecked(nIndex, bShowAllIsChecked ? true : bSelected);
}
}
string[] strCheckedItems = new string[clbReports.CheckedItems.Count];
clbReports.CheckedItems.CopyTo(strCheckedItems, 0);
List<string> checkBoxReportFilter = new List<string>();
foreach (ReportRecord obj in this._lstReportRecords)
{
foreach (string str in strCheckedItems)
{
if (str.Contains(obj.Description))
{
checkBoxReportFilter.Add(obj.PartID.ToString());
}
}
}
try
{
if (checkBoxReportFilter.Count == 0 && clbReports.CheckedItems.Count > 0)
{
throw new NullReferenceException();
}
_strReportFilter = String.Join(",", checkBoxReportFilter.ToArray());
}
catch (NullReferenceException)
{
_strReportFilter = "-1";
}
generateReport();
}
А вот код, в котором я очищаю элементы, получаю количество отчетов и создаю новые элементы.
_lstReportRecords = _dataController.ReportList;
bool[] bChecked = new bool[clbReports.Items.Count];
int nCounter = 0;
foreach (string str in _strReports)
{
foreach (string str2 in clbReports.SelectedItems)
{
bChecked[nCounter] = str2.Contains(str);
}
nCounter++;
}
clbReports.Items.Clear();
nCounter = 0;
foreach (string str in _strReports)
{
int nCount = _lstReportRecords.Where<ReportRecord>(delegate(ReportRecord rr) {
return rr.Description == str;
}).Count();
string newReport = str + " (" + nCount + ")";
clbReports.Items.Add(newReport);
clbReports.SetItemChecked(nCounter, bChecked[nCounter]);
nCounter++;
}
Скажите, пожалуйста, есть ли более простой способ сделать это. Я пытался выполнять циклы foreach через clbReports.Items, но он хочет, чтобы я привел его к строке (с ошибкой при попытке приведения к CheckBox), поэтому я не мог изменить значение. И даже если бы я мог привести его к CheckBox, у меня есть ощущение, что это даст мне ошибку, что перечисление не удалось, потому что список был изменен (или как они это называют). Любая помощь приветствуется. Спасибо.
Изменить. Имейте в виду, что отчет X предназначен только для того, чтобы фактические имена отчетов не отображались, чтобы он оставался универсальным. Однако в коде я просто скопировал и вставил, поэтому отчеты «Показать все отчеты об ошибках» и «Показать все записи с тегами» — это отчеты, которые мне нужно проверить.
int nCount = _lstReportRecords.Where(rr => rr.Description == str)
вместо запутанного пути? - person Timwi   schedule 08.09.2010