[WPF] Comment mettre une CheckBox dans une ListView ?
Voila une question relativement simple à priori ?
Les développeurs WindowsForms vous répondront tout naturellement:
"Simple, il suffit d'assigner true à la propriété CheckBoxes de ta ListView".
Seulement voila, avec WPF (Windows Presentation Foundation), la démarche n'est pas aussi simple.
En effet, le contrôle ListView de WPF est certainement l'un des plus complet et son utilisation n'est plus aussi simple qu'avant. Ainsi, l'affichage d'une ListView passe par une vue (View) dans laquelle vous définissez comment votre ListView doit afficher ses éléments. La plupart du temps, cette vue est composée d'une GridView dans laquelle les éléments sont disposés suivant des lignes/colonnes. Il est donc tout à fait possible de personnaliser 2 choses!
- le Template utilisé pour le Header de cette GridView (HeaderTemplate)
- le Template utilisé pour chacune des cellules de la GridView (CellTemplate)
Si l'on souhaite faire en sorte de disposer d'une CheckBox dans l'une des colonnes de notre GridView, il nous convient donc de mettre en place de Template adéquat:
<ListView ItemsSource="{Binding}" Margin="10,10,10,10" Name="listView1">
<ListView.Resources>
<DataTemplate x:Key="chkTemplateSing">
<CheckBox IsChecked="{Binding Path=CanSing}" IsEnabled="False" />
</DataTemplate>
<DataTemplate x:Key="chkTemplateDance">
<CheckBox IsChecked="{Binding Path=CanDance}" IsEnabled="False" />
</DataTemplate>
</ListView.Resources>
<ListView.View>
<GridView>
<GridViewColumn Header="Name" DisplayMemberBinding="{Binding Path=Name}"/>
<GridViewColumn Header="Singer" CellTemplate="{StaticResource chkTemplateSing}" />
<GridViewColumn Header="Dancer" CellTemplate="{StaticResource chkTemplateDance}" />
</GridView>
</ListView.View>
</ListView>
En partant de ce modèle, il vous sera très facile d'intégrer une ComboBox, une ProgressBar ou n'importe quel autre contrôle dans une ListView !
A+
Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :