Como: Alterar o alinhamento horizontal de uma coluna em um ListView
Por predefinição, o conteúdo de cada coluna num ListViewItem é alinhado à esquerda. Você pode alterar o alinhamento de cada coluna fornecendo um DataTemplate e definindo a propriedade HorizontalAlignment no elemento dentro do DataTemplate. Este tópico mostra como um ListView alinha seu conteúdo por padrão e como alterar o alinhamento de uma coluna em um ListView.
Exemplo
No exemplo a seguir, os dados nas colunas Title
e ISBN
estão alinhados à esquerda.
<!--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>
Para alterar o alinhamento da coluna ISBN
, você precisa especificar que a propriedade HorizontalContentAlignment de cada ListViewItem é Stretch, para que os elementos em cada ListViewItem possam se estender ou ser posicionados ao longo de toda a largura de cada coluna. Como o ListView está vinculado a uma fonte de dados, você precisa criar um estilo que defina o HorizontalContentAlignment. Em seguida, você precisa usar um DataTemplate para exibir o conteúdo em vez de usar a propriedade DisplayMemberBinding. Para exibir o ISBN
de cada modelo, o DataTemplate pode conter apenas um TextBlock que tem sua propriedade HorizontalAlignment definida como Right.
O exemplo a seguir define o estilo e os DataTemplate necessários para alinhar a coluna ISBN
à direita e altera o GridViewColumn para fazer referência ao 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>
Ver também
- Visão geral da vinculação de dados
- Visão geral do template de dados
- Vincular a Dados XML Usando um XMLDataProvider e Consultas XPath
- Visão geral do ListView
.NET Desktop feedback