diff options
author | N.N. <sevyves@users.sourceforge.net> | 2009-09-11 04:42:05 +0000 |
---|---|---|
committer | N.N. <sevyves@users.sourceforge.net> | 2009-09-11 04:42:05 +0000 |
commit | bd706e8c7bb54f2cb7aaa7554363ca08bd2fa5d1 (patch) | |
tree | 8d349d92d5f7600288a848148bb781952ba1c281 | |
parent | 1839f64d6f11a937a97e4b21c6341029a7d28272 (diff) |
numbering little fix
svn path=/trunk/externals/pix_opencv/; revision=12308
-rw-r--r-- | pix_opencv_motempl.cc | 123 |
1 files changed, 62 insertions, 61 deletions
diff --git a/pix_opencv_motempl.cc b/pix_opencv_motempl.cc index cde22b5..938acce 100644 --- a/pix_opencv_motempl.cc +++ b/pix_opencv_motempl.cc @@ -86,6 +86,18 @@ pix_opencv_motempl :: ~pix_opencv_motempl() ///////////////////////////////////////////////////////// void pix_opencv_motempl :: processRGBAImage(imageStruct &image) { + double timestamp = (double)clock()/CLOCKS_PER_SEC; // get current time in seconds + CvSize size = cvSize(img->width,img->height); // get current frame size + int i, j, idx1 = last, idx2; + IplImage* silh; + CvSeq* seq; + CvRect comp_rect; + double count; + double angle; + CvPoint center; + double magnitude; + CvScalar color; + t_atom rlist[6]; if ((this->comp_xsize!=image.xsize)&&(this->comp_ysize!=image.ysize)) { @@ -115,18 +127,6 @@ void pix_opencv_motempl :: processRGBAImage(imageStruct &image) //cvSet( rgba, cvScalar(1,2,3,4) ); cvMixChannels( (const CvArr**)in, 1, out, 2, from_to, 4 ); - double timestamp = (double)clock()/CLOCKS_PER_SEC; // get current time in seconds - CvSize size = cvSize(img->width,img->height); // get current frame size - int i, idx1 = last, idx2; - IplImage* silh; - CvSeq* seq; - CvRect comp_rect; - double count; - double angle; - CvPoint center; - double magnitude; - CvScalar color; - // allocate images at the beginning or // reallocate them if the frame size is changed if( (!mhi) || (mhi->width != size.width) || (mhi->height != size.height) || (!buf)) { @@ -183,6 +183,7 @@ void pix_opencv_motempl :: processRGBAImage(imageStruct &image) // iterate through the motion components, // One more iteration (i == -1) corresponds to the whole image (global motion) + j=0; for( i = -1; i < seq->total; i++ ) { if( i < 0 ) { // case of the whole image @@ -227,15 +228,13 @@ void pix_opencv_motempl :: processRGBAImage(imageStruct &image) cvLine( motion, center, cvPoint( cvRound( center.x + magnitude*cos(angle*CV_PI/180)), cvRound( center.y - magnitude*sin(angle*CV_PI/180))), color, 3, CV_AA, 0 ); - //aqui treurem la info dels blobs en questio ... - t_atom rlist[6]; - SETFLOAT(&rlist[0], i); - SETFLOAT(&rlist[1], center.x); - SETFLOAT(&rlist[2], center.y); - SETFLOAT(&rlist[3], comp_rect.width); - SETFLOAT(&rlist[4], comp_rect.height); - SETFLOAT(&rlist[5], angle); - outlet_list( m_dataout, 0, 6, rlist ); + SETFLOAT(&rlist[0], j++); + SETFLOAT(&rlist[1], center.x); + SETFLOAT(&rlist[2], center.y); + SETFLOAT(&rlist[3], comp_rect.width); + SETFLOAT(&rlist[4], comp_rect.height); + SETFLOAT(&rlist[5], angle); + outlet_list( m_dataout, 0, 6, rlist ); } @@ -248,6 +247,19 @@ void pix_opencv_motempl :: processRGBAImage(imageStruct &image) void pix_opencv_motempl :: processRGBImage(imageStruct &image) { + double timestamp = (double)clock()/CLOCKS_PER_SEC; // get current time in seconds + CvSize size = cvSize(img->width,img->height); // get current frame size + int i, j, idx1 = last, idx2; + IplImage* silh; + CvSeq* seq; + CvRect comp_rect; + double count; + double angle; + CvPoint center; + double magnitude; + CvScalar color; + t_atom rlist[6]; + if ((this->comp_xsize!=image.xsize)&&(this->comp_ysize!=image.ysize)) { this->comp_xsize = image.xsize; @@ -270,18 +282,6 @@ void pix_opencv_motempl :: processRGBImage(imageStruct &image) // FEM UNA COPIA DEL PACKET A image->imageData ... http://www.cs.iit.edu/~agam/cs512/lect-notes/opencv-intro/opencv-intro.html aqui veiem la estructura de IplImage memcpy( img->imageData, image.data, image.xsize*image.ysize*3 ); - double timestamp = (double)clock()/CLOCKS_PER_SEC; // get current time in seconds - CvSize size = cvSize(img->width,img->height); // get current frame size - int i, idx1 = last, idx2; - IplImage* silh; - CvSeq* seq; - CvRect comp_rect; - double count; - double angle; - CvPoint center; - double magnitude; - CvScalar color; - // allocate images at the beginning or // reallocate them if the frame size is changed if( (!mhi) || (mhi->width != size.width) || (mhi->height != size.height) || (!buf)) { @@ -338,6 +338,7 @@ void pix_opencv_motempl :: processRGBImage(imageStruct &image) // iterate through the motion components, // One more iteration (i == -1) corresponds to the whole image (global motion) + j=0; for( i = -1; i < seq->total; i++ ) { if( i < 0 ) { // case of the whole image @@ -382,14 +383,13 @@ void pix_opencv_motempl :: processRGBImage(imageStruct &image) cvLine( motion, center, cvPoint( cvRound( center.x + magnitude*cos(angle*CV_PI/180)), cvRound( center.y - magnitude*sin(angle*CV_PI/180))), color, 3, CV_AA, 0 ); - t_atom rlist[6]; - SETFLOAT(&rlist[0], i); - SETFLOAT(&rlist[1], center.x); - SETFLOAT(&rlist[2], center.y); - SETFLOAT(&rlist[3], comp_rect.width); - SETFLOAT(&rlist[4], comp_rect.height); - SETFLOAT(&rlist[5], angle); - outlet_list( m_dataout, 0, 6, rlist ); + SETFLOAT(&rlist[0], j++); + SETFLOAT(&rlist[1], center.x); + SETFLOAT(&rlist[2], center.y); + SETFLOAT(&rlist[3], comp_rect.width); + SETFLOAT(&rlist[4], comp_rect.height); + SETFLOAT(&rlist[5], angle); + outlet_list( m_dataout, 0, 6, rlist ); } @@ -404,6 +404,19 @@ void pix_opencv_motempl :: processYUVImage(imageStruct &image) void pix_opencv_motempl :: processGrayImage(imageStruct &image) { + double timestamp = (double)clock()/CLOCKS_PER_SEC; // get current time in seconds + CvSize size = cvSize(img->width,img->height); // get current frame size + int i, j, idx1 = last, idx2; + IplImage* silh; + CvSeq* seq; + CvRect comp_rect; + double count; + double angle; + CvPoint center; + double magnitude; + CvScalar color; + t_atom rlist[6]; + if ((this->comp_xsize!=image.xsize)&&(this->comp_ysize!=image.ysize)) { this->comp_xsize = image.xsize; @@ -429,18 +442,6 @@ void pix_opencv_motempl :: processGrayImage(imageStruct &image) // Convert to RGB cvCvtColor( alpha, img, CV_GRAY2RGB); - double timestamp = (double)clock()/CLOCKS_PER_SEC; // get current time in seconds - CvSize size = cvSize(img->width,img->height); // get current frame size - int i, idx1 = last, idx2; - IplImage* silh; - CvSeq* seq; - CvRect comp_rect; - double count; - double angle; - CvPoint center; - double magnitude; - CvScalar color; - // allocate images at the beginning or // reallocate them if the frame size is changed if( (!mhi) || (mhi->width != size.width) || (mhi->height != size.height) || (!buf)) { @@ -497,6 +498,7 @@ void pix_opencv_motempl :: processGrayImage(imageStruct &image) // iterate through the motion components, // One more iteration (i == -1) corresponds to the whole image (global motion) + j=0; for( i = -1; i < seq->total; i++ ) { if( i < 0 ) { // case of the whole image @@ -541,14 +543,13 @@ void pix_opencv_motempl :: processGrayImage(imageStruct &image) cvLine( motion, center, cvPoint( cvRound( center.x + magnitude*cos(angle*CV_PI/180)), cvRound( center.y - magnitude*sin(angle*CV_PI/180))), color, 3, CV_AA, 0 ); - t_atom rlist[6]; - SETFLOAT(&rlist[0], i); - SETFLOAT(&rlist[1], center.x); - SETFLOAT(&rlist[2], center.y); - SETFLOAT(&rlist[3], comp_rect.width); - SETFLOAT(&rlist[4], comp_rect.height); - SETFLOAT(&rlist[5], angle); - outlet_list( m_dataout, 0, 6, rlist ); + SETFLOAT(&rlist[0], j++); + SETFLOAT(&rlist[1], center.x); + SETFLOAT(&rlist[2], center.y); + SETFLOAT(&rlist[3], comp_rect.width); + SETFLOAT(&rlist[4], comp_rect.height); + SETFLOAT(&rlist[5], angle); + outlet_list( m_dataout, 0, 6, rlist ); } |