【C#】对一个坐标点按照一个中心进行旋转

/// <summary>
/// 对一个坐标点按照一个中心进行旋转 
/// </summary>
/// <param name="x">坐标x</param>
/// <param name="y">坐标y</param>
/// <param name="angle">旋转角度</param>
/// <param name="tmpX">返回坐标x</param>
/// <param name="tmpY">返回坐标y</param>
/// <param name="centerX">中心点x(默认0)</param>
/// <param name="centerY">中心点y(默认0)</param>
public static void RotateCenter(double x, double y, double angle, out double tmpX, out double tmpY, double centerX = 0, double centerY = 0)
{
    tmpX = 0;
    tmpY = 0;
    try
    {
        double angleHude = angle * Math.PI / 180;/*角度变成弧度*/
        double x1 = (x - centerX) * Math.Cos(angleHude) + (y - centerY) * Math.Sin(angleHude) + centerX;
        double y1 = -(x - centerX) * Math.Sin(angleHude) + (y - centerY) * Math.Cos(angleHude) + centerY;
        tmpX = x1;
        tmpY = y1;
    }
    catch (Exception ex)
    {
       
    }
   
}

/// <summary>
/// 对一个坐标点按照一个中心进行旋转
/// </summary>
/// <param name="originalPoint">原坐标</param>
/// <param name="angle">旋转角度</param>
/// <param name="centerPoint">中心坐标</param>
/// <returns></returns>
public static Point RotateCenter(Point originalPoint, double angle, Point centerPoint)
{
    Point tmpPoint = new Point(0,0);
    try
    {
        double angleHude = angle * Math.PI / 180;/*角度变成弧度*/
        double x1 = (originalPoint.X - centerPoint.X) * Math.Cos(angleHude) + (originalPoint.Y - centerPoint.Y) * Math.Sin(angleHude) + centerPoint.X;
        double y1 = -(originalPoint.X - centerPoint.X) * Math.Sin(angleHude) + (originalPoint.Y - centerPoint.Y) * Math.Cos(angleHude) + centerPoint.Y;
        tmpPoint.X = (int)x1;
        tmpPoint.Y = (int)y1;
    }
    catch (Exception ex)
    {
        
    }
    return tmpPoint;
}
posted @   qiutian-hao  阅读(69)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示