将布尔值绑定到visualstate
本文关键字:visualstate 绑定 布尔值 | 更新日期: 2023-09-27 18:29:42
我正在使用表达式混合,当列表框没有元素时,我想将文本框的状态更改为红色边框和红色文本。
所以当文本发生变化时,我会过滤列表框。
private void OnIPAddressTextChanged(object sender, System.Windows.Controls.TextChangedEventArgs e)
{
compositeViewModel.manualServerInfoViewModel.FilterServers(IPAddressTextbox.Text);
}
在我的视图模型中,我过滤结果并检查是否有任何结果。然后我相应地设置布尔属性
public bool HasResults { get; set; }
public void FilterServers(string FilterCriteria)
{
....
HasResults = (FilteredManualServers.Count > 0)? true : false;
}
在我的xaml中,当HasResults布尔值为false时,我试图将文本框的状态更改为带有红色边框的可视化状态。
<TextBox x:Name="IPAddressTextbox" Height="27.24" Margin="-92.799,8,0,0" VerticalAlignment="Top" Width="209" Background="#FFF3F3F3" BorderBrush="#FF2F2F2F" TextChanged="OnIPAddressTextChanged" >
<i:Interaction.Behaviors>
<ei:DataStateBehavior Binding="{Binding HasResults}" TrueState="NoResults" />
</i:Interaction.Behaviors>
</TextBox>
这就是NoResult可视化状态
<VisualStateGroup x:Name="Filtering">
<VisualState x:Name="NoResults">
<Storyboard>
<ColorAnimationUsingKeyFrames Storyboard.TargetProperty="(Border.BorderBrush).(SolidColorBrush.Color)" Storyboard.TargetName="IPAddressTextbox">
<EasingColorKeyFrame KeyTime="0" Value="Red"/>
</ColorAnimationUsingKeyFrames>
<ColorAnimationUsingKeyFrames Storyboard.TargetProperty="(TextElement.Foreground).(SolidColorBrush.Color)" Storyboard.TargetName="IPAddressTextbox">
<EasingColorKeyFrame KeyTime="0" Value="#FFCE1010"/>
</ColorAnimationUsingKeyFrames>
</Storyboard>
</VisualState>
</VisualStateGroup>
但是,当项数为空并且布尔值为false时,什么也不会发生。
我做错了什么?
问题是UI不知道HasResults的值何时更改。绑定中没有轮询机制。您必须通知UI有关HasResults的更改。你有两种可能性。
-
当视图模型从DependencyObject继承时,将HasResults属性转换为依赖属性。有关依赖属性的更多信息:
- 此处:http://msdn.microsoft.com/en-us/library/ms752914.aspx
- 这里:http://wpftutorial.net/DependencyProperties.html
-
在视图模型中实现INotifyPropertyChanged接口,并在HasResults 的setter中引发PropertyChanged事件
- 更多信息请点击此处:http://msdn.microsoft.com/en-us/library/system.componentmodel.inotifypropertychanged.aspx