不规则ROI

#include "cv.h"
#include "highgui.h"
  
int main(int argc, char** argv)
{
    IplImage* src, * res, * roi;
  
    /* usage: <prog_name> <image> */
    if (argc < 2)
    {
        fprintf(stderr, "Usage: %s <image>\n", argv[0]);
        return 1;
    }
  
    src = cvLoadImage(argv[1], 1);
    res = cvCreateImage(cvGetSize(src), 8, 3);
    roi = cvCreateImage(cvGetSize(src), 8, 1);
  
    /* prepare the 'ROI' image */
    cvZero(roi);
  
    /* Note that you can use any shape for the ROI */
    cvCircle(
        roi,
        cvPoint(130, 100),
        50,
        CV_RGB(255, 255, 255),
        -1, 8, 0
    );
  
    /* extract subimage */
    cvAnd(src, src, res, roi);
  
    /*
     * do the main processing with subimage here.
     * in this example, we simply invert the subimage
     */
    cvNot(res, res);
  
    /* 'restore' subimage */
    IplImage* roi_C3 = cvCreateImage(cvGetSize(src), 8, 3);
    cvMerge(roi, roi, roi, NULL, roi_C3);
    cvAnd(res, roi_C3, res, NULL);
  
    /* merge subimage with original image */
    cvNot(roi, roi);
    cvAdd(src, res, res, roi);
  
    /* show result */
    cvNamedWindow(argv[1], 1);
    cvNamedWindow("res", 1);
    cvShowImage(argv[1], src);
    cvShowImage("res", res);
  
    cvWaitKey(0);
  
    /* be tidy */
    cvDestroyAllWindows();
    cvReleaseImage(&src);
    cvReleaseImage(&res);
    cvReleaseImage(&roi);
  
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值