让我向您展示我正在努力实现的目标。这是表示角度三点的 XAML 代码:
<Border Width="200" Height="200" BorderBrush="Black" BorderThickness="1">
<Canvas HorizontalAlignment="Center" VerticalAlignment="Center"
Width="0" Height="0"
RenderTransform="1 0 0 -1 0 0">
<Line X1="0" Y1="0" X2="{Binding CoordinateX}" Y2="{Binding CoordinateY}" Stroke="Black" />
<Line X1="0" Y1="0" X2="100" Y2="0" Stroke="Black" />
</Canvas>
</Border>
我的数据上下文是:
Test a = new Test();
// degrees * (pi/180)
a.Angle = 45 * (Math.PI / 180.0);
this.DataContext = a;
public class Test
{
public Test() { }
public double Angle { get; set; }
public double CoordinateX { get { return Math.Cos(Angle) * 100; } }
public double CoordinateY { get { return Math.Sin(Angle) * 100; } }
}
但是现在,我想将最后一个用户控件实现为 CUSTOM WPF 控件:
public class Angle : Control
{
static Angle()
{
DefaultStyleKeyProperty.OverrideMetadata(typeof(Angle), new FrameworkPropertyMetadata(typeof(Angle)));
}
public double Angle
{
get { return (double)base.GetValue(AngleProperty); }
set { base.SetValue(AngleProperty, value); }
}
public static readonly DependencyProperty AngleProperty =
DependencyProperty.Register("Angle", typeof(double), typeof(Angle), new PropertyMetadata(90.0, new PropertyChangedCallback(AngleChanged)));
public double Radius
{
get { return (double)base.GetValue(RadiusProperty); }
set { base.SetValue(RadiusProperty, value); }
}
public static readonly DependencyProperty RadiusProperty =
DependencyProperty.Register("Radius", typeof(double), typeof(Angle), new PropertyMetadata(100));
static void AngleChanged(DependencyObject property, DependencyPropertyChangedEventArgs args)
{
// here is the part I do not have idea to get "PART_LINE1" and change the values for X2 and Y2
}
}
请检查最后一个静态空白,我正在尝试做这样的事情:
// var x = Math.Cos(Angle * (Math.PI / 180))
// var y = Math.Sin(...);
// PART_LINE.X2 = x;
// PART_LINE.Y2 = y;