画布不占据网格中的整个空间

时间:2011-02-26 15:52:47

标签: silverlight silverlight-4.0

我有一个网格画布。在canvas的mousemove事件我试图翻译画布。它工作正常。但是我的画布没有占据网格中的整个空间。我需要在此程序中进行哪些更改,以使画布占据整个空间。

这是我的xaml: -

<UserControl x:Class="SilverlightTestCanvasDemo.MainPage"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d"
    d:DesignHeight="300" d:DesignWidth="400">

    <Grid x:Name="LayoutRoot" Background="White">

            <Canvas x:Name="canvas" Margin="0" Background="Red">
                <TextBlock Canvas.Left="84" TextWrapping="Wrap" Text="This is some text to test whether screen is moving" Canvas.Top="99" Height="84" Width="196" FontSize="18.667" FontFamily="Cambria"/>
            </Canvas>

    </Grid>
</UserControl>

这是代码: -

using System.Windows;
using System.Windows.Controls;
using System.Windows.Media;

namespace SilverlightTestCanvasDemo
{
    public partial class MainPage : UserControl
    {
        private bool _isDown = false;
        private Point _lastPoint;

        public MainPage()
        {
            InitializeComponent();
            this.Loaded += MainPage_Loaded;
        }

        void MainPage_Loaded(object sender, RoutedEventArgs e)
        {
            canvas.MouseLeftButtonDown += canvas_MouseLeftButtonDown;
            canvas.MouseLeftButtonUp += canvas_MouseLeftButtonUp;
            canvas.MouseMove += canvas_MouseMove;
        }

        void canvas_MouseMove(object sender, System.Windows.Input.MouseEventArgs e)
        {
            if (_isDown)
            {
                Point point = e.GetPosition(canvas);
                double deltaX = point.X - _lastPoint.X;
                double deltaY = point.Y - _lastPoint.Y;
                CompositeTransform transform = null;
                if (!(canvas.RenderTransform is CompositeTransform))
                {
                    transform = new CompositeTransform();
                    canvas.RenderTransform = transform;
                }
                else
                {
                    transform = canvas.RenderTransform as CompositeTransform;
                }

                transform.TranslateX += deltaX;
                transform.TranslateY += deltaY;

                //canvas.Height += deltaY;
                //canvas.Width += deltaX;


                _lastPoint = e.GetPosition(canvas);
            }
        }

        void canvas_MouseLeftButtonUp(object sender, System.Windows.Input.MouseButtonEventArgs e)
        {
            _isDown = false;
        }

        void canvas_MouseLeftButtonDown(object sender, System.Windows.Input.MouseButtonEventArgs e)
        {
            _isDown = true;
            _lastPoint = e.GetPosition(canvas);
        }
    }
}

提前致谢:)

1 个答案:

答案 0 :(得分:1)

试试这个: -

<Grid x:Name="LayoutRoot">
    <Canvas x:Name="canvas" Margin="0" Background="AliceBlue">
        <Canvas>
            <TextBlock Canvas.Left="84" TextWrapping="Wrap" Text="This is some text to test whether screen is moving" Canvas.Top="99" Height="84" Width="196" FontSize="18.667" FontFamily="Cambria"/>
        </Canvas>
    </Canvas>
</Grid>

并将鼠标移动代码调整为: -

   void canvas_MouseMove(object sender, System.Windows.Input.MouseEventArgs e)
    {
        if (_isDown)
        {
            Point point = e.GetPosition(canvas);
            double deltaX = point.X - _lastPoint.X;
            double deltaY = point.Y - _lastPoint.Y;
            CompositeTransform transform = null;

            if (!(canvas.Children[0].RenderTransform is CompositeTransform))
            {
                transform = new CompositeTransform();
                canvas.Children[0].RenderTransform = transform;
            }
            else
            {
                transform = canvas.Children[0].RenderTransform as CompositeTransform;
            }

            transform.TranslateX += deltaX;
            transform.TranslateY += deltaY;

            _lastPoint = e.GetPosition(canvas);
        }
    }

这里发生的事情是第二个内部Canvas被用作一个球童来容纳一群真正的孩子。现在,您只需要转换此内部画布以移动所有内容。