//裁剪圖片
#include <stdio.h>
#include <stdlib.h>
#include "opencv2/opencv.hpp"
void CutIplImage(IplImage* src, IplImage* dst, int x, int y)
{
CvSize size = cvSize(dst->width, dst->height);//區域大小
cvSetImageROI(src, cvRect(x, y, size.width, size.height));//設置源圖像ROI
cvCopy(src, dst); //複製圖像
cvResetImageROI(src);//源圖像用完後,清空ROI
}
這是一個使用opencv裁剪圖片的函數。
IplImage是OpenCV中的數據結構,用來表示圖像。(詳見附錄)
src是原圖像 ,dst爲裁剪後的圖像,x, y 爲ROI左上角座標。
對IplImage用cvSetImageROI函數設置了ROI後,
對圖像的處理都將僅限於ROI區域,相當於該圖像變爲了ROI中的圖像,
使用ROI需要cvResetImageROI清除ROI。
分解
CvSize size = cvSize(dst->width, dst->height);//區域大小
CvSize是存儲圖像長和寬的數據結構,cvSize函數對這一結構進行賦值。
cvSetImageROI(src, cvRect(x, y, size.width, size.height));//設置源圖像ROI
基於給定的矩形設置圖像的ROI(詳見附錄)
cvCopy(src, dst); //複製圖像
將 src 複製到 dst
cvResetImageROI(src);//源圖像用完後,清空ROI
cvResetImageROI與cvSetImageROI相對應
清空之前設置的ROI
附錄
ROI(region of interest),感興趣區域。機器視覺、圖像處理中,從被處理的圖像以方框、圓、橢圓、不規則多邊形等方式勾勒出需要處理的區域,稱爲感興趣區域。
typedef struct _IplImage
{
int nSize; /* sizeof(IplImage) */
int ID; /* version (=0)*/
int nChannels; /* Most of OpenCV functions support 1,2,3 or 4 channels */
int alphaChannel; /* Ignored by OpenCV */
int depth; /* Pixel depth in bits: IPL_DEPTH_8U, IPL_DEPTH_8S, IPL_DEPTH_16S,
IPL_DEPTH_32S, IPL_DEPTH_32F and IPL_DEPTH_64F are supported. */
char colorModel[4]; /* Ignored by OpenCV */
char channelSeq[4]; /* ditto */
int dataOrder; /* 0 - interleaved color channels, 1 - separate color channels.
cvCreateImage can only create interleaved images */
int origin; /* 0 - top-left origin,
1 - bottom-left origin (Windows bitmaps style). */
int align; /* Alignment of image rows (4 or 8).
OpenCV ignores it and uses widthStep instead. */
int width; /* Image width in pixels. */
int height; /* Image height in pixels. */
struct _IplROI *roi; /* Image ROI. If NULL, the whole image is selected. */
struct _IplImage *maskROI; /* Must be NULL. */
void *imageId; /* " " */
struct _IplTileInfo *tileInfo; /* " " */
int imageSize; /* Image data size in bytes
(==image->height*image->widthStep
in case of interleaved data)*/
char *imageData; /* Pointer to aligned image data. */
int widthStep; /* Size of aligned image row in bytes. */
int BorderMode[4]; /* Ignored by OpenCV. */
int BorderConst[4]; /* Ditto. */
char *imageDataOrigin; /* Pointer to very origin of image data
(not necessarily aligned) -
needed for correct deallocation */
}
IplImage;
typedef struct CvSize
{
int width;
int height;
}
CvSize;
CV_INLINE CvSize cvSize( int width, int height )
{
CvSize s;
s.width = width;
s.height = height;
return s;
}
希望得以指正和交流,謝謝。