灰度图像与二维数组转化与重现
将灰度图像转化成二维数组,并且再将二维数组重现图像。
这一部分是博主zzuomo所创,原文链接https://blog.csdn.net/zzuomo/article/details/8693979
#include <cv.h>
#include <highgui.h>
#include <iostream>
using namespace std;
#define M 1600
#define N 2560
int main(int argc, char* argv[])
{
IplImage *src = cvLoadImage("120.jpg", 0);
cvNamedWindow("source", 1);
cvShowImage("source", src);
cvWaitKey();
int m = src->height;
int n = src->width;
int i, j;
printf("channel = %d", src->nChannels);
// 分配内存
int **p;
p = new int *[m];
for (i=0; i<m; i++)
{
p[i] = new int[n];
}
// 将图像数据存到二位数组中
CvScalar s;
for (i=0; i<m; i++)
{
for (j=0; j<n; j++)
{
s = cvGet2D(src, i, j);
p[i][j] = s.val[0];
}
}
/**************************************/
// 或者
//uchar *ptr;
//for (i=0; i<m; i++)
//{
// ptr = (uchar*)src->imageData + i*src->widthStep;
// for (j=0; j<n; j++)
// {
// p[i][j] = (int)*(ptr+j);
// }
//}
//保存图像信息的数组的输出
// for (i=0; i<m; i++)
//{
// for (j=0; j<n; j++)
// {
// cout<<p[i][j]<<endl;
// }
//}
/**************************************/
// 将二位数组中的数据载入新的单通道灰度图像中,看是否和原图一致
IplImage *copy = cvCreateImage(cvGetSize(src), 8, 1);
for (i=0; i<m; i++)
{
for (j=0; j<n; j++)
{
cvSetReal2D(copy, i, j, p[i][j]);
}
}
// 显示图像副本
cvNamedWindow("copy", 1);
cvShowImage("copy", copy);
cvWaitKey();
// 释放图像
cvReleaseImage(&src);
cvReleaseImage(©);
cvDestroyAllWindows();
//释放内存
for (i=0; i<m; i++)
delete [] p[i];
delete [] p;
return 0;
}
彩色图像RGB与二维数组的转化与重现
先使用三个二维数组保存每个像素点的各个通道R、G、B数据。与灰色图像类似,然后将每个通道的数组信息进行单色调重现,最后将三个图像进行融合叠加。
addWeighted()函数:
这个函数实现对输入的两幅图像进行线性系数的加权和。
void addWeighted(InputArray src1, double alpha, InputArray src2,double beta, double gamma, OutputArray dst, int dtype=-1);
第一个参数:src1,表示进行加权操作的第一个图像对象;
第二个参数:double型的alpha,表示第一个图像的加权系数;
第三个参数:src2,表示进行加权操作的第二个图像对象;
第四个参数:double型的beta,表示第二个图像的加权系数,很多情况下,有关系 alpha+beta=1.0;
第五个参数:double型的gamma,表示一个 作用到加权和后的图像上的标量,可以理解为加权和后的图像的偏移量;
第六个参数:dst,表示两个图像加权和后的图像,尺寸和图像类型与src1和src2相同。