56

I want to know how to work out the new co-ordinates for a point when rotated by an angle relative to another point.

I have a block arrow and want to rotate it by an angle theta relative to a point in the middle of the base of the arrow.

This is required to allow me to draw a polygon between 2 onscreen controls. I can't use and rotate an image.

From what I have considered so far what complicates the matter further is that the origin of a screen is in the top left hand corner.

Sophie Alpert
  • 139,698
  • 36
  • 220
  • 238
James
  • 3,597
  • 11
  • 47
  • 57

4 Answers4

138

If you rotate point (px, py) around point (ox, oy) by angle theta you'll get:

p'x = cos(theta) * (px-ox) - sin(theta) * (py-oy) + ox
p'y = sin(theta) * (px-ox) + cos(theta) * (py-oy) + oy
Sophie Alpert
  • 139,698
  • 36
  • 220
  • 238
8

If you are using GDI+ to do that, you can use Transform methods of the Graphics object:

graphics.TranslateTransform(point of origin);
graphics.RotateTransform(rotation angle);

Then draw the actual stuff.

Mehrdad Afshari
  • 414,610
  • 91
  • 852
  • 789
2

If you have the System.Windows.Media namespace available, then you can use the built in transformations:

    using System.Windows.Media;

    var transform = new RotateTransform() {Angle = angleInDegrees, CenterX = center.X, CenterY = center.Y};
    var transformedPoint = transform.Transform(point);
thumbmunkeys
  • 20,606
  • 8
  • 62
  • 110
0

This takes a layout transform command on your image in the WPF, and rotates it the degree you want.

progress_image.LayoutTransform = new RotateTransform(90);
Spinstaz
  • 287
  • 6
  • 12