低照度图像增强代码

更新时间:2023-05-29 02:18:18 阅读: 评论:0

低照度图像增强代码低照度图像增强代码
代码
// An highlighted block
#include <opencv2/core/core.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <iostream>
#include <stdio.h>
weekends
//#include <cv.h>
2010国家线
//#include<highgui.h>
using namespace cv;
using namespace std;heartbeat
//图像的三个颜⾊通道
#define BLUE0
#define GREEN1
pets2成绩查询
#define RED2
#ifndef SCREEN_XY
#define SCREEN_XY(x, y)(255-((255-(x))*(255-(y))>>8))//将新的图层与原图做滤⾊混合//x为原始图像像素值,y为新图层的像素值
#endif
int main()
{
char imgfile[256]="E:\\新桌⾯\\新建⽂件夹 (4)\\Project1\\Low Light\\09.png";//载⼊需要增强图像 Mat src =imread(imgfile);//载⼊图像需要是三通道彩⾊图像
imshow("待增强图像", src);
int size = ls * ws;//获取原图像的⼤⼩
uchar r =0, g =0, b =0, g_alpha =0;//定义参数初始值
uchar *pSrcData = src.data;//获取图图像的像素值
for(int i =0; i < size; i++, pSrcData +=3)//
{
//将绿⾊通道反⾊,与b、g、r通道分别相乘,得到新的图层颜⾊
g_alpha =255- pSrcData[GREEN];//将绿⾊通道反⾊frequently
b = pSrcData[BLUE]* g_alpha >>8;
g = pSrcData[GREEN]* g_alpha >>8;
r = pSrcData[RED]* g_alpha >>8;
//将上个步骤得到的新图层,与原始图做滤⾊混合,即执⾏f(a,b)=1-(1-a)*(1-b)的操作
pSrcData[BLUE]=SCREEN_XY(pSrcData[BLUE], b);//
pSrcData[GREEN]=SCREEN_XY(pSrcData[GREEN], g);
pSrcData[RED]=SCREEN_XY(pSrcData[RED], r);
away
//如果发现使⽤⼀次照度增强后,图⽚仍然偏暗,再运⾏⼀次上述代码
//如果觉得合适,就只增强⼀次即可
g_alpha =255- pSrcData[GREEN];
espyb = pSrcData[BLUE]* g_alpha >>8;
g = pSrcData[GREEN]* g_alpha >>8;
r = pSrcData[RED]* g_alpha >>8;剪刀差
pSrcData[BLUE]=SCREEN_XY(pSrcData[BLUE], b);
pSrcData[GREEN]=SCREEN_XY(pSrcData[GREEN], g);
amf
pSrcData[RED]=SCREEN_XY(pSrcData[RED], r);
}
imshow("增强后的图像", src);
imwrite("test09.png",src);
waitKey();
return0;
}
张家界玻璃桥叫停

本文发布于:2023-05-29 02:18:18,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/90/126454.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:图像   图层   新建   得到   照度   通道   像素
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图