C#图像亮度调式与伪彩色图处理的示例分析

小编给大家分享一下C#图像亮度调式与伪彩色图处理的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

十年的光泽网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。全网整合营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整光泽建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“光泽网站设计”,“光泽网站推广”以来,每个客户项目都认真落实执行。

如图,左图是效果,右图是原理,右图X轴代表图像一个像素点的灰度,Y轴代表RGB三个颜色对应的伪彩色图颜色。代码如下:

C#图像亮度调式与伪彩色图处理的示例分析C#图像亮度调式与伪彩色图处理的示例分析

for (int y = 0; y < height; y++)
{
 for (int x = 0; x < width; x++)
 {
  Color c = bmp.GetPixel(x, y);
  int R = c.R; int G = c.G; int B = c.B;
  byte temp = (byte)(B * 0.114 + G * 0.587 + R * 0.299);
  if (temp >= 0 && temp <= 63)
  {
   bmp.SetPixel(x, y, Color.FromArgb(0, (byte)(4 * temp), (byte)255));
  }
  if (temp >= 64 && temp <= 127)
  {
   bmp.SetPixel(x, y, Color.FromArgb(0, 255, (byte)(510 - 4 * temp)));
 
  }
  if (temp >= 128 && temp <= 191)
  {
   bmp.SetPixel(x, y, Color.FromArgb((byte)(4 * temp - 510), 255, 0));
  }
  if (temp >= 192 && temp <= 255)
  {
   bmp.SetPixel(x,y, Color.FromArgb(255, (byte)(1022 - 4 * temp),0));
  }
 }
}

图像亮度调整:

for (int y = 50; y < 100; y++)
 {
  for (int x = 50; x < 100; x++)
  {
   // 处理指定位置像素的亮度

   Color c = b.GetPixel(x, y);

   int R = c.R; int G = c.G; int B = c.B;

   R = R + degree; if (R > 255) R = 255;

   G = G + degree; if (G > 255) G = 255;

   B = B + degree; if (B > 255) B = 255;

   b.SetPixel(x, y, Color.FromArgb(R, G, B));

  }

 }//其中degree是亮度阶梯度

以上是“C#图像亮度调式与伪彩色图处理的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


网站名称:C#图像亮度调式与伪彩色图处理的示例分析
分享链接:http://csdahua.cn/article/gsejco.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流