Lavorando su Rilevamento visi e riconoscimento, e dopo aver rilevato correttamente un volto, voglio solo ritagliare il viso e salvarlo da qualche parte nell'unità per dare per il codice di riconoscimento. Sto facendo fatica a salvare la regione di interesse come una nuova immagine. Ho alcuni codici online ma è scritto nella versione precedente di OpenCV che utilizza IplImage*
. Sto usando OpenCV 2.4.2 che utilizza cv::Mat
.
Heeeelp !!!
Pubblicherò i miei codici (riconoscimento dei volti e riconoscimento di per sé) se lo volete.ritaglia e salva ROI come nuova immagine in OpenCV 2.4.2 utilizzando cv :: Mat
#include <cv.h>
#include <highgui.h>
#include <math.h>
// alphablend <imageA> <image B> <x> <y> <width> <height>
// <alpha> <beta>
IplImage* crop(IplImage* src, CvRect roi)
{
// Must have dimensions of output image
IplImage* cropped = cvCreateImage(cvSize(roi.width,roi.height), src->depth, src->nChannels);
// Say what the source region is
cvSetImageROI(src, roi);
// Do the copy
cvCopy(src, cropped);
cvResetImageROI(src);
cvNamedWindow("check", 1);
cvShowImage("check", cropped);
cvSaveImage ("style.jpg" , cropped);
return cropped;
}
int main(int argc, char** argv)
{
IplImage *src1, *src2;
CvRect myRect;
// IplImage* cropped ;
src1=cvLoadImage(argv[1],1);
src2=cvLoadImage(argv[2],1);
{
int x = atoi(argv[3]);
int y = atoi(argv[4]);
int width = atoi(argv[5]);
int height = atoi(argv[6]);
double alpha = (double)atof(argv[7]);
double beta = (double)atof(argv[8]);
cvSetImageROI(src1, cvRect(x,y,width,height));
cvSetImageROI(src2, cvRect(100,200,width,height));
myRect = cvRect(x,y,width,height) ;
cvAddWeighted(src1, alpha, src2, beta,0.0,src1);
cvResetImageROI(src1);
crop (src1 , myRect);
cvNamedWindow("Alpha_blend", 1);
cvShowImage("Alpha_blend", src1);
cvWaitKey(0);
}
return 0;
}
Grazie. Peace
Nella cartella tutorial opencv è presente un codice sul rilevamento del volto. Considera quello. Dovrai usare 'cv :: imwrite' per salvare il file. – Acorbe
Hai ancora il codice di riconoscimento, ritaglio e rilevamento? Ho lo stesso identico progetto! –