En una de las preguntas de los foros, se comentaba a ver si era posible en una listview hacer un footer para indicar totales en una ListView, la verdad que no es muy complicado de realizar aprovechándonos de la propiedad ContainerStyle para GroupStyle, a continuación voy a poner el código de ejemplo.
El XAML de la ventana seria
- <Window x:Class=»WpfApplication5.Window1″
- xmlns=»http://schemas.microsoft.com/winfx/2006/xaml/presentation»
- xmlns:x=»http://schemas.microsoft.com/winfx/2006/xaml»
- xmlns:local=»clr-namespace:WpfApplication5″
- Title=»Window1″ Width=»640″ Height=»480″>
- <Window.Resources>
- <local:MyDataSource x:Key=»MyData» />
- <CollectionViewSource x:Key=»ViewSource» Source=»{Binding Source={StaticResource MyData}, Path=Users}»>
- <CollectionViewSource.GroupDescriptions>
- <PropertyGroupDescription PropertyName=»Country» />
- </CollectionViewSource.GroupDescriptions>
- </CollectionViewSource>
- </Window.Resources>
- <Grid x:Name=»LayoutRoot»>
- <ListView ItemsSource=»{Binding Source={StaticResource ViewSource}}»>
- <ListView.GroupStyle>
- <GroupStyle>
- <GroupStyle.ContainerStyle>
- <Style TargetType=»{x:Type GroupItem}»>
- <Setter Property=»Template»>
- <Setter.Value>
- <ControlTemplate TargetType=»{x:Type GroupItem}»>
- <DockPanel>
- <Grid DockPanel.Dock=»Bottom»>
- <Grid.Resources>
- <local:TotalSumConverter x:Key=»sumConverter» />
- </Grid.Resources>
- <Grid.ColumnDefinitions>
- <ColumnDefinition Width=»*» />
- <ColumnDefinition Width=»*» />
- </Grid.ColumnDefinitions>
- <Grid.RowDefinitions>
- <RowDefinition />
- <RowDefinition />
- </Grid.RowDefinitions>
- <StackPanel Orientation=»Horizontal»>
- <TextBlock Grid.Column=»0″ Text=»Total: « FontWeight=»Bold»/>
- <TextBlock Grid.Column=»0″ Text=»{Binding Path=Name}» />
- </StackPanel>
- <Line Grid.Column=»1″ Stroke=»Black» X2=»500″ Fill=»Black» VerticalAlignment=»Center» />
- <TextBlock Grid.Row=»1″ Grid.Column=»1″ HorizontalAlignment=»Right» Text=»{Binding Path=Items, Converter={StaticResource sumConverter}}» />
- </Grid>
- <ItemsPresenter />
- </DockPanel>
- </ControlTemplate>
- </Setter.Value>
- </Setter>
- </Style>
- </GroupStyle.ContainerStyle>
- </GroupStyle>
- </ListView.GroupStyle>
- <ListView.View>
- <GridView>
- <GridViewColumn Width=»140″ Header=»Nombre» DisplayMemberBinding=»{Binding Name}»/>
- <GridViewColumn Width=»140″ Header=»Telefono» DisplayMemberBinding=»{Binding Phone}»/>
- <GridViewColumn Width=»140″ Header=»Ciudad» DisplayMemberBinding=»{Binding Country}» />
- <GridViewColumn Width=»140″ Header=»Total» DisplayMemberBinding=»{Binding Total}» />
- </GridView>
- </ListView.View>
- </ListView>
- </Grid>
- </Window>
Si os fijais hemos definido el estilo para GroupStyle y hemos indicado porque propiedad se agrupa en CollectionViewSource, luego hemos definido como queríamos representar ese pie, en este caso vamos a mostrar la suma de todos los items de ese grupo
Ahora vamos a seguir poniendo el código de las restantes clases necesarias
MyDataSource.cs
- using System;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.Linq;
- using System.Text;
- namespace WpfApplication5
- {
- public class MyDataSource
- {
- public ObservableCollection<User>
- Users { get; set; }
- public MyDataSource()
- {
- Users = new ObservableCollection<User>();
- LoadDummyData();
- }
- private void LoadDummyData()
- {
- Users.Add(new User() { Name = «Oscar», Phone = «(122) 555-1234», Country = «España», Total = 432 });
- Users.Add(new User() { Name = «Maite», Phone = «(212) 555-1234», Country = «España», Total = 456 });
- Users.Add(new User() { Name = «Javi», Phone = «(301) 555-1234», Country = «España», Total = 123 });
- Users.Add(new User() { Name = «Joseba», Phone = «+33 (122) 555-1234», Country = «USA», Total = 333 });
- Users.Add(new User() { Name = «Mike», Phone = «+33 (122) 555-1234», Country = «USA», Total = 222 });
- Users.Add(new User() { Name = «Jim», Phone = «+33 (122) 555-1234», Country = «USA», Total = 444 });
- }
- }
- }
User.cs
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- namespace WpfApplication5
- {
- public class User
- {
- public string Name { get; set; }
- public string Phone { get; set; }
- public string Country { get; set; }
- public double Total { get; set; }
- }
- }
TotalSumConverter.cs
- using System;
- using System.Collections.Generic;
- using System.Globalization;
- using System.Linq;
- using System.Text;
- using System.Windows.Data;
- namespace WpfApplication5
- {
- public class TotalSumConverter : IValueConverter
- {
- public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
- {
- var users = value as IEnumerable<object>;
- if (users == null)
- return «€0.00»; double sum = 0;
- foreach (var u in users)
- {
- sum += ((User)u).Total;
- } return sum.ToString(«c»);
- }
- public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
- { throw new System.NotImplementedException(); }
- }
- }
El resultado final seria
Fácil no?, espero que os sirva
En una de las preguntas de los foros, se comentaba a ver si era posible en una listview hacer un footer
Hola Oskar,
en primer lugar agradecerte el artículo, la duda es si se puede aplicar en WinForms.
Muchas gracias.