2011-08-24 57 views
25

我有使用数据绑定在画布中显示的项目列表。如何通过绑定在画布中显示项目

ItemsToShowInCanvas = new ObservableCollection<ItemDetail> 
    { 
     new ItemDetail {Text = "ABC", Top = 10, Left = 200}, 
     new ItemDetail {Text = "DEF", Top = 100, Left = 300}, 
     new ItemDetail {Text = "PQR", Top = 50, Left = 150} 
    }; 

ItemDetail是汽车性能的简单类的文字,top和left值

public class ItemDetail 
{ 
    public string Text { get; set; } 
    public double Top { get; set; } 
    public double Left { get; set; } 
} 

当我数据绑定的物品,但会出现在画布上。但是这些项目不会出现在使用Top和Left属性提及的位置上。

<Canvas> 
    <ItemsControl ItemsSource="{Binding Path=ItemsToShowInCanvas}"> 
     <ItemsControl.ItemTemplate> 
      <DataTemplate> 
       <TextBlock Text="{Binding Path=Text}" Canvas.Top="{Binding Path=Top}" Canvas.Left="{Binding Path=Left}"/> 
      </DataTemplate> 
     </ItemsControl.ItemTemplate> 
    </ItemsControl> 
</Canvas> 
+2

的ItemsControl的TextBlock使用StackPanel的默认itemspanel。您添加的文本块实际上是添加到堆叠面板,但不添加到画布。 ItemsControl正在添加到画布上。尝试更改项目面板到画布 – Bathineni

+0

感谢您的答案bathineni。我试图把ItemsPanel作为Canvas,但它没有工作。项目开始显示一个在另一个上。添加ItemContainerStyle工作。的 –

+0

可能重复[WPF:是否有可能在XAML画布的儿童属性绑定?](http://stackoverflow.com/questions/889825/wpf-is-it-possible-to-bind-a-canvass-children -property-in-xaml) –

回答

37

设置ItemsPanelCanvas并绑定容器,而不是在DataTemplate

<ItemsControl ItemsSource="{Binding Path=ItemsToShowInCanvas}"> 
    <ItemsControl.ItemsPanel> 
     <ItemsPanelTemplate> 
      <Canvas/> 
     </ItemsPanelTemplate> 
    </ItemsControl.ItemsPanel> 
    <ItemsControl.ItemContainerStyle> 
     <Style TargetType="ContentPresenter"> 
      <Setter Property="Canvas.Left" Value="{Binding Left}"/> 
      <Setter Property="Canvas.Top" Value="{Binding Top}"/> 
     </Style> 
    </ItemsControl.ItemContainerStyle> 
    <ItemsControl.ItemTemplate> 
     <DataTemplate> 
      <TextBlock Text="{Binding Path=Text}" /> 
     </DataTemplate> 
    </ItemsControl.ItemTemplate> 
</ItemsControl> 
+0

如果我有'Shape'而不是'TextBlock',我可以简单地替换一个吗? – IAbstract

+0

另外,'ItemsControl'驻留在文档树中? – IAbstract

+0

ItemsControl.ItemsContainerStyle正是我所需要的,其余的工作。谢谢一堆。 – Grenter

相关问题