Когда пользователь выполняет сортировку столбцов в моем DataGrid
, я хочу, чтобы все нулевые или пустые ячейки сортировались в нижней части, а не сверху.
Я написал IComparer<T>
, который гарантирует, что пробелы всегда отсортированы вниз, но я не могу понять, как применить его к столбцам моего DataGrid
. Обратите внимание, что начальный тип DataGrid
, который я делаю с помощью метода LINQ OrderBy()
, отлично работает. Проблема в том, что все последующие сортировки, выполняемые пользователем, сортируют пробелы в верхней части.
Код сравнения
public class BlankLastStringComparer : IComparer<string>
{
public int Compare(string x, string y)
{
if (string.IsNullOrEmpty(x) && !string.IsNullOrEmpty(y))
return 1;
else if (!string.IsNullOrEmpty(x) && string.IsNullOrEmpty(y))
return -1;
else
return string.Compare(x, y);
}
}
Вопросы
Как мне использовать DataGridColumn
для использования моего компаратора? Или, если это невозможно, можете ли вы предложить обходное решение? Я надеюсь на дружественное MVVM-решение, если это возможно.