单击列表视图项时,我想显示由文本框组成的列表…
以下是我提出的,它不起作用.
我在模板中有两个网格,并希望根据列表视图项是否被选中来显示和隐藏网格.我哪里出错了?
我从listview的模板本身中删除了这些视觉状态,但我必须承认我不确定它们是如何工作的,或者它们是如何被触发的.应该有一些代码来做这件事吗?
<ListView Grid.Row="2" ItemsSource="{Binding Lines}" HorizontalAlignment="Stretch"> <ListView.ItemTemplate> <DataTemplate> <Grid> <Grid Name="Readonly"> <Grid.ColumnDefinitions> <ColumnDefinition Width="*"/> <ColumnDefinition Width="3*"/> </Grid.ColumnDefinitions> <TextBlock Text="{Binding One}" Grid.Column="0"/> <TextBlock Text="{Binding Two}" Grid.Column="1"/> </Grid> <Grid Name="Editing" Visibility="Collapsed"> <Grid.ColumnDefinitions> <ColumnDefinition Width="*"/> <ColumnDefinition Width="3*"/> </Grid.ColumnDefinitions> <TextBox Text="{Binding One}" Grid.Column="0"/> <TextBox Text="{Binding Two}" Grid.Column="1"/> </Grid> <VisualStateManager.VisualStateGroups> <VisualStateGroup x:Name="SelectionStates"> <VisualState x:Name="Selected"> <Storyboard> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="Editing" Storyboard.TargetProperty="Visibility"> <DiscreteObjectKeyFrame KeyTime="0" Value="Visible"/> </ObjectAnimationUsingKeyFrames> <ObjectAnimationUsingKeyFrames Storyboard.TargetName="Readonly" Storyboard.TargetProperty="Visibility"> <DiscreteObjectKeyFrame KeyTime="0" Value="Collapsed"/> </ObjectAnimationUsingKeyFrames> </Storyboard> </VisualState> </VisualStateGroup> </VisualStateManager.VisualStateGroups> </Grid> </DataTemplate> </ListView.ItemTemplate> </ListView>
非常感谢,
可汗
解决方法
这是你想要做的.
创建一个用户控件,表示ListView项中所需的布局.定义ListView时,请确保将UserControl包含在DataTemplate中,如下所示:
<ListView> <ListView.ItemTemplate> <DataTemplate> <local:MyUserControl /> </DataTemplate> </ListView.ItemTemplate> </ListView.ItemsPanel> </ListView>
现在,对于VisualStates.您需要在UserControl中设置状态.这意味着Edit的状态和View的状态.一个州需要像这样进行本地化.想想Button控件.按钮中的状态在每个按钮中定义,而不是在某个共享位置.
当您准备好更改其中一个项目的状态时,您需要将其连接到您的代码后面.在你的代码中,你需要遍历ListView中的项目并调用你创建的方法,比如MakeStateEdit()和MakeStateView().这将是您设置用户控件状态的那些方法的实现.外部代码只是相信它会发生.
这意味着你需要调用VisualStateManager.GoToState(this,“Edit”,true); (或者你创建的任何状态)在UserControl中,在代码隐藏中.相反,您可以在调用MakeStateView()时设置“View”状态.
要迭代ListView Items属性,您需要使用这样的技术(http://blog.jerrynixon.com/2012/09/how-to-access-named-control-inside-xaml.html).你会发现,一旦你开始走这条路,它真的不是很复杂.您可能会对在XAML中无法完成所有这些操作感到失望.你不能.但这是可以完成的!
祝你好运!