diff options
-rw-r--r-- | blobtrack.cpp | 247 |
1 files changed, 0 insertions, 247 deletions
diff --git a/blobtrack.cpp b/blobtrack.cpp deleted file mode 100644 index 5015034..0000000 --- a/blobtrack.cpp +++ /dev/null @@ -1,247 +0,0 @@ -/* - * OpenCV 2.3 - blobtrack_sample.cpp ported to Gem by Antoine Villeret - 2012 -*/ - -#include "blobtrack.h" - -/* List of Blob Trajectory ANALYSIS modules: */ -/*================= END MODULES DECRIPTION ===================================*/ - -/* Run pipeline on all frames: */ -int RunBlobTrackingAuto( CvCapture* pCap, CvBlobTrackerAuto* pTracker,char* fgavi_name = NULL, char* btavi_name = NULL ) -{ - int OneFrameProcess = 0; - int key; - int FrameNum = 0; - CvVideoWriter* pFGAvi = NULL; - CvVideoWriter* pBTAvi = NULL; - - //cvNamedWindow( "FG", 0 ); - - /* Main loop: */ - for( FrameNum=0; pCap && (key=cvWaitKey(OneFrameProcess?0:1))!=27; - FrameNum++) - { /* Main loop: */ - IplImage* pImg = NULL; - IplImage* pMask = NULL; - - if(key!=-1) - { - OneFrameProcess = 1; - if(key=='r')OneFrameProcess = 0; - } - - pImg = cvQueryFrame(pCap); - if(pImg == NULL) break; - - - /* Process: */ - pTracker->Process(pImg, pMask); - - if(fgavi_name) - if(pTracker->GetFGMask()) - { /* Debug FG: */ - IplImage* pFG = pTracker->GetFGMask(); - CvSize S = cvSize(pFG->width,pFG->height); - static IplImage* pI = NULL; - - if(pI==NULL)pI = cvCreateImage(S,pFG->depth,3); - cvCvtColor( pFG, pI, CV_GRAY2BGR ); - - if(fgavi_name) - { /* Save fg to avi file: */ - if(pFGAvi==NULL) - { - pFGAvi=cvCreateVideoWriter( - fgavi_name, - CV_FOURCC('x','v','i','d'), - 25, - S ); - } - cvWriteFrame( pFGAvi, pI ); - } - - if(pTracker->GetBlobNum()>0) - { /* Draw detected blobs: */ - int i; - for(i=pTracker->GetBlobNum();i>0;i--) - { - CvBlob* pB = pTracker->GetBlob(i-1); - CvPoint p = cvPointFrom32f(CV_BLOB_CENTER(pB)); - CvSize s = cvSize(MAX(1,cvRound(CV_BLOB_RX(pB))), MAX(1,cvRound(CV_BLOB_RY(pB)))); - int c = cvRound(255*pTracker->GetState(CV_BLOB_ID(pB))); - cvEllipse( pI, - p, - s, - 0, 0, 360, - CV_RGB(c,255-c,0), cvRound(1+(3*c)/255) ); - } /* Next blob: */; - } - - cvNamedWindow( "FG",0); - cvShowImage( "FG",pI); - } /* Debug FG. */ - - - /* Draw debug info: */ - if(pImg) - { /* Draw all information about test sequence: */ - char str[1024]; - int line_type = CV_AA; // Change it to 8 to see non-antialiased graphics. - CvFont font; - int i; - IplImage* pI = cvCloneImage(pImg); - - cvInitFont( &font, CV_FONT_HERSHEY_PLAIN, 0.7, 0.7, 0, 1, line_type ); - - for(i=pTracker->GetBlobNum(); i>0; i--) - { - CvSize TextSize; - CvBlob* pB = pTracker->GetBlob(i-1); - CvPoint p = cvPoint(cvRound(pB->x*256),cvRound(pB->y*256)); - CvSize s = cvSize(MAX(1,cvRound(CV_BLOB_RX(pB)*256)), MAX(1,cvRound(CV_BLOB_RY(pB)*256))); - int c = cvRound(255*pTracker->GetState(CV_BLOB_ID(pB))); - - cvEllipse( pI, - p, - s, - 0, 0, 360, - CV_RGB(c,255-c,0), cvRound(1+(3*0)/255), CV_AA, 8 ); - - p.x >>= 8; - p.y >>= 8; - s.width >>= 8; - s.height >>= 8; - sprintf(str,"%03d",CV_BLOB_ID(pB)); - cvGetTextSize( str, &font, &TextSize, NULL ); - p.y -= s.height; - cvPutText( pI, str, p, &font, CV_RGB(0,255,255)); - { - const char* pS = pTracker->GetStateDesc(CV_BLOB_ID(pB)); - - if(pS) - { - char* pStr = strdup(pS); - char* pStrFree = pStr; - - while (pStr && strlen(pStr) > 0) - { - char* str_next = strchr(pStr,'\n'); - - if(str_next) - { - str_next[0] = 0; - str_next++; - } - - p.y += TextSize.height+1; - cvPutText( pI, pStr, p, &font, CV_RGB(0,255,255)); - pStr = str_next; - } - free(pStrFree); - } - } - - } /* Next blob. */; - - cvNamedWindow( "Tracking", 0); - cvShowImage( "Tracking",pI ); - - if(btavi_name && pI) - { /* Save to avi file: */ - CvSize S = cvSize(pI->width,pI->height); - if(pBTAvi==NULL) - { - pBTAvi=cvCreateVideoWriter( - btavi_name, - CV_FOURCC('x','v','i','d'), - 25, - S ); - } - cvWriteFrame( pBTAvi, pI ); - } - - cvReleaseImage(&pI); - } /* Draw all information about test sequence. */ - } /* Main loop. */ - - if(pFGAvi)cvReleaseVideoWriter( &pFGAvi ); - if(pBTAvi)cvReleaseVideoWriter( &pBTAvi ); - return 0; -} /* RunBlobTrackingAuto */ - -/* Read parameters from command line - * and transfer to specified module: - */ -void set_params(int argc, char* argv[], CvVSModule* pM, const char* prefix, const char* module) -{ - int prefix_len = strlen(prefix); - int i; - for(i=0; i<argc; ++i) - { - int j; - char* ptr_eq = NULL; - int cmd_param_len=0; - char* cmd = argv[i]; - if(MY_STRNICMP(prefix,cmd,prefix_len)!=0) continue; - cmd += prefix_len; - if(cmd[0]!=':')continue; - cmd++; - - ptr_eq = strchr(cmd,'='); - if(ptr_eq)cmd_param_len = ptr_eq-cmd; - - for(j=0; ; ++j) - { - int param_len; - const char* param = pM->GetParamName(j); - if(param==NULL) break; - param_len = strlen(param); - if(cmd_param_len!=param_len) continue; - if(MY_STRNICMP(param,cmd,param_len)!=0) continue; - cmd+=param_len; - if(cmd[0]!='=')continue; - cmd++; - pM->SetParamStr(param,cmd); - printf("%s:%s param set to %g\n",module,param,pM->GetParam(param)); - } - } - - pM->ParamUpdate(); - -} /* set_params */ - -/* Print all parameter values for given module: */ -void print_params(CvVSModule* pM, const char* module, const char* log_name) -{ - FILE* log = log_name?fopen(log_name,"at"):NULL; - int i; - if(pM->GetParamName(0) == NULL ) return; - - - printf("%s(%s) module parameters:\n",module,pM->GetNickName()); - if(log) - fprintf(log,"%s(%s) module parameters:\n",module,pM->GetNickName()); - - for (i=0; ; ++i) - { - const char* param = pM->GetParamName(i); - const char* str = param?pM->GetParamStr(param):NULL; - if(param == NULL)break; - if(str) - { - printf(" %s: %s\n",param,str); - if(log) - fprintf(log," %s: %s\n",param,str); - } - else - { - printf(" %s: %g\n",param,pM->GetParam(param)); - if(log) - fprintf(log," %s: %g\n",param,pM->GetParam(param)); - } - } - - if(log) fclose(log); - -} /* print_params */ |