Opencvを使用していて、別のイメージの一部からイメージを作成したい。
それを行う関数を見つけられなかったので、画像をピクセルごとにコピーすることからなるアイデアを実装しようとしましたが、無駄に、私が待っている結果が得られませんでした。
誰もが別のアイデアを持っています
コード:
#include "cv.h"
#include "highgui.h"
#include <stdlib.h>
#include <stdio.h>
#include <iostream>
int main(int argc,char** argv) {
IplImage * img =0;
uchar *data;
int i,j,k;
int height,width,widthStep,nChannels;
img=cvLoadImage(argv[1],3);
height =img->height;
width = img->width;
widthStep= img->widthStep;
nChannels = img->nChannels;
data=(uchar*)img->imageData;
IplImage* img1=cvCreateImage(cvSize(height/2,width/2),IPL_DEPTH_8U,nChannels);
for(i=0;i<height/2;i++){
for(j=0;j<width/2;j++){
for(k=0;k<3;k++){
img1->imageData[i*widthStep+j*nChannels]=data[i*widthStep+j*nChannels];
}
}
}
cvShowImage("image_Originale2",img1);
cvWaitKey(0);
cvReleaseImage(&img);
return 0;
}
あなたが達成しようとしていることは、その画像に[〜#〜] roi [〜#〜](関心領域)を設定することで行うことができ、 ROIで定義された部分を新しい画像にコピーします。
あなたは この投稿でIplImage
を使用したデモ を見ることができます。
これらの投稿は、さまざまなシナリオを解決するためのROIの使用を示しています。
コードがOpenCVのCインターフェースを使用していることに注意することが重要です。 C++インターフェースはcv::Mat
、これはIplImage
と同等です。つまり、探しているのは問題のCソリューションです。
cv::Mat
のコピーコンストラクタを使用する必要があります。 IplImage
よりもはるかに優れています。
int x = 10,
y = 20,
width = 200,
height = 200;
Mat img1, img2;
img1 = imread("Lenna.png");
img2 = img1(Rect(x, y, width, height));
コピーコンストラクタを使用する:
cv::Mat whole = ...; // from imread or anything else
cv::Mat part(
whole,
cv::Range( 20, 220 ), // rows
cv::Range( 10, 210 ));// cols
cvSetImageROI() 関数を調べます。
指定された長方形の画像関心領域(ROI)を設定します。