C#反色处理及其效率问题分析
程序员文章站
2023-11-21 16:20:46
本文实例分析了c#反色处理及其效率问题。分享给大家供大家参考。具体分析如下:
网上很多这方面的资料,常看到的版本如下面:
public bitmap rep...
本文实例分析了c#反色处理及其效率问题。分享给大家供大家参考。具体分析如下:
网上很多这方面的资料,常看到的版本如下面:
public bitmap repic(bitmap thispic, int width, int height) { bitmap bm = new bitmap(width, height);//初始化一个记录后的图片的对象 int x, y, resultr, resultg, resultb; color pixel; for (x = 0; x < width; x++) { for (y = 0; y < height; y++) { pixel = thispic.getpixel(x, y); //获取当前坐标的像素值 resultr = 255 - pixel.r; //反红 resultg = 255 - pixel.g; //反绿 resultb = 255 - pixel.b; //反蓝 bm.setpixel(x, y, color.fromargb(resultr, resultg, resultb)); //绘图 } } return bm; //返回经过处理后的图片 }
上述代码执行没有问题,但效率存在很大一个问题,执行起来很慢,测试了一下1920 x 1080分辨率,执行时间8秒左右;2560 x 1920分辨率,执行时间达到了15秒左右,当然小图片处理起来要快一些,当然也与cpu配置有关。
后来又尝试了另外一种方法,利用system.drawing.imaging 中的bitmapdata 和lockbits方法,其中用到了指针,代码如下:
public bitmap reversepic(bitmap thispic) { bitmap src = new bitmap(image.fromhbitmap(thispic.gethbitmap())); // 加载图像 bitmapdata srcdat = src.lockbits(new rectangle(point.empty, src.size), imagelockmode.readwrite, pixelformat.format24bpprgb); // 锁定位图 unsafe // 不安全代码 { byte* pix = (byte*)srcdat.scan0; // 像素首地址 for (int i = 0; i < srcdat.stride * srcdat.height; i++) pix[i] = (byte)(255 - pix[i]); } src.unlockbits(srcdat); // 解锁 return src; }
经测试效率明显提高了许多,2560 x 1920分辨率,执行时间不到1秒,看来用指针操作果然效率会很高,但c#中对指针的操作视为不安全的,使用unsafe关键字后,编译出错,得将编译器选项设置为允许对使用 unsafe 关键字的代码进行编译。方法如下:
在 visual studio 开发环境中设置此编译器选项
1. 打开项目的 “属性”页。
2. 单击 “生成”属性页。
3. 选中 “允许不安全代码”复选框。
希望本文所述对大家的c#程序设计有所帮助。