openCV实现图像归一化
今天下午师弟问了一个关于图像归一化的问题,因此小编写了关于图像归一化的代码,比如一个文件夹下有多幅图像,每幅图像的大小不一致,如果想把这些图像归一化为相同大小的图像,就涉及到归一化的问题,现分享代码如下:
- #include <opencv2/opencv.hpp>
- #include "highgui.h"
- #include <iostream>
- using namespace std;
- using namespace cv;
- int main()
- {
- IplImage *src;
- src = cvLoadImage("100000.jpg");
- cvShowImage("100000",src);
- //cvReleaseImage(&src);
- IplImage* gray_image;
- gray_image = cvCreateImage(cvGetSize(src),8,1);
- cvCvtColor(src,gray_image,CV_BGR2GRAY);
- //cvShowImage("GrayImage",gray_image);
- IplImage* norm_image;
- CvSize norm_cvsize;
- norm_cvsize.width = 480; //目标图像的宽
- norm_cvsize.height = 640; //目标图像的高
- cout<<"开始归一化"<<endl;
- norm_image = cvCreateImage(norm_cvsize, gray_image->depth,gray_image->nChannels);//构造目标图象
- cvResize(gray_image, norm_image, CV_INTER_LINEAR); //缩放源图像到目标图像
- cout<<"归一化完成"<<endl;
- cvShowImage("归一化图像",norm_image);
- cvWaitKey(0);
- cvSaveImage("norm.jpg", norm_image); //保存归一化图像到本地文件夹下
- cvReleaseImage(&norm_image);
- }
上面的代码实现了将一幅768*1024的图像转化为480*640的图像,并将处理后的图像保存在文件夹下,如果想将多幅图像大小不一致的图像归一化为相同大小的图像,只需要加一个for循环,在此小编只实现了一幅图像的处理。下面给出原图像和和代码运行后得到的处理后的图像:
至此,实现了一幅图像大小的更改。如果将一个文件夹下的多幅图像进行归一化为相同大小的图像,只需要在上面的代码中加上一个for循环即可,代码如下:
- #include <opencv2/opencv.hpp>
- #include "highgui.h"
- #include <iostream>
- #include<fstream>
- using namespace std;
- using namespace cv;
- int nImages=1491;
- void main()
- {
- //加载图像名到数组中
- char **img_name_index = new char *[nImages]; // load image names of Ukbench
- ifstream inf_img ("..\\data\\img_name.txt", ios_base::in);
- if(!inf_img) return;
- for (int n = 0; n < nImages; n++)
- {
- img_name_index[n] = new char[100];
- if (!img_name_index[n]) break;
- inf_img.getline(img_name_index[n], 32);
- }
- inf_img.close();
- for(int i=0;i<nImages;i++)
- {
- cout<<i+1<<endl;
- char temp[100]="\0";
- char result_img[100]="\0";
- sprintf(temp,"..\\images\\%s",img_name_index[i]);
- IplImage *src;
- src = cvLoadImage(temp);
- IplImage* gray_image;
- gray_image = cvCreateImage(cvGetSize(src),8,1);
- cvCvtColor(src,gray_image,CV_BGR2GRAY);
- IplImage* norm_image;
- CvSize norm_cvsize;
- norm_cvsize.width = 480; //目标图像的宽
- norm_cvsize.height = 640; //目标图像的高
- norm_image = cvCreateImage(norm_cvsize, gray_image->depth,gray_image->nChannels); //构造目标图象
- cvResize(gray_image, norm_image, CV_INTER_LINEAR); //缩放源图像到目标图像
- sprintf(result_img,"..\\new_image\\%d.jpg",i+1);
- cvSaveImage(result_img, norm_image);//cvSaveImage("norm.jpg", norm_image); //保存归一化图像到本地文件夹下
- cvReleaseImage(&norm_image);
- cvReleaseImage(&src);
- cvReleaseImage(&gray_image);
- }
- }