I have a TextBox
that I allow my users to rotate. But what I would LOVE for my users is to have their Cursor
rotate to the same angle that the TextBox
was rotated at. For example, if they rotated the TextBox
to 28°, then when the Cursor
enters that TextBox
the Cursor
should also rotate itself to 28°.

- 20,799
- 66
- 75
- 101
-
Maybe... Since the "Cursor" is itself an actual Control, it could be rotated the same way I am rotating my other Controls. Hmmm, I'll try this and repost. – May 14 '10 at 16:12
-
When you say Cursor do you mean the Mouse Cursor ie. the I Beam or are you refering to the Caret which is displayed to indicate where the next character will be inserted/deleted etc. I only ask because I of ten hear the word cursor used to imply both. I assume you mean the mouse cursor because the blinking caret does rotate, but thought I would ask anyway. – Chris Taylor May 14 '10 at 16:18
-
I am referring to the | Beam, :) – May 14 '10 at 16:54
2 Answers
You can rotate your cursor using the System.Drawing.Icon class from WinForms in combination with WPF's bitmap rotation ability.
The way to do this is to load the icon, convert it to a BitmapSource, use Image and RenderTargetBitmap to rotate it, convert it back to an Icon, save it, and finally update bytes 2, 10, and 11 that make it a .cur instead of a .ico.
Here's what the code looks like:
public Cursor GetRotatedCursor(byte[] curFileBytes, double rotationAngle)
{
// Load as Bitmap, convert to BitmapSource
var origStream = new MemoryStream(curFileBytes);
var origBitmap = new System.Drawing.Icon(origStream).ToBitmap();
var origSource = System.Windows.Interop.Imaging.CreateBitmapSourceFromHBitmap(origBitmap.GetHBitmap());
// Construct rotated image
var image = new Image
{
BitmapSource = origSource,
RenderTransform = new RotateTransform(rotationAngle)
};
// Render rotated image to RenderTargetBitmap
var width = origBitmap.Width;
var height = origBitmap.Height;
var resultSource = new RenderTargetBitmap(width, height, 96, 96, PixelFormats.Pbgra32);
resultSource.Render(image);
// Convert to System.Drawing.Bitmap
var pixels = new int[width*height];
resultSource.CopyPixels(pixels, width, 0);
var resultBitmap = new System.Drawing.Bitmap(width, height, System.Drawing.Imaging.PixelFormat.Format32bppPargb);
for(int y=0; y<height; y++)
for(int x=0; x<width; x++)
resultBitmap.SetPixel(x, y, Color.FromArgb(pixels[y*width+x]));
// Save to .ico format
var resultStream = new MemoryStream();
new System.Drawing.Icon(resultBitmap.GetHIcon()).Save(resultStream);
// Convert saved file into .cur format
resultStream.Seek(2); resultStream.WriteByte(curFileBytes, 2, 1);
resultStream.Seek(10); resultStream.WriteByte(curFileBytes, 10, 2);
resultStream.Seek(0);
// Construct Cursor
return new Cursor(resultStream);
}
If you want to avoid the loop, you can replace it with a small bit of usafe code to call the System.Drawing.Bitmap constructor that takes initialization data:
fixed(int* bits = pixels)
{
resultBitmap = new System.Drawing.Bitmap(width, height, width, System.Drawing.Imaging.PixelFormat.Format32bppPargb, new IntPtr(bits));
}
You'll need to call this every time your TextBox rotation changes. This can be done either from the code that rotates your TextBox, or from a PropertyChangedCallback on a value that is bound to the TextBox's rotation.

- 62,163
- 12
- 140
- 141
-
@Ray Burns SepehrM is right, something changed in a new version of the framework (i'm using 4.5) can you please update the code? – Mauro Sampietro Feb 19 '16 at 09:25
mmm I'm not sure... but since the cursor is managed by Windows.. I guess you would need to hide the cursor when it enters the textbox and draw your own (which would be easy to rotate since you are rotating the other controls).
Heh, Googling for a way to do this, the first result was naturally from SO, you might wanna check the accepted answer (if you are using wpf):

- 1
- 1

- 13,725
- 11
- 47
- 72