根据其RenderTransform在wpf画布上绘制圆圈

时间:2018-05-14 14:27:37

标签: c# wpf canvas

所以我试图将比例和平移值设置为wpf画布渲染变换,然后根据这个新的变换矩阵绘制一些圆。

我有这样的代码。

设置画布渲染变换比例和平移属性。

window.canvas.RenderTransform.Value.Scale(xScale, yScale);
window.canvas.RenderTransform.Value.Translate(offsetX, offsetY);

并添加一个这样的圆圈。

Ellipse circle = new Ellipse()
{
    Width = 5,
    Height = 5,
    Stroke = Brushes.Red,
    StrokeThickness = 8
};
circle.SetValue(Canvas.LeftProperty, (double) x);
circle.SetValue(Canvas.TopProperty,  (double) y);
window.canvas.Children.Add(circle);

但画布不会在圆点上应用变换矩阵,我该怎么办?

1 个答案:

答案 0 :(得分:2)

表达式

window.canvas.RenderTransform.Value

返回变换矩阵的副本,因为struct Matrix是值类型,而不是引用类型。您在副本上执行的任何操作都将丢失。

使用

var matrix = new Matrix();
matrix.Scale(xScale, yScale);
matrix.Translate(offsetX, offsetY);
window.canvas.RenderTransform = new MatrixTransform(matrix);

或只是

window.canvas.RenderTransform =
    new MatrixTransform(xScale, 0, 0, yScale, offsetX, offsetY);

如果之前已将MatrixTransform分配给RenderTransform属性,您也可以设置其Matrix值:

var matrix = new Matrix();
matrix.Scale(xScale, yScale);
matrix.Translate(offsetX, offsetY);
((MatrixTransform)window.canvas.RenderTransform).Matrix = matrix;