2011-11-20 80 views
0
#include "iostream" 
    #include "cv.h" 
    #include "highgui.h" 
    #include "cvaux.h" 
    #include "cxmisc.h" 
    #include "math.h" 

    using namespace cv; 
    using namespace std; 

    int main(){ 

    int height, width, x, y, i, minX, minY, maxX, maxY; 
    char imgFileName[100]; 


    IplImage *origImage = cvLoadImage("data set baybayin/0000.jpg", -1); 
    height = origImage->height; 
    width = origImage->width; 

    IplImage *grayImage = cvCreateImage(cvSize(width, height), 8, 1); 
    IplImage *binImage = cvCreateImage(cvSize(width, height), 8, 1); 


    //Pre-processing phase 
    //image cleaning 
    cvCvtColor(origImage, grayImage, CV_BGR2GRAY); 
    cvDilate(grayImage, grayImage, NULL, 1); 
    cvSmooth(grayImage, grayImage, CV_GAUSSIAN, 21, 21, 0, 0); 
    //image binarization 
    cvThreshold(grayImage, binImage, 120, 255, CV_THRESH_BINARY); 
    //cvNormalize(binImage,binImage,0,1,CV_MINMAX); 

    //getting image info 
    minX = width; 
    minY = height; 
    maxX = 0; 
    maxY = 0; 

    //image cropping 
    CvScalar s; 

    //finding the boundaries 
    for (x=0; x<width-1; x++){ 
     for(y=0; y<height-1; y++){ 
      //getting pixel values 
      s = cvGet2D(binImage, y, x); 
      //printf("%f\n", s.val[0]); 
      //identifying boundaries 
      if (s.val[0] == 0){ 
       //printf("HELLO"); 
       minX = min(minX, x); 
       minY = min(minY, y); 
       maxX = max(maxX, x); 
       maxY = max(maxY, y); 
       //printf("%d\n", minY); 
      } 
     } 
    } 

    //creating rectangle 
    CvRect rect = cvRect(minX, minY, maxX-minX, maxY-minY); 
    //sets the part of the image to be cropped 
    cvSetImageROI(binImage, rect); 
    IplImage *cropImage = cvCreateImage(cvGetSize(binImage), 8, 1); 
    IplImage *newImage = cvCreateImage(cvSize(400, 400), 8, 1); 

    //copies cropped image to new declared image 
    cvCopy(binImage, cropImage, NULL); 
    //cvSaveImage("bin/binImage16.jpg", binImage); 

    cvSaveImage("data set baybayin/cropImage0.jpg", cropImage); 


    cvResetImageROI(binImage); 
    cvReleaseImage(&origImage); 
    cvReleaseImage(&binImage); 
    cvReleaseImage(&grayImage); 
    cvReleaseImage(&cropImage); 
    cvReleaseImage(&newImage); 


    } 

嗨,我可以问我如何加载我的代码上面的多个图像?由于此代码仅加载和处理一个图像,并且我几乎无法了解一些在线的说明。对不起,我是一个新手。我也想在处理后询问代码;如何将新图像和已处理图像保存到具有相应文件名的另一个文件夹中?谢谢。加载和处理多个图像

回答

0

通过声明额外的IplImage对象处理多个图像,无论是从文件加载它们:

IplImage *anotherImage = cvLoadImage("data set baybayin/0000.jpg", -1); 

或自己创建它们:

IplImage *grayImage = cvCreateImage(cvSize(width, height), 8, 1); 

如果你需要做同样的事情到多个图像,那么明智的做法是编写一个接受IplImage *作为输入的函数,并返回一个新创建的IplImage *作为输出。请注意,这个新创建的图像必须由调用函数以cvRelease释放。或者,如果您正在彼此独立处理图像,则编码您的可执行文件以处理单个图像,并在命令行外壳(bash或同等)中循环显示图像。

使用cvSaveImage功能保存图像。处理路径名操作超出了库的范围 - 您有责任提供输出图像的路径。在C中,您可以使用字符数组操作来完成此操作。在C++中,你有像boost这样的库来帮助你。如果使用上面提到的替代方法,则可以使用shell的路径操作功能(例如bash)。

如果你是一个OpenCV的完全新手,那么我建议this book:虽然它只处理旧的C接口(而不是新的C++接口),它会提高你对库的理解。

+0

我不明白你的指示,对不起。如何在特定文件中读取字符串? – cmsl

+0

他们呢? – misha

+0

我已阅读关于将所有文件名保存在文本文档中并阅读所有文件名以便程序可以找到所需的图像。就像包含这些内容的文本文档一样:00000.jpg 00001.jpg 00002.jpg等等。阅读这篇文本文档后,图像将被加载。但是,我不知道如何实现它。 – cmsl