그 외 공부

[opencv c++ 영상 다루기 공부] *세번째* 영상 흑백 변환

ssangeun 2015. 8. 11. 15:56

First. 사진 흑백 변환


#code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <opencv.hpp>
 
int main(void)
{
    char key;
    IplImage    *ornImage;
    IplImage    *grayImage;
    ornImage = cvLoadImage("test.jpg"-1);
    cvNamedWindow("ornImage"0);
    cvNamedWindow("grayImage"0);
    grayImage = cvCreateImage(cvGetSize(ornImage), IPL_DEPTH_8U, 1);
    cvCvtColor(ornImage, grayImage, CV_BGR2GRAY);
    cvShowImage("ornImage", ornImage);
    cvShowImage("grayImage", grayImage);
 
    key = cvWaitKey(0);
 
    cvReleaseImage(&ornImage);
    cvReleaseImage(&grayImage);
    
    return 0;
}
cs


#공부



#결과




Second, 실시간 동영상 흑백 변환


#code

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <opencv.hpp>
 
int main(void)
{
    char key;
    IplImage    *ornImage;
    IplImage    *grayImage;
    CvCapture    *camera;
    CvSize ornSize, cropSize;
 
    ornSize.height = 480;
    ornSize.width = 640;
    cropSize.height = 480;
    cropSize.width = 640;
 
    camera = cvCreateCameraCapture(0);
    grayImage = cvCreateImage(ornSize, IPL_DEPTH_8U, 1);
 
    while (1)
    {
        if (!cvGrabFrame(camera))
        {
            printf("camera error\n");
            return 0;
        }
 
        ornImage = cvRetrieveFrame(camera);
        cvCvtColor(ornImage, grayImage, CV_BGR2GRAY);
        cvShowImage("ornImage", ornImage);
        cvShowImage("grayImage", grayImage);
 
        key = cvWaitKey(1);
        if (key == 27)
        {
            break;
        }
    }
    return 0;
}
 
cs





#공부


#결과