방법: XAML에서 뷰를 사용하여 데이터 정렬 및 그룹화
업데이트: 2007년 11월
이 예제에서는 XAML(Extensible Application Markup Language)에서 데이터 수집의 뷰를 만드는 방법을 보여 줍니다. 뷰에서는 그룹화, 정렬 및 필터링 기능과 현재 항목이라는 개념을 사용할 수 있습니다.
예제
다음 예제에서 places라는 정적 리소스는 각 Place 개체가 도시 이름 및 주 이름으로 구성된 Place 개체 컬렉션으로 정의됩니다. src 접두사는 데이터 소스인 Places가 정의된 네임스페이스에 매핑됩니다. scm 및 dat 접두사는 각각 System.ComponentModel 및 System.Windows.Data 네임스페이스에 매핑됩니다.
다음 예제에서는 도시 이름별로 정렬되고 주 이름별로 그룹화된 데이터 수집의 뷰를 만듭니다.
<Window.Resources>
<src:Places x:Key="places"/>
<CollectionViewSource Source="{StaticResource places}" x:Key="cvs">
<CollectionViewSource.SortDescriptions>
<scm:SortDescription PropertyName="CityName"/>
</CollectionViewSource.SortDescriptions>
<CollectionViewSource.GroupDescriptions>
<dat:PropertyGroupDescription PropertyName="State"/>
</CollectionViewSource.GroupDescriptions>
</CollectionViewSource>
그러면 뷰는 다음 예제와 같이 바인딩 소스가 될 수 있습니다.
<ListBox ItemsSource="{Binding Source={StaticResource cvs}}"
DisplayMemberPath="CityName" Name="lb">
<ListBox.GroupStyle>
<x:Static Member="GroupStyle.Default"/>
</ListBox.GroupStyle>
</ListBox>
XmlDataProvider 리소스에 정의된 XML 데이터에 대한 바인딩의 경우 XML 이름 앞에 @ 기호를 추가합니다.
<XmlDataProvider x:Key="myTasks" XPath="Tasks/Task">
<x:XData>
<Tasks >
<Task Name="Groceries" Priority="2" Type="Home">
<CollectionViewSource x:Key="mySortedTasks"
Source="{StaticResource myTasks}">
<CollectionViewSource.SortDescriptions>
<scm:SortDescription PropertyName="@Priority" />
</CollectionViewSource.SortDescriptions>
<CollectionViewSource.GroupDescriptions>
<dat:PropertyGroupDescription PropertyName="@Priority" />
</CollectionViewSource.GroupDescriptions>
</CollectionViewSource>
전체 예제를 보려면 XAML 데이터 정렬 및 그룹화 샘플을 참조하십시오.