学习OpenCV(一)

看了第二章的一些代码:

#include <cv.h> 
#include <highgui.h> 
using namespace std; 

int g_slider_position = 0;
CvCapture *g_capture = NULL;

void onTrackbarSlide(int pos){
    cvSetCaptureProperty(g_capture, CV_CAP_PROP_POS_FRAMES, pos);
}

//利用cvPyrDown创建输入图像宽高一半的图像
IplImage* doPyrDown( IplImage *in, int filter = IPL_GAUSSIAN_5x5 ){
    assert(in->width % 2 == 0 && in->height % 2 == 0);
    IplImage *out = cvCreateImage(cvSize(in->width/2, in->height/2), in->depth, in->nChannels);
    cvPyrDown(in, out);
    return (out);
}

//对图像进行平滑处理
void example1( IplImage *image ){
    cvNamedWindow("hzh1", 0);
    cvNamedWindow("hzh2", 0);

    cvShowImage("hzh1", image);

    IplImage *out = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 3);
    cvSmooth(image, out, CV_GAUSSIAN, 3, 3);
    cvShowImage("hzh2", out);

    cvReleaseImage(&out);

    cvWaitKey(0);

    cvDestroyWindow("hzh1");
    cvDestroyWindow("hzh2");
}

//打开avi视屏 并添加滚动条
void example2(){
    cvNamedWindow("xxx", CV_WINDOW_AUTOSIZE);
    g_capture = cvCreateFileCapture("E:\\ConsoleApplication5\\ConsoleApplication5\\hzhhzh.avi");

    int frames = (int)cvGetCaptureProperty(g_capture, CV_CAP_PROP_FRAME_COUNT);
    if (frames != 0){
        cvCreateTrackbar("Position", "xxx", &g_slider_position, frames, onTrackbarSlide);
    }

    IplImage *frame;
    while (1){
        frame = cvQueryFrame(g_capture);
        if (!frame) break;
        cvSetTrackbarPos("Position", "xxx", ++g_slider_position);
        cvShowImage("xxx", frame);
        char c = cvWaitKey(1);
        if (c == 27){
            break;
        }
    }
    cvReleaseCapture(&g_capture);
    cvDestroyWindow("xxx");
}


//边缘检测 输出单通道图像
IplImage* doCanny(
    IplImage* in,
    double lowThresh,
    double highThresh,
    double aperture
    ){
//  if (in->nChannels != 1){
//      return 0;
//  }

    IplImage *out = cvCreateImage(
        cvGetSize(in),
        IPL_DEPTH_8U,
        1
        );

    cvCanny(in, out, lowThresh, highThresh, aperture);
    return out;
}

//读取彩色视屏,并以灰度格式输出
void example3(){
    CvCapture *capture = 0;
    capture = cvCreateFileCapture("E:\\opencv\\sources\\samples\\cpp\\tutorial_code\\HighGUI\\video-input-psnr-ssim\\video\\Megamind.avi");
    IplImage *bgr_frame = cvQueryFrame(capture);
    double fps = cvGetCaptureProperty(capture, CV_CAP_PROP_FPS);
    CvSize size = cvSize((int)cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_WIDTH),
        (int)cvGetCaptureProperty(capture, CV_CAP_PROP_FRAME_HEIGHT)
        );
    CvVideoWriter *writer = cvCreateVideoWriter(
        "hzhhzh.avi",
        CV_FOURCC('M', 'J', 'P', 'G'),
        fps,
        size
        );
    IplImage *logpolar_frame = cvCreateImage(
        size,
        IPL_DEPTH_8U,
        3
        );
    while ((bgr_frame = cvQueryFrame(capture)) != NULL){
        cvLogPolar(bgr_frame,
            logpolar_frame,
            cvPoint2D32f(bgr_frame->width/2, bgr_frame->height/2),
            40,
            CV_INTER_LINEAR + CV_WARP_FILL_OUTLIERS
            );
        cvWriteFrame(writer, logpolar_frame);
    }
    cvReleaseVideoWriter(&writer);
    cvReleaseImage(&logpolar_frame);
    cvReleaseCapture(&capture);
}

int main() { 
    IplImage *xx = cvvLoadImage("E:\\新建文件夹\\73F1DDAD71C72EAA72674E618DA840A8_140.jpg");

    cvNamedWindow("hzh1",0);
//  cvNamedWindow("hzh2",0);
//
    cvRectangle(xx, cvPoint(5, 10), cvPoint(20, 300), cvScalar(255-, 0, 0));
    cvShowImage("hzh1", xx);
//  cvShowImage("hzh2", doCanny(xx,10,100,3));
    cvWaitKey(0);
//  cvDestroyWindow("hzh1");
//  cvDestroyWindow("hzh2");
//
//  example2();
//  example1(xx);



//  example3();
//  example2();
    return 0; 
}
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值