我正在尝试获取列表视图以显示由文本块组成的项目列表…
单击列表视图项时,我想显示由文本框组成的列表…
以下是我提出的,它不起作用.
我在模板中有两个网格,并希望根据列表视图项是否被选中来显示和隐藏网格.我哪里出错了?
我从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>
非常感谢,
可汗
最佳答案 您正在将Storyboard动画设置在正在呈现的项目之外.您指定的目标不仅超出了外部页面的范围,而且它们可能尚不存在.因此,在呈现页面时无法设置Storyboard.
这是你想要做的.
创建一个用户控件,表示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中无法完成所有这些操作感到失望.你不能.但这是可以完成的!
祝你好运!