XAML: Powiązanie właściwości w DataTemplate
Jestem całkiem nowy w XAML, ale cieszę się, że się go uczę. To, z czym naprawdę walczę, to wiązanie własności z elementem wDataTemplate
.
Stworzyłem prosty przykład WPF, aby (mam nadzieję) wyjaśnić mój problem.
W tym przykładzie próbuję powiązaćVisibility
własność aCheckBox
wDataTemplate
do właściwości w moim modelu widoku. (Używając tego scenariusza wyłącznie do nauki / demonstracji).
Mam prosty DataModel o nazwieItem
, ale w tym przykładzie ma niewielkie znaczenie.
class Item : INotifyPropertyChanged
{
// Fields...
private bool _IsRequired;
private string _ItemName;
I dość prosty model widoku o nazwie ItemViewModel.
class ItemViewModel : INotifyPropertyChanged
{
private ObservableCollection<Item> _Items;
private bool _IsCheckBoxChecked;
private bool _IsCheckBoxVisible;
public ObservableCollection<Item> Items
{
get { return _Items; }
set { _Items = value; }
}
public bool IsCheckBoxChecked
{
get { return _IsCheckBoxChecked; }
set
{
if (_IsCheckBoxChecked == value)
return;
_IsCheckBoxChecked = value;
if (PropertyChanged != null)
{
PropertyChanged(this, new PropertyChangedEventArgs("IsCheckBoxChecked"));
PropertyChanged(this, new PropertyChangedEventArgs("IsCheckBoxVisible"));
}
}
}
public bool IsCheckBoxVisible
{
get { return !_IsCheckBoxChecked; }
set
{
if (_IsCheckBoxVisible == value)
return;
_IsCheckBoxVisible = value;
if (PropertyChanged != null)
PropertyChanged(this, new PropertyChangedEventArgs("IsCheckBoxVisible"));
}
(Konstruktorzy iINotifyPropertyChanged
implementacja pominięta dla zwięzłości.)
Kontrolki określone w MainPage.xaml w następujący sposób.
<Window.Resources>
<local:VisibilityConverter x:Key="VisibilityConverter"/>
</Window.Resources>
<Window.DataContext>
<local:ItemViewModel/>
</Window.DataContext>
<Grid>
<StackPanel>
<CheckBox x:Name="checkBox" Content="Hide CheckBoxes" FontSize="14" IsChecked="{Binding IsCheckBoxChecked, Mode=TwoWay}" />
<ListView ItemsSource="{Binding Items}" HorizontalContentAlignment="Stretch" >
<ListView.ItemTemplate >
<DataTemplate>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<TextBlock Text="{Binding ItemName}"/>
<CheckBox Grid.Column="1" Visibility="{Binding IsCheckBoxVisible, Converter={StaticResource VisibilityConverter}}" >
<CheckBox.DataContext>
<local:ItemViewModel/>
</CheckBox.DataContext>
</CheckBox>
</Grid>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
<StackPanel Orientation="Horizontal" Margin="4,4,0,0">
<TextBlock Text="IsCheckBoxVisible:"/>
<TextBlock Text="{Binding IsCheckBoxVisible}" Margin="4,0,0,0" FontWeight="Bold" />
</StackPanel >
<Button Content="Button" Visibility="{Binding IsCheckBoxVisible, Converter={StaticResource VisibilityConverter}}" Margin="4,4,4,4"/>
</StackPanel>
</Grid>
Pole wyboru „Ukryj pola wyboru” jest powiązane zIsCheckBoxChecked
i służy do aktualizacjiIsCheckBoxVisible
. Dodałem też kilka dodatkowych kontrolek poniżejDataTemplate
udowodnić (dla siebie), że wszystko działa.)
Zaimplementowałem również konwerter wartości Jeffa Wilcoxa. (Dziękuję Ci.)http://www.jeff.wilcox.name/2008/07/visibility-type-converter/
Kiedy uruchamiam aplikację, zaznaczając i odznaczając „Ukryj pole wyboru”, steruję pozaDataTemplate
działają zgodnie z oczekiwaniami, ale niestetyCheckbox
wewnątrz szablonu danych pozostaje niezmieniony.
Odniosłem sukces z:
IsVisible="{Binding IsChecked, Converter={StaticResource VisibilityConverter}, ElementName=checkBox}"
Ale nie próbuję tylko naśladować innej kontroli, ale podejmuję decyzje na podstawie wartości.
NAPRAWDĘ doceniłbym wszelką pomoc lub radę, którą możesz zaoferować.
Dziękuję Ci.