搜索
bottom↓
回复: 123

兔司机教你做个自跟踪摄像头,0基础入门篇,会51单片机就可以

  [复制链接]

出0入0汤圆

发表于 2011-3-23 16:50:29 | 显示全部楼层 |阅读模式
效果图在另一篇帖子里http://www.ourdev.cn/bbs/bbs_content.jsp?bbs_sn=4626646&bbs_page_no=1&search_mode=3&search_text=yirenonege&bbs_id=9999


(原文件名:框架.jpg)

源程序找不到了,但是上位机和下位机需要自己写的加起来绝不超过200行,先写这些有问题大家再问吧

1  了解什么是模式识别(Pattern Recognition),模式识别简单的说就是分类,把具有相同特征的事物分开;
             机器学习(Machine Learning),是使机器自动适应环境的变化,通过不断的反馈调整自身:
             机器视觉(machine vision),是机器用摄像头了解世界,解决问题的课题.
             图像处理(image processing),要知道图像对机器说来是一个矩阵.举个简单的例子,黑白二值图像中0表示白,1表示黑.
             说这些是大家百度 google的时候有关键词,这些课程有的大学本科就有,有的研究生阶段开设,就像高等数学\模电一样是一门学问

2  了解现在的应用
   http://www-2.cs.cmu.edu/afs/cs/project/cil/ftp/html/vision.html 梅尔卡梅隆大学机器视觉主页
   http://www.verycd.com/topics/2727693/该课程前两节给出了不少现实的应用
   说这些是告诉大家,不要害怕英文,建议多用google英文版搜索词汇,这个是忠告,因为有的英文文章写的很细,比看中文好多了.

3  用到的算法camshift算法,是meanshift算法的派生推广吧,Mean Shift这个概念最早是由Fukunaga等人于1975年在一篇关于概率密度梯度函数的估计的文献
   中提出来的(  FUKUNAGE K, HOSTETLER L D. The estimation of the gradient of a density function with application in pattern recognition
   [J]. IEEE Trans. on Information Theory, 1975,21:32-40.).  后来被推广到机器视觉领域.由于收敛速度快,稳定,国话叫鲁棒性.得到广泛应用.
   说这些是告诉大家,这个算法的家学渊源,不是某个人突发奇想,一下子完成的,有坚实的理论根基.那篇论文下下来之后,确实会死好些脑细胞,不感兴趣不看
   也罢.

4  opencv,又intel发起的视觉开源库,基本涵盖了机器视觉的经典算法,霍夫变换,开尔曼滤波,支持向量机等内容.可以说是机器视觉的程序实现.最重要的是它
   像linux一样是开源的,在opencv中文网站可以下载的到(http://www.opencv.org.cn/index.php/%E9%A6%96%E9%A1%B5)

5  下载安装好opencv库后可以看到里面有一些例子,其中一个是摄像头跟踪选定物体的应用程序,在那个文件夹里还有它的源码.大家仔细分析一下就可看出,哪
   个数据结构中包含识别的物体的位置.用串口发送控制命令给下位机即可.

6  机械部分.电机的种类很多,这里是舵机,舵机是一种位置伺服的电机.通过发送pwm控制电机转动的角度.有电源\地\信号 三根线.淘宝有卖云台的,价格在
   100+左右.云台由两舵机和链接部件组成.话说买给我的有颗螺丝根本就没法拧下去,发来的时候有点歪,感觉怪怪的,懒的计较了.下面我用相机拍了几张照片
   有兴趣可以看一下舵机内部.清晰到你爽,\(^o^)/.话说到这里,其实用扫描仪扫电路最爽了,淘个二手的100,玩够了再100卖了

7 将摄像头绑定在云台上,好吧,你找到物体的坐标了和控制电机的方法了,那就那就随便写点简单的程序让摄像头中被追踪的物体始终处于视野中心吧 : )
  


8 <<学习opencv>>千万不要买中文版的看下图你就知道了,看了中文的你会越看越糊涂

------------------------------------谜一样的分割线------------------------------------------------------------

中文的翻译,书上是我的专用书注符号,大家别介意 (原文件名:译文.jpg)


英文原文,话说清华出版社纸张和东南没法比啊 (原文件名:原文.jpg)


好吧,都比我牛,也许我看错了 (原文件名:前言.jpg)

点击此处下载 ourdev_624844K9D1PB.rar(文件大小:6.38M) (原文件名:舵机分解图.rar)

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……

出0入0汤圆

 楼主| 发表于 2012-8-29 17:01:27 | 显示全部楼层
本帖最后由 yirenonege 于 2012-8-29 17:36 编辑
  1. #ifdef _CH_
  2. #pragma package <opencv>
  3. #endif

  4. #ifndef _EiC
  5. #include "cv.h"
  6. #include "highgui.h"
  7. #include <stdio.h>
  8. #include <ctype.h>
  9. #endif

  10. IplImage *image = 0, *hsv = 0, *hue = 0, *mask = 0, *backproject = 0, *histimg = 0;
  11. CvHistogram *hist = 0;

  12. int backproject_mode = 0;
  13. int select_object = 0;
  14. int track_object = 0;
  15. int show_hist = 1;
  16. CvPoint origin;
  17. CvRect selection;
  18. CvRect track_window;
  19. CvBox2D track_box;
  20. CvConnectedComp track_comp;
  21. int hdims = 16;
  22. float hranges_arr[] = {0,180};
  23. float* hranges = hranges_arr;
  24. int vmin = 10, vmax = 256, smin = 30;

  25. void on_mouse( int event, int x, int y, int flags, void* param )
  26. {
  27.     if( !image )
  28.         return;

  29.     if( image->origin )
  30.         y = image->height - y;

  31.     if( select_object )
  32.     {
  33.         selection.x = MIN(x,origin.x);
  34.         selection.y = MIN(y,origin.y);
  35.         selection.width = selection.x + CV_IABS(x - origin.x);
  36.         selection.height = selection.y + CV_IABS(y - origin.y);
  37.         
  38.         selection.x = MAX( selection.x, 0 );
  39.         selection.y = MAX( selection.y, 0 );
  40.         selection.width = MIN( selection.width, image->width );
  41.         selection.height = MIN( selection.height, image->height );
  42.         selection.width -= selection.x;
  43.         selection.height -= selection.y;
  44.     }

  45.     switch( event )
  46.     {
  47.     case CV_EVENT_LBUTTONDOWN:
  48.         origin = cvPoint(x,y);
  49.         selection = cvRect(x,y,0,0);
  50.         select_object = 1;
  51.         break;
  52.     case CV_EVENT_LBUTTONUP:
  53.         select_object = 0;
  54.         if( selection.width > 0 && selection.height > 0 )
  55.             track_object = -1;
  56.         break;
  57.     }
  58. }


  59. CvScalar hsv2rgb( float hue )
  60. {
  61.     int rgb[3], p, sector;
  62.     static const int sector_data[][3]=
  63.         {{0,2,1}, {1,2,0}, {1,0,2}, {2,0,1}, {2,1,0}, {0,1,2}};
  64.     hue *= 0.033333333333333333333333333333333f;
  65.     sector = cvFloor(hue);
  66.     p = cvRound(255*(hue - sector));
  67.     p ^= sector & 1 ? 255 : 0;

  68.     rgb[sector_data[sector][0]] = 255;
  69.     rgb[sector_data[sector][1]] = 0;
  70.     rgb[sector_data[sector][2]] = p;

  71.     return cvScalar(rgb[2], rgb[1], rgb[0],0);
  72. }

  73. int main( int argc, char** argv )
  74. {
  75.     CvCapture* capture = 0;
  76.    
  77.     if( argc == 1 || (argc == 2 && strlen(argv[1]) == 1 && isdigit(argv[1][0])))
  78.         capture = cvCaptureFromCAM( argc == 2 ? argv[1][0] - '0' : 0 );
  79.     else if( argc == 2 )
  80.         capture = cvCaptureFromAVI( argv[1] );

  81.     if( !capture )
  82.     {
  83.         fprintf(stderr,"Could not initialize capturing...\n");
  84.         return -1;
  85.     }

  86.     printf( "Hot keys: \n"
  87.         "\tESC - quit the program\n"
  88.         "\tc - stop the tracking\n"
  89.         "\tb - switch to/from backprojection view\n"
  90.         "\th - show/hide object histogram\n"
  91.         "To initialize tracking, select the object with mouse\n" );

  92.     cvNamedWindow( "Histogram", 1 );
  93.     cvNamedWindow( "CamShiftDemo", 1 );
  94.     cvSetMouseCallback( "CamShiftDemo", on_mouse, 0 );
  95.     cvCreateTrackbar( "Vmin", "CamShiftDemo", &vmin, 256, 0 );
  96.     cvCreateTrackbar( "Vmax", "CamShiftDemo", &vmax, 256, 0 );
  97.     cvCreateTrackbar( "Smin", "CamShiftDemo", &smin, 256, 0 );

  98.     for(;;)
  99.     {
  100.         IplImage* frame = 0;
  101.         int i, bin_w, c;

  102.         frame = cvQueryFrame( capture );
  103.         if( !frame )
  104.             break;

  105.         if( !image )
  106.         {
  107.             /* allocate all the buffers */
  108.             image = cvCreateImage( cvGetSize(frame), 8, 3 );
  109.             image->origin = frame->origin;
  110.             hsv = cvCreateImage( cvGetSize(frame), 8, 3 );
  111.             hue = cvCreateImage( cvGetSize(frame), 8, 1 );
  112.             mask = cvCreateImage( cvGetSize(frame), 8, 1 );
  113.             backproject = cvCreateImage( cvGetSize(frame), 8, 1 );
  114.             hist = cvCreateHist( 1, &hdims, CV_HIST_ARRAY, &hranges, 1 );
  115.             histimg = cvCreateImage( cvSize(320,200), 8, 3 );
  116.             cvZero( histimg );
  117.         }

  118.         cvCopy( frame, image, 0 );
  119.         cvCvtColor( image, hsv, CV_BGR2HSV );

  120.         if( track_object )
  121.         {
  122.             int _vmin = vmin, _vmax = vmax;

  123.             cvInRangeS( hsv, cvScalar(0,smin,MIN(_vmin,_vmax),0),
  124.                         cvScalar(180,256,MAX(_vmin,_vmax),0), mask );
  125.             cvSplit( hsv, hue, 0, 0, 0 );

  126.             if( track_object < 0 )
  127.             {
  128.                 float max_val = 0.f;
  129.                 cvSetImageROI( hue, selection );
  130.                 cvSetImageROI( mask, selection );
  131.                 cvCalcHist( &hue, hist, 0, mask );
  132.                 cvGetMinMaxHistValue( hist, 0, &max_val, 0, 0 );
  133.                 cvConvertScale( hist->bins, hist->bins, max_val ? 255. / max_val : 0., 0 );
  134.                 cvResetImageROI( hue );
  135.                 cvResetImageROI( mask );
  136.                 track_window = selection;
  137.                 track_object = 1;

  138.                 cvZero( histimg );
  139.                 bin_w = histimg->width / hdims;
  140.                 for( i = 0; i < hdims; i++ )
  141.                 {
  142.                     int val = cvRound( cvGetReal1D(hist->bins,i)*histimg->height/255 );
  143.                     CvScalar color = hsv2rgb(i*180.f/hdims);
  144.                     cvRectangle( histimg, cvPoint(i*bin_w,histimg->height),
  145.                                  cvPoint((i+1)*bin_w,histimg->height - val),
  146.                                  color, -1, 8, 0 );
  147.                 }
  148.             }

  149.             cvCalcBackProject( &hue, backproject, hist );
  150.             cvAnd( backproject, mask, backproject, 0 );
  151.             cvCamShift( backproject, track_window,
  152.                         cvTermCriteria( CV_TERMCRIT_EPS | CV_TERMCRIT_ITER, 10, 1 ),
  153.                         &track_comp, &track_box );
  154.             track_window = track_comp.rect;
  155.             
  156.             if( backproject_mode )
  157.                 cvCvtColor( backproject, image, CV_GRAY2BGR );
  158.             if( image->origin )
  159.                 track_box.angle = -track_box.angle;
  160.             cvEllipseBox( image, track_box, CV_RGB(255,0,0), 3, CV_AA, 0 );       //  cvEllipseBox是画一个椭圆的函数,我记得应该有中心点的位置,要看opencv函数的原型
  161.         }
  162.         
  163.         if( select_object && selection.width > 0 && selection.height > 0 )
  164.         {
  165.             cvSetImageROI( image, selection );
  166.             cvXorS( image, cvScalarAll(255), image, 0 );
  167.             cvResetImageROI( image );
  168.         }

  169.         cvShowImage( "CamShiftDemo", image );
  170.         cvShowImage( "Histogram", histimg );

  171.         c = cvWaitKey(10);
  172.         if( (char) c == 27 )
  173.             break;
  174.         switch( (char) c )
  175.         {
  176.         case 'b':
  177.             backproject_mode ^= 1;
  178.             break;
  179.         case 'c':
  180.             track_object = 0;
  181.             cvZero( histimg );
  182.             break;
  183.         case 'h':
  184.             show_hist ^= 1;
  185.             if( !show_hist )
  186.                 cvDestroyWindow( "Histogram" );
  187.             else
  188.                 cvNamedWindow( "Histogram", 1 );
  189.             break;
  190.         default:
  191.             ;
  192.         }
  193.     }

  194.     cvReleaseCapture( &capture );
  195.     cvDestroyWindow("CamShiftDemo");

  196.     return 0;
  197. }

  198. #ifdef _EiC
  199. main(1,"camshiftdemo.c");
  200. #endif
复制代码
我安装的是1.0版本的opencv    在C:\Program Files\OpenCV\samples\c里有一个可执行的程序camshiftdemo.exe,你要有摄像头就能运行,里面还有它的源代码。当年吵得沸沸扬扬的绿坝里,骗取人民大量税收的大骗子用的是这个开源的视觉处理库。。。另外串口部分,用windows 或者是linux下的串口程序就好了,反正都是大家熟悉的c语言。 至于控制部分,我是把图像分成9个区,跟踪的物体的坐标落在哪个区域里了判断出来发给单片机就行了

//  cvEllipseBox是画一个椭圆的函数,我记得应该有中心点的位置的参数,要看opencv官方提供的函数的原型的解释。

图像处理识别不是电子工程师不可触及的雷区,理解了他们的含义调用起来。希望有志于此的本科生学好数学,考研继续研究,也就是好多人疑问要不要读研究生,工作经验不是更好。像这种相对专业的东西,基本上都是得花时间专门搞的,那时候就是写库给别人用的层次了。


此处是当时的效果图,http://www.amobbs.com/thread-4626646-1-1.html,论坛改了之后地址变了,可惜不能更新到楼主位置了。提示一下可以用来做太阳能电池板跟踪吆。读书的时候拓展一下知识面,挺好的。毕业了也就没时间了,基本上此贴要说的也就这么多了

出0入0汤圆

发表于 2011-3-23 17:09:09 | 显示全部楼层
e....

出0入0汤圆

发表于 2011-3-23 17:16:22 | 显示全部楼层
不错,看看

出0入0汤圆

发表于 2011-3-23 17:17:48 | 显示全部楼层
回家再看。下班锻炼身体去了!

出0入0汤圆

发表于 2011-3-23 17:18:05 | 显示全部楼层
嘿嘿,高兴的飘过一下~~

出0入0汤圆

发表于 2011-3-23 17:53:09 | 显示全部楼层
都是动物头像

出0入0汤圆

发表于 2011-3-23 17:55:47 | 显示全部楼层
mark了看

出0入0汤圆

发表于 2011-3-24 22:54:04 | 显示全部楼层
mark、改天再看

出0入0汤圆

发表于 2011-3-24 23:12:24 | 显示全部楼层
很......悬

出0入0汤圆

发表于 2011-3-25 07:13:46 | 显示全部楼层
不久前买了个可以自动跟踪摄像头,这是它的介绍: Creative WebCam Center是一套功能强大的应用程序,让你可以执行先进的视频应用,例如:远程监控、动态侦测以及间隔摄影等等,并提供了浏览捕捉下来的视频及图片的功能。搭配 WebCam Live! Motion的可移动镜头,左右移动范围达200度;上下移动达105度。------试了效果很一般,

出0入0汤圆

发表于 2011-3-25 07:42:44 | 显示全部楼层
马克#

出0入0汤圆

发表于 2011-3-25 08:20:01 | 显示全部楼层
mark!!

出0入0汤圆

发表于 2011-3-25 08:34:03 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-25 08:50:45 | 显示全部楼层
看看

出0入0汤圆

发表于 2011-3-25 09:37:41 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-25 10:03:51 | 显示全部楼层
mark ...

出0入0汤圆

 楼主| 发表于 2011-3-25 15:03:13 | 显示全部楼层
回复【15楼】zhuhanliang
-----------------------------------------------------------------------

楼上,提上裤子,注意影响...

出0入0汤圆

发表于 2011-3-25 16:56:09 | 显示全部楼层
貌似蛮有意思的,留名,回头好好研究下。

出0入0汤圆

发表于 2011-3-25 17:35:02 | 显示全部楼层
牛!!

出0入0汤圆

发表于 2011-3-25 18:57:59 | 显示全部楼层
Mark

出0入0汤圆

发表于 2011-3-25 19:02:19 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-25 19:36:41 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-25 19:55:25 | 显示全部楼层
学习!!!!!

出0入0汤圆

发表于 2011-3-25 19:55:29 | 显示全部楼层
可以下到《学习OPENCV》的原本,呵呵没在这个电脑上,这书很不错,我拜读啦两个月,有了OPENCV,什么CV的问题都能解决。

但是,还有几个很不错的软件哦~ 比如 NI vision。我也常用。还有一个我忘记啦,是机器视觉的最专业的软件。“h”开头的

计算机视觉!

我做过机械仪表的数字化改造,就是把摄像头对到机械仪表盘上,标定之后就能出读书到计算机上录取,精度比眼高,速度比人快建议大家学习一下!

其实这个就和地形匹配有点关系啦。  可以结合google 地图 和GPS 再加上地形匹配,我们的四轴可以像战斧一样钻进人家的窗户里

出0入0汤圆

发表于 2011-3-25 20:10:07 | 显示全部楼层
好吧,这个我承认是打酱油的!

出0入0汤圆

发表于 2011-3-25 20:18:32 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-25 20:33:35 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-3-26 00:01:02 | 显示全部楼层
学习一下。

出0入0汤圆

发表于 2011-3-26 00:16:37 | 显示全部楼层
哈哈,这个讲解挺不错的。

出0入0汤圆

发表于 2011-3-26 00:20:24 | 显示全部楼层
MARK

出0入0汤圆

发表于 2011-3-26 11:53:16 | 显示全部楼层
MARK

出0入0汤圆

发表于 2011-3-28 15:30:12 | 显示全部楼层
学习

出0入0汤圆

 楼主| 发表于 2011-3-30 10:36:18 | 显示全部楼层

(原文件名:论文内容.JPG)

点击此处下载 ourdev_626733VYSPUJ.zip(文件大小:2.31M) (原文件名:camshift算法部分文献.zip)

出0入0汤圆

发表于 2011-3-30 10:38:11 | 显示全部楼层
昨天碰一牛人买家,这个是他的一些作品。。
http://www.cnblogs.com/yangyangcv/

出0入0汤圆

 楼主| 发表于 2011-3-30 11:26:54 | 显示全部楼层
回复【35楼】wangguanfu
-----------------------------------------------------------------------

"对CCV就不做过多介绍了,多点触摸的利器,几乎所有做多点触摸的公司都是直接使用或是间接借鉴了CCV,作为开发者之一鄙人相当自豪啊。"

这个没法比啊,人家专业是这个~~~

出0入0汤圆

发表于 2011-3-30 12:50:47 | 显示全部楼层
回复【35楼】wangguanfu
-----------------------------------------------------------------------

这个好像是模板匹配之类的,sift特征匹配等

出0入0汤圆

发表于 2011-3-30 12:54:44 | 显示全部楼层
回头学……

出0入0汤圆

发表于 2011-3-30 15:42:51 | 显示全部楼层
回复【24楼】yuxuanqq  
-----------------------------------------------------------------------
你说的那个叫halcon
www.mvtec.com/halcon/

出0入0汤圆

发表于 2011-3-30 15:48:11 | 显示全部楼层
m

出0入0汤圆

发表于 2011-3-30 16:04:52 | 显示全部楼层
mark!!!

出0入0汤圆

发表于 2011-3-30 16:58:50 | 显示全部楼层

出0入0汤圆

发表于 2011-3-30 17:04:16 | 显示全部楼层
貌似很好,mark~

出0入0汤圆

发表于 2011-5-24 13:14:55 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-5-24 13:34:08 | 显示全部楼层
maark

出0入0汤圆

发表于 2011-5-24 14:26:11 | 显示全部楼层
我承认,我看不懂

出0入0汤圆

发表于 2011-6-1 14:33:17 | 显示全部楼层
MARK

出0入0汤圆

发表于 2011-6-1 16:20:06 | 显示全部楼层
GOOD

出0入0汤圆

发表于 2011-6-1 18:07:32 | 显示全部楼层
请教兔斯基,OpenCV 能不能做对焦检测?用于控制镜头的聚焦

出0入0汤圆

发表于 2011-6-1 22:01:05 | 显示全部楼层
mark!

出0入0汤圆

发表于 2011-6-2 06:14:58 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-6-2 08:40:06 | 显示全部楼层
回复【楼主位】yirenonege  
-----------------------------------------------------------------------

这个我还真想过!
只是柑橘没什么用啊!

出0入0汤圆

发表于 2011-6-2 08:53:37 | 显示全部楼层
好呀

出0入0汤圆

发表于 2011-8-21 13:21:45 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-8-21 13:51:49 | 显示全部楼层
不明白,顶了再看

出0入0汤圆

发表于 2011-8-21 13:58:52 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-8-26 20:08:44 | 显示全部楼层
mark!!

出0入0汤圆

发表于 2011-11-21 14:12:41 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-11-21 18:08:06 | 显示全部楼层
创新的那个云台摄像头貌似有sdk  可惜太贵了

出15入9汤圆

发表于 2011-11-21 18:46:40 | 显示全部楼层
打包拿走。。

出0入0汤圆

发表于 2011-11-21 19:32:01 | 显示全部楼层
回复【35楼】wangguanfu
昨天碰一牛人买家,这个是他的一些作品。。
http://www.cnblogs.com/yangyangcv/
-----------------------------------------------------------------------

这个太牛X了啊!!

出0入0汤圆

发表于 2011-11-21 19:44:43 | 显示全部楼层
mark一下

出0入0汤圆

发表于 2011-11-21 19:48:05 | 显示全部楼层
顶!!

出0入0汤圆

发表于 2011-11-21 20:01:16 | 显示全部楼层
这个很有意思的样子,也想自己整一个。。

出0入0汤圆

发表于 2011-11-21 23:01:41 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-11-21 23:16:23 | 显示全部楼层
MARK!!

出0入0汤圆

发表于 2011-11-21 23:17:55 | 显示全部楼层
牛人

出0入0汤圆

发表于 2011-11-22 08:53:05 | 显示全部楼层
maark

出0入0汤圆

发表于 2011-11-22 09:09:10 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-11-22 09:16:59 | 显示全部楼层
MK

出0入0汤圆

发表于 2011-11-23 12:37:27 | 显示全部楼层
好贴!好人~!留个记号!

出0入0汤圆

发表于 2011-11-23 14:04:55 | 显示全部楼层
好人啊,不对,应该是好兔子啊,非常感谢

出0入0汤圆

发表于 2011-11-24 16:21:34 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-11-24 16:23:38 | 显示全部楼层
mark,,,这个是趋势。。。。。

出0入0汤圆

发表于 2011-11-24 16:31:17 | 显示全部楼层
mark!!!

出0入0汤圆

发表于 2011-11-24 16:36:33 | 显示全部楼层
先留个爪印,以后慢慢学!

出0入0汤圆

发表于 2011-11-24 17:45:23 | 显示全部楼层
mark

出0入0汤圆

发表于 2011-11-24 18:11:20 | 显示全部楼层
太好玩了 MARK一下

出0入0汤圆

发表于 2011-11-24 18:37:40 | 显示全部楼层
牛人 MARK

出0入0汤圆

发表于 2011-11-24 19:18:09 | 显示全部楼层
都是高手……

出0入0汤圆

发表于 2011-11-25 08:50:29 | 显示全部楼层
好东西啊,学习一下

出0入0汤圆

发表于 2011-11-28 21:56:09 | 显示全部楼层
学习下。。。准备加上个武器系统。。。。

出0入0汤圆

发表于 2011-12-5 21:06:38 | 显示全部楼层
有意思  mark

出0入0汤圆

发表于 2012-4-25 19:54:21 | 显示全部楼层
很不错 学习一下

出0入0汤圆

发表于 2012-4-26 15:47:57 | 显示全部楼层
学习学习

出0入0汤圆

发表于 2012-4-28 15:57:44 | 显示全部楼层
lz,你在第5点中说的opencv中的那个例子叫啥啊? 小弟在弄人脸跟踪,只能做到画红圈跟踪人脸,控制摄像头随着转动这块不知道用啥函数代码实现,希望lz能详细指教一下~真心感谢!

出0入0汤圆

发表于 2012-8-29 12:54:30 | 显示全部楼层
你的QQ是多少啊?

出0入0汤圆

发表于 2012-8-29 13:56:22 | 显示全部楼层
djlakdjlsjdlajljdlajsljla

出0入0汤圆

发表于 2012-8-29 14:08:46 | 显示全部楼层
你QQ 是多少啊?

出0入0汤圆

发表于 2012-8-29 15:28:12 | 显示全部楼层
你QQ是多少啊?

出0入0汤圆

发表于 2012-8-29 15:28:54 | 显示全部楼层
你QQ是多少啊?

出0入0汤圆

发表于 2012-8-29 15:31:00 | 显示全部楼层
你QQ 是多少啊?

出0入0汤圆

发表于 2012-8-29 15:31:30 | 显示全部楼层
你QQ 多少啊?

出0入0汤圆

发表于 2012-8-29 15:41:06 | 显示全部楼层
mark  一下

出0入0汤圆

发表于 2012-8-29 16:05:51 | 显示全部楼层
mark!!!!!!!!!

出0入0汤圆

 楼主| 发表于 2012-8-29 16:08:20 | 显示全部楼层
hjh198773 发表于 2012-8-29 15:31
你QQ 多少啊?

我现在不搞图像处理了,只是当时有兴趣研究了一下,我以为陈年老帖没人看了,取消回复了。。。主要是修改了OPENCV里面自带的例程,里面有一个摄像头追踪物体的代码,阅读之后找到追踪到后的坐标就可以了

出0入0汤圆

 楼主| 发表于 2012-8-29 16:09:58 | 显示全部楼层
ydy65683 发表于 2012-4-28 15:57
lz,你在第5点中说的opencv中的那个例子叫啥啊? 小弟在弄人脸跟踪,只能做到画红圈跟踪人脸,控制摄像头随 ...

很抱歉现在才看到,我记得是安装完opencv安装文件夹里的例程里自带  

出0入0汤圆

发表于 2012-8-29 17:07:34 | 显示全部楼层
很厉害的大牛

出0入0汤圆

发表于 2012-8-29 17:45:14 | 显示全部楼层
载安装好opencv库后可以看到里面有一些例子,其中一个是摄像头跟踪选定物体的应用程序,这个在哪下载啊?
控制云台有源代码吗?
你上面的代码是什么?

出0入0汤圆

发表于 2012-8-29 17:46:43 | 显示全部楼层
能不能把这个项目具体的说说下啊?
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-26 21:14

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表