2011-02-14 77 views
0

我目前使用ICollectionView,myCollectionView绑定到ObservableCollection。该集合的内容是从ComboBox中选择的。每个集合项myCollectionItem都有一个VisualBrush myVisualBrush作为子项,CurrentItem的画笔显示在预览面板中。WPF绑定到当前项目不更新的孩子

集合项还是一个子对象myItemChild,它包含许多用于生成滑块的属性。此滑块会更改预览面板上的属性。

这一切都按预期工作。

当集合视图的CurrentItem被更改时,预览面板会正确更新,但滑块将继续显示以前的CurrentItem的myItemChild。

对myItemChild的更改没有提出,我该如何处理这种情况?

它很有可能我错过了一些明显的东西,所以任何指针赞赏。

问候

罗布

<Grid> 
    <Grid.RowDefinitions> 
    <RowDefinition Height="Auto"></RowDefinition> 
    <RowDefinition Height="Auto"></RowDefinition> 
    <RowDefinition Height="Auto"></RowDefinition> 
    </Grid.RowDefinitions> 

    <!-- Combo Box for selection of item--> 
    <ComboBox Grid.Row="0" ItemsSource="{Binding myCollectionView, Mode=TwoWay}" IsSynchronizedWithCurrentItem="True"> 
    <ComboBox.ItemTemplate> 
     <DataTemplate DataType="{x:Type vm:myCollectionItem}" > 
     <StackPanel> 
      <Rectangle Height="40" Width="40" Fill="{Binding myVisualBrush}"/> 
     </StackPanel> 
     </DataTemplate> 
    </ComboBox.ItemTemplate> 
    </ComboBox> 

    <!-- Panel to preview item--> 
    <ContentControl Grid.Row="1" Content="{Binding myCollectionView/}"> 
    <ContentControl.ContentTemplate> 
     <DataTemplate DataType="{x:Type vm:myCollectionItem}" > 
     <Rectangle Margin="20" Fill="{Binding myVisualBrush}" /> 
     </DataTemplate> 
    </ContentControl.ContentTemplate> 
    </ContentControl> 

    <!-- Slider to edit item--> 
    <ContentControl Grid.Row="2" Content="{Binding myCollectionView/}"> 
    <ContentControl.ContentTemplate> 

     <DataTemplate DataType="{x:Type vm:myCollectionItem}" > 
     <ContentControl Content="{Binding myItemChild}"> 
      <ContentControl.ContentTemplate> 

      <DataTemplate DataType="{x:Type vm:myCollectionItemChild}" > 
       <StackPanel> 
       <Label Content="{Binding myValueLabel, Mode=OneWay}"/> 
       <Slider Value="{Binding myValue, Mode=TwoWay}" Maximum="{Binding myValueMax}" Minimum="{Binding myValueMin}"/> 
       </StackPanel> 
      </DataTemplate> 

      </ContentControl.ContentTemplate> 
     </ContentControl> 
     </DataTemplate> 

    </ContentControl.ContentTemplate> 
    </ContentControl> 
</Grid> 
+0

骑士你为什么要在绑定中使用斜线?删除它,写内容=“{Binding myItemChild}” – vorrtex 2011-02-14 16:16:01

+0

@vorrtex当我简化代码时,这是一个错字。应该在myCollectionView上指示CurrentItem。我编辑了这个问题。谢谢 – rjw 2011-02-14 16:21:53

回答

0

我试图重现你的问题,但它的工作原理没有问题。 这里是我的代码隐藏:

public partial class MainWindow : Window 
{ 
    public MainWindow() 
    { 
     InitializeComponent(); 
     var items = new ObservableCollection<myCollectionItem>{ 
      new myCollectionItem(Brushes.Red, new myCollectionItemChild("Red", 15, 0, 80)), 
      new myCollectionItem(Brushes.Green, new myCollectionItemChild("Green", 0.7, 0, 1)), 
      new myCollectionItem(Brushes.Purple, new myCollectionItemChild("Purple", 22,11,33))}; 
     this.DataContext = new Model { myCollectionView = items }; 
    } 


} 

public class Model 
{ 
    public ObservableCollection<myCollectionItem> myCollectionView { get; set; } 
} 

public class myCollectionItem 
{ 
    public myCollectionItem(Brush br, myCollectionItemChild child) 
    { 
     this.myVisualBrush = br; 
     this.myItemChild = child; 
    } 
    public Brush myVisualBrush { get; set; } 
    public myCollectionItemChild myItemChild { get; set; } 
} 

public class myCollectionItemChild 
{ 
    public myCollectionItemChild(string label, double val, double min, double max) 
    { 
     this.myValueLabel = label; 
     this.myValue = val; 
     this.myValueMin = min; 
     this.myValueMax = max; 
    } 
    public string myValueLabel { get; set; } 
    public double myValue { get; set; } 
    public double myValueMax { get; set; } 
    public double myValueMin { get; set; } 
} 

而且,你不需要使用的控制模板。它可以写得更清楚:

<Grid> 
    <Grid.RowDefinitions> 
     <RowDefinition Height="Auto"></RowDefinition> 
     <RowDefinition Height="80"></RowDefinition> 
     <RowDefinition Height="Auto"></RowDefinition> 
    </Grid.RowDefinitions> 

    <!-- Combo Box for selection of item--> 
    <ComboBox Grid.Row="0" ItemsSource="{Binding myCollectionView, Mode=TwoWay}" IsSynchronizedWithCurrentItem="True"> 
     <ComboBox.ItemTemplate> 
      <DataTemplate DataType="{x:Type vm:myCollectionItem}" > 
       <StackPanel> 
        <Rectangle Height="40" Width="40" Fill="{Binding myVisualBrush}"/> 
       </StackPanel> 
      </DataTemplate> 
     </ComboBox.ItemTemplate> 
    </ComboBox> 

    <!-- Panel to preview item--> 
    <Rectangle Margin="20" Fill="{Binding myCollectionView/myVisualBrush}" Grid.Row="1" /> 

    <!-- Slider to edit item--> 
    <StackPanel Grid.Row="2" DataContext="{Binding myCollectionView/myItemChild}"> 
     <Label Content="{Binding myValueLabel, Mode=OneWay}"/> 
     <Slider Value="{Binding myValue, Mode=TwoWay}" Maximum="{Binding myValueMax}" Minimum="{Binding myValueMin}"/> 
    </StackPanel> 
</Grid>