如何通过WPF画布中的坐标获取矩形位置

时间:2018-09-07 12:15:39

标签: c# .net wpf canvas

我有一些坐标用于绘制矩形。例如A(146,557),B(1499,557),C(1499,637),D(146,637)。

如何在WPF中使用坐标绘制矩形?

Rectangle myRectangle = new Rectangle();
double rectangleHeight = RectangleHeight(146,557,1499,557,1499,637,146,637);
double rectangleWidth = RectangleWidth(146,557,1499,557,1499,637,146,637);
myRectangle.Height = rectangleHeight;
myRectangle.Width = rectangleWidth;
SolidColorBrush partiallyTransparentSolidColorBrush = new SolidColorBrush(Colors.Green);
partiallyTransparentSolidColorBrush.Opacity = 0.25;
myRectangle.Fill = partiallyTransparentSolidColorBrush;
canvas.Children.Insert(0, myRectangle);
Canvas.SetTop(myRectangle, rectangleHeight);
Canvas.SetLeft(myRectangle, rectangleWidth);

这是我获取高度和宽度的方法。

private double RectangleHeight(int h1, int h2, int h3, int h4, int h5, int h6, int h7, int h8) {
    int a1 = h1 - h7;
    int a2 = h2 - h8;
    int b1 = a1 * a1;
    int b2 = a2 * a2;
    double sqt1 = Math.Sqrt(b1 + b2);
    return sqt1;
}
private double RectangleWidth(int w1, int w2, int w3, int w4, int w5, int w6, int w7, int w8)
{
    int a1 = w3 - w1;
    int a2 = w2 - w4;
    int b1 = a1 * a1;
    int b2 = a2 * a2;
    double sqt2 = Math.Sqrt(b1 + b2);
    return sqt2;
}

1 个答案:

答案 0 :(得分:1)

您的宽度和高度计算错误。对于矩形,它只是Cx - AxCy - Ay。顶部和左侧也不等于宽度和高度:

SolidColorBrush partiallyTransparentSolidColorBrush = new SolidColorBrush(Colors.Green);
partiallyTransparentSolidColorBrush.Opacity = 0.25;

int ax = 146, ay = 557, cx = 1499, cy = 637;

var myRectangle = new Rectangle
{
    Height = cy - ay,
    Width = cx - ax,
    Fill = partiallyTransparentSolidColorBrush
};
Canvas.SetTop(myRectangle, ay);
Canvas.SetLeft(myRectangle, ax);
canvas.Children.Insert(0, myRectangle);

您可以使用“多边形”代替“矩形”,并且无需进行任何计算即可指定每个点:

var partiallyTransparentSolidColorBrush = new SolidColorBrush(Colors.Green);
partiallyTransparentSolidColorBrush.Opacity = 0.25;

var myRectangle = new Polygon
{
    //Stroke = Brushes.Black,
    //StrokeThickness = 2,
    Fill = partiallyTransparentSolidColorBrush,
    Points =
    {
        new Point(146, 557),
        new Point(1499, 557),
        new Point(1499, 637),
        new Point(146, 637),
    }
};

canvas.Children.Add(myRectangle);

使用多边形也可以绘制更复杂的形状。