Silverlight DataGridRows в DataGrid — как их выборочно скрыть?

У меня есть ObservableCollection, питающий DataGrid, который хорошо обновляется.

Дело в том, что я хочу отфильтровать (свернуть) строки, не удаляя их из коллекции.

Есть ли способ сделать это или разместить представление в сетке, как в обычном .Net?


person Dan    schedule 27.01.2009    source источник


Ответы (2)


Я только что опубликовал запись в своем блоге, посвященную именно этой проблеме.

К сообщению прикреплено простое демонстрационное приложение, которое демонстрирует, как добиться того, чего вы хотите.

Решение должно быть достаточно общим, чтобы его можно было использовать повторно, и основано на следующем пользовательском методе расширения:

public static class Extensions
{
    /// <summary>
    /// Applies an action to each item in the sequence, which action depends on the evaluation of the predicate.
    /// </summary>
    /// <typeparam name="TSource">The type of the elements of source.</typeparam>
    /// <param name="source">A sequence to filter.</param>
    /// <param name="predicate">A function to test each element for a condition.</param>
    /// <param name="posAction">An action used to mutate elements that match the predicate's condition.</param>
    /// <param name="negAction">An action used to mutate elements that do not match the predicate's condition.</param>
    /// <returns>The elements in the sequence that matched the predicate's condition and were transformed by posAction.</returns>
    public static IEnumerable<TSource> ApplyMutateFilter<TSource>(this IEnumerable<TSource> source,
                                                                  Func<TSource, bool> predicate,
                                                                  Action<TSource> posAction,
                                                                  Action<TSource> negAction)
    {
        if (source != null)
        {
            foreach (TSource item in source)
            {
                if (predicate(item))
                {
                    posAction(item);
                }
                else
                {
                    negAction(item);
                }
            }
        }

        return source.Where(predicate);
    }
}
person Peter McG    schedule 29.01.2009

Если у вас есть представление поверх наблюдаемой коллекции, вы можете добиться этого. Я написал статью о фильтрации сетки данных Silverlight. у вас есть FilteredCollectionView, на который вы можете добавить любой IFilter. Вот ссылка на статью:

http://www.codeproject.com/KB/silverlight/autofiltering_silverlight.aspx

Надеюсь, это поможет вам.

person Community    schedule 29.01.2009