Qt/C++ 改变图片亮度算法 注意是算法

由于项目需要,结合网上的资源,提供这三种方法来改变图片亮度

  1. QImage Bright1(QImage &image,int brightness)  
  2. {  
  3.     uchar *line =image.scanLine(0);   
  4.     uchar *pixel = line;  
  5.   
  6.     for (int y = 0; y < image.height(); ++y)  
  7.     {  
  8.         pixel = line;  
  9.         for (int x = 0; x < image.width(); ++x)  
  10.         {  
  11.             *pixel = qBound(0, *pixel + brightness, 255);  
  12.             *(pixel + 1) = qBound(0, *(pixel + 1) + brightness, 255);  
  13.             *(pixel + 2) = qBound(0, *(pixel + 2) + brightness, 255);  
  14.             pixel += 4;  
  15.         }  
  16.   
  17.         line += image.bytesPerLine();  
  18.     }  
  19.     return image;  
  20. }  
  21.   
  22.   
  23. QImage Bright2(QImage &image,int brightness)  
  24. {  
  25.     QImage origin = image;  
  26.     QColor oldColor;  
  27.     int delta = brightness;  
  28.     int r=0,g=0,b=0;  
  29.     uchar *line =image.scanLine(0);   
  30.     uchar *pixel = line;  
  31.     QImage * newImage = new QImage(origin.width(), origin.height(), QImage::Format_ARGB32);  
  32.     for(int y=0; yheight(); ++y)  
  33.     {  
  34.         for(int x=0; xwidth(); ++x)  
  35.         {  
  36.             oldColor = QColor(image.pixel(x,y));  
  37.             r = oldColor.red() + brightness;  
  38.             g = oldColor.green() + brightness;  
  39.             b = oldColor.blue() + brightness;  
  40.             newImage->setPixel(x,y, qRgb(r,g,b));  
  41.         }  
  42.     }  
  43.   
  44.     return *newImage;  
  45. }  
  46.    
  47. QImage Bright3(QImage& source, int factor)  
  48. {  
  49.     if (factor < -255 || factor > 255)  
  50.         return source;  
  51.   
  52.     int red, green, blue;  
  53.     int pixels = source.width() * source.height();  
  54.     unsigned int *data = (unsigned int *)source.bits();  
  55.     for (int i = 0; i < pixels; ++i)  
  56.     {  
  57.         red= qRed(data[i])+ factor;  
  58.         red = (red < 0x00) ? 0x00 : (red > 0xff) ? 0xff : red;  
  59.         green= qGreen(data[i])+factor;  
  60.         green = (green < 0x00) ? 0x00 : (green > 0xff) ? 0xff : green;  
  61.         blue= qBlue(data[i])+factor;  
  62.         blue =  (blue  < 0x00) ? 0x00 : (blue  > 0xff) ? 0xff : blue ;  
  63.         data[i] = qRgba(red, green, blue, qAlpha(data[i]));  
  64.     }  
  65.     return source;  
  66. }  

总体思路就是获取每一个像素点,再通过一个什么什么算法计算出该出该像素的值,再重新设置该像素点的值,差不多就是这样

powered by:小乌龟在大乌龟背上
更多文章:http://blog.csdn.net/what951006

你可能感兴趣的:(Qt项目实现技术记录)