我正在尝试将TextBlock绑定到ObservableCollection中的特定元素。 这就是我现在所做的:
private ObservableCollection<double> arr = new ObservableCollection<double>();
public ObservableCollection<double> Arr { get { return arr; } set { arr = value; } }
testBox.DataContext = this;
private void Button_Click(object sender, RoutedEventArgs e)
{
Arr[0] += 1.0;
}
[ValueConversion(typeof(ObservableCollection<double>), typeof(String))]
public class myObsCollConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
ObservableCollection<double> l = value as ObservableCollection<double>;
if( l == null )
return DependencyProperty.UnsetValue;
int i = int.Parse(parameter.ToString());
return l[i].ToString();
}
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
{
return DependencyProperty.UnsetValue;
}
}
<Window.Resources>
<local:myObsCollConverter x:Key="myConverter"/>
</Window.Resources>
<TextBlock Name="testBox" Text="{Binding Path=Arr,Converter={StaticResource myConverter}, ConverterParameter=0}" />
我看到的是testBox在创建时显示了Arr的第一个值。 但它并没有反映出这个元素的任何变化。 为了看到我的textBox中的Arr [0]的更改,我该怎么做?
答案 0 :(得分:22)
无需转换器。您可以像这样直接绑定到Arr[0]
<TextBlock Name="testBox" Text="{Binding Path=Arr[0]}"/>
Arr
中的元素需要实现INotifyPropertyChanged
才能动态更新。
更新:详细说明:
public class MyDouble : INotifyPropertyChanged
{
public event PropertyChangedEventHandler PropertyChanged;
private double _Value;
public double Value
{
get { return _Value; }
set { _Value = value; OnPropertyChanged("Value"); }
}
void OnPropertyChanged(string propertyName)
{
var handler = PropertyChanged;
if (handler != null)
{
handler(this, new PropertyChangedEventArgs(propertyName));
}
}
}
然后
ObservableCollection<MyDouble> Arr { get; set; }
并绑定到
<TextBlock Name="testBox" Text="{Binding Path=Arr[0].Value}"/>
答案 1 :(得分:6)
ObservableCollection
不会将更改传播到存储在属于该集合的对象中的值。它只会在集合本身的内容发生变化时触发通知(即添加,删除,重新排序项目)。如果您想要在集合中的值发生变化时更新UI,那么您必须单独连接自己。
答案 2 :(得分:0)
你可以在我的情况下使用这种方式我想绑定布尔数组的可见性: 代码背后:
using System.Windows;
public static readonly DependencyProperty ButtonVisibleProperty =
DependencyProperty.Register("ButtonVisible", typeof(BindingList<Boolean>), typeof(BaseWindow), new PropertyMetadata(new BindingList<Boolean>()));
public BindingList<Boolean> ButtonVisible
{
get { return (BindingList<Boolean>)GetValue(BaseWindow.ButtonVisibleProperty); }
set
{
SetValue(BaseWindow.ButtonVisibleProperty, value);
OnPropertyChanged("ButtonVisible");
}
}
和Xaml:
Visibility=""{Binding Path=ButtonVisible[0], RelativeSource={RelativeSource AncestorType={x:Type Window}}}"
小心!在我的情况下,ancestorType依赖于你的祖先是一个窗口