将Canvas大小绑定到其背景ImageBrush中的图像大小

时间:2011-12-21 13:25:37

标签: wpf silverlight imagebrush

我有一个画布,我希望它的大小适合背景ImageBrush。

这里的一个障碍是正在实例化控件,然后传入图像并将其指定为ImageBrush。另一个障碍是我正在为WPF和Silverlight进行此控制,而ImageBrush则不同(即它们不共享任何事件)。

编辑:

<UserControl x:Class="Escalon.Annotations.AnnotationControl"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Height="400" Width="500" >
    <ScrollViewer Name="ctlScrollViewer" HorizontalScrollBarVisibility="Auto" Height="400" Width="500">
        <Canvas Name="ctlSizingCanvas" >
            <Canvas  Name="ctlCanvas" Loaded="ctlCanvas_Loaded" Height="400" Width="500"
                MouseLeftButtonDown="MouseLeftButtonDownHandler" MouseMove="Canvas_MouseMove" MouseLeftButtonUp="Canvas_MouseLeftButtonUp" >
                <Canvas.RenderTransform>
                    <ScaleTransform x:Name="ctlZoomTransform" />
                </Canvas.RenderTransform>
                <Canvas.Background>
                    <ImageBrush ImageSource="{Binding Source}" Stretch="UniformToFill" ></ImageBrush>
                </Canvas.Background>
            </Canvas>
        </Canvas>
    </ScrollViewer>
</UserControl>

问题是,我没有使用Image控件,我使用的是ImageBrush控件,它没有高度和宽度。

1 个答案:

答案 0 :(得分:0)

我只是将图像添加到画布并将画布大小绑定到图像大小,而不是使用ImageBrush。