Практическое руководство. Изменение порядка выравнивания столбцов в элементе управления ListView по горизонтали
По умолчанию содержимое каждого столбца в ListViewItem выравнивается по левому краю. Изменить выравнивание каждого столбца можно, предоставив объект DataTemplate и задав свойства HorizontalAlignment в элементе внутри объекта DataTemplate. В этом разделе показано, как ListView выравнивает содержимое по умолчанию и как изменить выравнивание одного столбца в ListView.
Пример
В следующем примере данные в столбцах Title
и ISBN
выровнены по левому краю.
<!--XmlDataProvider is defined in a ResourceDictionary,
such as Window.Resources-->
<XmlDataProvider x:Key="InventoryData" XPath="Books">
<x:XData>
<Books xmlns="">
<Book ISBN="0-7356-0562-9" Stock="in" Number="9">
<Title>XML in Action</Title>
<Summary>XML Web Technology</Summary>
</Book>
<Book ISBN="0-7356-1370-2" Stock="in" Number="8">
<Title>Programming Microsoft Windows With C#</Title>
<Summary>C# Programming using the .NET Framework</Summary>
</Book>
<Book ISBN="0-7356-1288-9" Stock="out" Number="7">
<Title>Inside C#</Title>
<Summary>C# Language Programming</Summary>
</Book>
<Book ISBN="0-7356-1377-X" Stock="in" Number="5">
<Title>Introducing Microsoft .NET</Title>
<Summary>Overview of .NET Technology</Summary>
</Book>
<Book ISBN="0-7356-1448-2" Stock="out" Number="4">
<Title>Microsoft C# Language Specifications</Title>
<Summary>The C# language definition</Summary>
</Book>
</Books>
</x:XData>
</XmlDataProvider>
<ListView ItemsSource="{Binding Source={StaticResource InventoryData}, XPath=Book}">
<ListView.View>
<GridView>
<GridViewColumn Width="300" Header="Title"
DisplayMemberBinding="{Binding XPath=Title}"/>
<GridViewColumn Width="150" Header="ISBN"
DisplayMemberBinding="{Binding XPath=@ISBN}"/>
</GridView>
</ListView.View>
</ListView>
Чтобы изменить выравнивание столбца ISBN
, нужно указать для свойства HorizontalContentAlignment каждого объекта ListViewItemзначение Stretch, чтобы эти элементы в каждом объекте ListViewItem могли охватывать всю ширину каждого столбца. Так как объект ListView привязан к источнику данных, нужно создать стиль, который задает это свойство HorizontalContentAlignment. Затем для отображения содержимого нужно использовать шаблон DataTemplate, а не свойство DisplayMemberBinding. Чтобы отобразить ISBN
каждого шаблона, в DataTemplate может содержаться только объект TextBlock, у которого для свойства HorizontalAlignment задано значение Right.
В следующем примере определяется стиль и шаблон DataTemplate, которые нужны для выравнивания столбца ISBN
по правому краю, а ссылка в объекте GridViewColumn заменяется ссылкой на DataTemplate.
<!--The Style and DataTemplate are defined in a ResourceDictionary,
such as Window.Resources-->
<Style TargetType="ListViewItem">
<Setter Property="HorizontalContentAlignment" Value="Stretch"/>
</Style>
<DataTemplate x:Key="ISBNTemplate">
<TextBlock HorizontalAlignment="Right"
Text="{Binding XPath=@ISBN}"/>
</DataTemplate>
<ListView ItemsSource="{Binding Source={StaticResource InventoryData}, XPath=Book}">
<ListView.View>
<GridView>
<GridViewColumn Width="300" Header="Title"
DisplayMemberBinding="{Binding XPath=Title}"/>
<GridViewColumn Width="150" Header="ISBN"
CellTemplate="{StaticResource ISBNTemplate}"/>
</GridView>
</ListView.View>
</ListView>
См. также
.NET Desktop feedback
Обратная связь
https://aka.ms/ContentUserFeedback.
Ожидается в ближайшее время: в течение 2024 года мы постепенно откажемся от GitHub Issues как механизма обратной связи для контента и заменим его новой системой обратной связи. Дополнительные сведения см. в разделеОтправить и просмотреть отзыв по