设置用户控制位置

时间:2016-08-30 13:04:29

标签: c# wpf itemscontrol

Hello Stackoverflowers,

我正在使用ItemsControl,我的元素全部绘制在左上角,这会创建实际位置和鼠标位置之间的间隙(我的元素应该在哪里)。相关鼠标位置保存在视图模型中。

                   <ItemsControl
                        ItemsSource="{Binding OverlayElementsList}"
                        Background="Transparent"
                        BorderBrush="Black"
                        BorderThickness="2">

                    <ItemsControl.ItemsPanel>
                        <ItemsPanelTemplate>
                            <Canvas/>
                        </ItemsPanelTemplate>
                    </ItemsControl.ItemsPanel>

                    <ItemsControl.ItemContainerStyle>
                        <Style TargetType="ContentPresenter">
                        <Setter Property="Canvas.Left" Value="{Binding ElementName=X, Path=Client.OverlayElement.StartPoint}" />
                        <Setter Property="Canvas.Top" Value="{Binding ElementName=Y, Path=Client.OverlayElement.StartPoint}" />
                        </Style>
                    </ItemsControl.ItemContainerStyle>


                    <ItemsControl.Resources>
                        <DataTemplate DataType="{x:Type elements:OverlayElement}">
                            <ContentControl Content="{Binding View}" />

                        </DataTemplate>
                    </ItemsControl.Resources>

以下是ItemsControl.Resources中可能的View bin之一:

<UserControl x:Class="Client.ImageOverlayElementView"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             xmlns:local="clr-namespace:Genetec.CS.OverlayModule.Client"
             mc:Ignorable="d" 
             d:DataContext="{d:DesignInstance local:ImageOverlayElement}">
    <Grid>
            <Image 
                Source="{Binding ImageSource}"
                Height="{Binding Height}"
                Width="{Binding Width}"
                Canvas.Left="{Binding StartPoint}"
                Canvas.Top="{Binding EndPoint}"/>
    </Grid>
</UserControl>

Canvas.Left和Canvas.Top属性似乎被忽略了,为什么?

0 个答案:

没有答案