public Image RotateImg(Image b, int angle)
{
angle = angle % 360;
//弧度转换
double radian = angle * Math.PI / 180.0;
double cos = Math.Cos(radian);
double sin = Math.Sin(radian);
//原图的宽和高
int w = b.Width;
int h = b.Height;
int W = (int)(Math.Max(Math.Abs(w * cos - h * sin), Math.Abs(w * cos + h * sin)));
int H = (int)(Math.Max(Math.Abs(w * sin - h * cos), Math.Abs(w * sin + h * cos)));
//目标位图
Bitmap dsImage = new Bitmap(W, H);
System.Drawing.Graphics g = System.Drawing.Graphics.FromImage(dsImage);
g.FillRectangle(Brushes.White, new Rectangle(0, 0, W, H));
g.InterpolationMode = System.Drawing.Drawing2D.InterpolationMode.Bilinear;
g.SmoothingMode = System.Drawing.Drawing2D.SmoothingMode.HighQuality;
//计算偏移量
Point Offset = new Point((W - w) / 2, (H - h) / 2);
//构造图像显示区域:让图像的中心与窗口的中心点一致
Rectangle rect = new Rectangle(Offset.X, Offset.Y, w, h);
Point center = new Point(rect.X + rect.Width / 2, rect.Y + rect.Height / 2);
g.TranslateTransform(center.X, center.Y);
g.RotateTransform(360 - angle);
//恢复图像在水平和垂直方向的平移
g.TranslateTransform(-center.X, -center.Y);
g.DrawImage(b, rect);
//重至绘图的所有变换
g.ResetTransform();
g.Save();
g.Dispose();
//保存旋转后的图片
b.Dispose();
dsImage.Save("FocusPoint.jpg", System.Drawing.Imaging.ImageFormat.Jpeg);
return dsImage;
}
public void BitmapToBpp(double hsb)
{
int w = this.bmpobj.Width;
int h = this.bmpobj.Height;
Bitmap bmp = new Bitmap(w, h, PixelFormat.Format1bppIndexed);
BitmapData data = bmp.LockBits(new Rectangle(0, 0, w, h), ImageLockMode.ReadWrite, PixelFormat.Format1bppIndexed);
for (int y = 0; y < h; y++)
{
byte[] scan = new byte[(w + 7) / 8];
for (int x = 0; x < w; x++)
{
if ((double)this.bmpobj.GetPixel(x, y).GetBrightness() >= hsb)
{
byte[] array = scan;
int num = x / 8;
array[num] |= (byte)(128 >> x % 8);
}
}
Marshal.Copy(scan, 0, (IntPtr)((int)data.Scan0 + data.Stride * y), scan.Length);
}
bmp.UnlockBits(data);
this.bmpobj = bmp;
}
public void GrayByPixels()
{
if (this.bmpobj != null)
{
for (int i = 0; i < this.bmpobj.Width; i++)
{
for (int j = 0; j < this.bmpobj.Height; j++)
{
Color curColor = this.bmpobj.GetPixel(i, j);
int ret = (int)((double)curColor.R * 0.299 + (double)curColor.G * 0.587 + (double)curColor.B * 0.114);
this.bmpobj.SetPixel(i, j, Color.FromArgb(ret, ret, ret));
}
}
}
}
转载于:https://my.oschina.net/sqhua/blog/3036260