单摄像头+激光测距
如何用摄像头来测距(opencv)作者:郭世龙 最近一直忙着找工作,blog都长草了,今天把以前作的一个东西放上来充充门面吧。记得在哪看到过老外做的这个东西,觉得很好玩,就自己也做了一个。在摄像头下面固定一个激光笔,就构成了这个简易的测距装置。看一下图吧。 原 理 假设激光束是与摄像头的光轴完全平行,激光束的中心落点在在摄像头的视域中
·
作者:郭世龙
(1)
θ可通过下式计算:
θ=Num*Rop+Offset (2)
其中:Num是从图像中心到落点的像素个数
Rop是每个像素的弧度值
Offset是弧度误差
合并以上等式可以得到:

Num可以从图像上计算得到。Rop和Offset需要通过实验计算获得。首先测量出D的准确值,然后根据等式(1)可以计算出准确的θ,根据等式(2)可到只含有参数Rop和Offset的方程。在不同的距离多次测量D的准确值计算θ,求解方程组可以求出Rop和Offset。这里Rop=0.0030354,Offset=0.056514344。

程 序
头文件:
class LaserRange
{
public:
struct RangeResult * GetRange(IplImage * imgRange,IplImage * imgDst);
LaserRange();
virtual ~LaserRange();
{
public:
struct RangeResult * GetRange(IplImage * imgRange,IplImage * imgDst);
private:
unsigned int maxW;
unsigned int maxH;
unsigned int MaxPixel;
RangeResult * strctResult;
// Values used for calculating range from captured image data
const double gain; // Gain Constant used for converting pixel offset to angle in radians
const double offset; // Offset Constant
const double h_cm; // Distance between center of camera and laser
unsigned int pixels_from_center; // Brightest pixel location from center
};
cpp文件:
LaserRange::LaserRange():gain(0.0030354),offset(0),h_cm(4.542)
{
LaserRange::~LaserRange()
{
if(NULL!=strctResult) delete strctResult;
}
{
}
struct RangeResult * LaserRange::GetRange(IplImage * imgRange,IplImage * imgDst)
{
if(NULL==imgRange) return strctResult;
Preprocess(imgRange,imgDst);
pixels_from_center = abs(120-maxH);
{
}
void LaserRange::Preprocess(void *img, IplImage * imgTemp)
{
}
调用函数:
int CLaserVisionDlg::CaptureImage()
{
// CvCapture* capture = 0;
// capture = cvCaptureFromCAM(0); //0表示设备号
if( !capture )
{
fprintf(stderr,"Could not initialize capturing.../n");
return -1;
}
// cvNamedWindow( "LaserRangeImage", 1 );
// cvvNamedWindow( "image", 1);
cvvNamedWindow( "Dimage", 1);
for(;;)
{
IplImage* frame = 0;
if(isStop) break;
{
//cvReleaseCapture( &capture );
//cvDestroyWindow("LaserRangeImage");
// cvDestroyWindow( "image");
cvDestroyWindow( "Dimage");
return 0;
}
//cvDestroyWindow("LaserRangeImage");
// cvDestroyWindow( "image");
return 0;
}
更多推荐
所有评论(0)