프로젝트

일반

사용자정보

통계
| 브랜치(Branch): | 개정판:

markus / KCOM / Common / MathHelper.cs @ 38d69491

이력 | 보기 | 이력해설 | 다운로드 (2.6 KB)

1
using System;
2
using System.Collections.Generic;
3
using System.Linq;
4
using System.Text;
5
using System.Threading.Tasks;
6
using System.Windows;
7
using System.Windows.Media;
8

    
9
namespace KCOM.Common
10
{
11
    public static class MathHelper
12
    {
13

    
14
        public static Point RotatePoint(Point p1, Point p2, double angle)
15
        {
16

    
17
            //double radians = ConvertToRadians(angle);
18
            //double sin = Math.Sin(radians);
19
            //double cos = Math.Cos(radians);
20

    
21
            //// Translate point back to origin
22
            //p1.X -= p2.X;
23
            //p1.Y -= p2.Y;
24

    
25
            //// Rotate point
26
            //double xnew = p1.X * cos - p1.Y * sin;
27
            //double ynew = p1.X * sin + p1.Y * cos;
28

    
29
            //// Translate point back
30
            //Point newPoint = new Point((int)xnew + p2.X, (int)ynew + p2.Y);
31

    
32

    
33
            var transform = new RotateTransform() { Angle = angle, CenterX = p2.X, CenterY = p2.Y };
34
            var transformedPoint = transform.Transform(p1);
35

    
36
            return transformedPoint;
37
        }
38

    
39
        public static double ConvertToRadians(double angle)
40
        {
41
            return (Math.PI / 360) * angle;
42
        }
43

    
44
        public static Rect RotateRect(Rect rect,Point Center,double angle)
45
        {
46
            Rect rotateRect = rect;
47
   
48
            var centerPoint = new Point(rect.X + rect.Width,rect.Y + rect.Height);
49
            var rotationCenter = RotatePoint(centerPoint, Center, angle);
50

    
51
            if (angle == 270 || angle == 90)
52
            {
53
                rotateRect = new Rect(0,0, rect.Height, rect.Width);
54
            }
55
            else
56
            {
57
                rotateRect = new Rect(0,0, rect.Width, rect.Height);
58
            }
59

    
60
            rotateRect.X = rotationCenter.X;
61
            rotateRect.Y = rotationCenter.Y;
62

    
63
            rect.Transform(RotateAroundPoint(angle, Center));
64

    
65
            //var points = RectToPoints(rect).Select(x=> RotateAroundPoint(x,Center,angle));
66

    
67
            //var newtest = PointsToRect(points);
68

    
69
            return rect;
70
        }
71

    
72
        private static Matrix RotateAroundPoint(double angle, Point center)
73
        {
74
            // Translate the point to the origin.
75
            Matrix result = new Matrix();
76
            result.RotateAt(angle, center.X, center.Y);
77
            return result;
78
        }
79

    
80
        private static IEnumerable<Point> RectToPoints(Rect rect)
81
        {
82
            return new [] { rect.TopLeft, rect.TopRight, rect.BottomLeft, rect.BottomRight };
83
        }
84

    
85
        private static Rect PointsToRect(IEnumerable<Point> points)
86
        {
87
            return new Rect(points.ToArray()[0],points.ToArray()[3]);
88
        }
89
    }
90
}
클립보드 이미지 추가 (최대 크기: 500 MB)