在我正在进行的程序中,我有一个三角形的对象(播放器),该三角形应该始终面向鼠标旋转。考虑到这两点,我尝试了不同的方程式,我在网上找到了它们但是它们似乎没有用,或者至少表现得很好。
delta_x = cursor.X - pos.X;
delta_y = cursor.Y - pos.Y;
cursorAngle = (float)Math.Atan2(delta_y, delta_x) * (float)(180 / Math.PI);
这是我发现的最有效的公式,但它仍然不能很好地工作,因为它只面向特定角度或距离的鼠标。 Cursor.X和.Y是鼠标的坐标,pos.X和.Y是播放器的坐标。
我创建了这个WinForm示例,每次在窗体上移动鼠标时,都会计算鼠标与窗体中心的角度和距离。我在标签中显示的结果。
表单中心的红点只是一个参考面板,与代码无关。
private void f_main_MouseMove(object sender, MouseEventArgs e)
{
Point center = new Point(378, 171);
Point mouse = this.PointToClient(Cursor.Position);
lb_mouseposition.Text = $"Mouse Angle: {CalculeAngle(center, mouse)} / Distance: {CalculeDistance(center, mouse)}";
}
private double CalculeAngle(Point start, Point arrival)
{
var deltaX = Math.Pow((arrival.X - start.X), 2);
var deltaY = Math.Pow((arrival.Y - start.Y), 2);
var radian = Math.Atan2((arrival.Y - start.Y), (arrival.X - start.X));
var angle = (radian * (180 / Math.PI) + 360) % 360;
return angle;
}
private double CalculeDistance(Point start, Point arrival)
{
var deltaX = Math.Pow((arrival.X - start.X), 2);
var deltaY = Math.Pow((arrival.Y - start.Y), 2);
var distance = Math.Sqrt(deltaY + deltaX);
return distance;
}
角度在这里显示的度数从0到359.我希望这有助于计算两点之间的角度。