基于EmguCV的摄像机标定及矫正
版权声明:本文为博主原创文章,未经博主允许不得转载。
前言
之前用OpenCV做过摄像机标定及矫正,现在平台换了,改用C#,就用EmguCV做一下,其实就是OpenCV的C#版。
在EmguCV中有两类摄像机标定的类,一个是CvInvoke类,一个是CameraCalibration类,两种标定效果差不多,只不过CvInvoke涉及的函数大多都是指针类型的,而C#对于指针的操作比较麻烦。本文是在CameraCalibration类的基础上完成摄像机标定,用CvInvoke类完成矫正图像。
函数说明
1、角点检测
- public static PointF[] FindChessboardCorners(
- Image<Gray, byte> image,
- Size patternSize,
- CALIB_CB_TYPE flags
- )
Parameters
- image
- Type: Emgu.CV.Image<Gray, Byte>Source chessboard view
- patternSize
- Type: System.Drawing.SizeThe number of inner corners per chessboard row and column
- flags
- Type: Emgu.CV.CvEnum.CALIB_CB_TYPEVarious operation flags
Return Value
Type: PointF[]The corners detected if the chess board pattern is found, otherwise null is returned
注:输入图像需是灰度图,检测之前角点需要开辟空间,如:
- cornersDetected = new PointF[nPoints]; //nPoints表示单幅图像角点总数
- cornersDetected = CameraCalibration.FindChessboardCorners(chessboardImage, patternSize,
- CALIB_CB_TYPE.ADAPTIVE_THRESH | CALIB_CB_TYPE.NORMALIZE_IMAGE);
2、标定函数
- public static double CalibrateCamera(
- MCvPoint3D32f[][] objectPoints,
- PointF[][] imagePoints,
- Size imageSize,
- IntrinsicCameraParameters intrinsicParam,
- CALIB_TYPE calibrationType,
- MCvTermCriteria termCriteria,
- out ExtrinsicCameraParameters[] extrinsicParams
- )
Parameters
- objectPoints
- Type: Emgu.CV.Structure.MCvPoint3D32f[][]The 3D location of the object points. The first index is the index of image, second index is the index of the point
- imagePoints
- Type: System.Drawing..::..PointF[][]The 2D image location of the points. The first index is the index of the image, second index is the index of the point
- imageSize
- Type: System.Drawing.SizeThe size of the image, used only to initialize intrinsic camera matrix
- intrinsicParam
- Type: Emgu.CV.IntrinsicCameraParametersThe intrisinc parameters, might contains some initial values. The values will be modified by this function.
- calibrationType
- Type: Emgu.CV.CvEnum.CALIB_TYPEcCalibration type
- termCriteria
- Type: Emgu.CV.Structure.MCvTermCriteriaThe termination criteria
- extrinsicParams
- Type: Emgu.CV.ExtrinsicCameraParameters[]The output array of extrinsic parameters.
Return Value
Type: DoubleThe final reprojection error注:objectPoints表示棋盘角点在世界坐标系下的坐标,有多少幅棋盘图像就应有多少角点坐标集,以物理尺寸为单位。imagePoints表示角点在图像中的坐标,以像素为单位。返回值是重投影误差。
3、映射矩阵求取
- public static void cvInitUndistortMap(
- IntPtr intrinsicMatrix,
- IntPtr distortionCoeffs,
- IntPtr mapx,
- IntPtr mapy
- )
Parameters
- intrinsicMatrix
- Type: System.IntPtrThe camera matrix (A) [fx 0 cx; 0 fy cy; 0 0 1]
- distortionCoeffs
- Type: System.ntPtrThe vector of distortion coefficients, 4x1 or 1x4 [k1, k2, p1, p2].
- mapx
- Type: System.IntPtrThe output array of x-coordinates of the map
- mapy
- Type: System.ntPtrThe output array of y-coordinates of the map
注:定义Matrix类的映射矩阵变量,其属性中包含Ptr,可以直接当指针用,如:
- private Matrix<float> mapx = new Matrix<float>(height, width);
- private Matrix<float> mapy = new Matrix<float>(height, width);
4、几何变换
- public static void cvRemap(
- IntPtr src,
- IntPtr dst,
- IntPtr mapx,
- IntPtr mapy,
- int flags,
- MCvScalar fillval
- )
Parameters
- src
- Type: System.ntPtr
Source image
- dst
- Type: System.IntPtr
Destination image
- mapx
- Type: System.IntPtr
The map of x-coordinates (32fC1 image)
- mapy
- Type: System.ntPtr
The map of y-coordinates (32fC1 image)
- flags
- Type: System.Int32
A combination of interpolation method and the optional flag CV_WARP_FILL_OUTLIERS
- fillval
- Type: Emgu.CV.Structure.MCvScalar
A value used to fill outliers
注:flags定义在 CvEnum下的 WARP枚举类型,调用: (int)WARP.CV_WARP_INVERSE_MAP
程序说明
基于EmguCV摄像机标定及矫正的软件界面如下:
如图所示,界面包含棋盘格信息设置,标定及矫正事件的实现等等。
矫正前后图像对比:
代码实现了从摄像头读取棋盘格图像或者从本地读取图像,图像个数有Imges指定,棋盘格大小有Square Size指定;然后成功检测到角点之后进行摄像头标定,保存角点值和摄像头内参数,通过Rectify按钮实现畸变矫正功能。为避免每次标定时都要检测角点,设置Read Corners按钮,读取角点(包含objectPoints和imagePoints),然后Start Calibrate实现标定。所有的数据都是保存到xml文件中,方便查看和提取。
基于EmguCV的摄像机标定及矫正的更多相关文章
- 机器视觉学习笔记(5)——基于OpenCV的单目摄像机标定
本文CameraCalibrator类源代码来自于OpenCV2 计算机视觉编程手册(Robert Laganiere 著 张静 译) 强烈建议阅读机器视觉学习笔记(4)--单目摄像机标定参数说明之后 ...
- halcon摄像机标定
摄像机标定程序: 注意:E:/calibration_image :为标定图像文件路径 'E:/calibration_description/caltab_123mm.descr:为标定 ...
- 相机标定过程(opencv) + matlab参数导入opencv + matlab标定和矫正
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% 辛苦原创所得,转载请注明出处 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% ...
- [zt]摄像机标定(Camera calibration)笔记
http://www.cnblogs.com/mfryf/archive/2012/03/31/2426324.html 一 作用建立3D到2D的映射关系,一旦标定后,对于一个摄像机内部参数K(光心焦 ...
- [OpenCV-Python] OpenCV 中摄像机标定和 3D 重构 部分 VII
部分 VII摄像机标定和 3D 重构 OpenCV-Python 中文教程(搬运)目录 42 摄像机标定 目标 • 学习摄像机畸变以及摄像机的内部参数和外部参数 • 学习找到这些参数,对畸变图像进行修 ...
- 【OpenCV】摄像机标定+畸变校正
摄像机标定 本文目的在于记录如何使用MATLAB做摄像机标定,并通过OpenCV进行校正后的显示. 首先关于校正的基本知识通过OpenCV官网的介绍即可简单了解: http://docs.open ...
- 相机标定与矫正opencv+MATLAB
博客转载自:http://blog.csdn.net/Loser__Wang/article/details/51811347 本文目的在于记录如何使用MATLAB做摄像机标定,并通过opencv进行 ...
- Matlab 摄像机标定+畸变校正
博客转载自:http://blog.csdn.net/Loser__Wang/article/details/51811347 本文目的在于记录如何使用MATLAB做摄像机标定,并通过opencv进行 ...
- C#下的摄像机标定
前言:计算机视觉的基本任务之一是从摄像机获取的图像信息出发计算三维空间中物体的几何信息,并由此重建和识别物体,而空间物体表面某点的三维几何位置与其在图像中对应点之间的相互关系是由摄像机成像的几何模型决 ...
随机推荐
- Js怎么获取DOM及获取浏览器的宽高?
在JavaScript中,经常会需要获取document文档元素,是HTML文档对象模型的缩写,HTML DOM 定义了用于 HTML 的一系列标准的对象,以及访问和处理 HTML 文档的标准方法. ...
- 在Ubuntu14.04中配置mysql远程连接教程
上一篇文章,小编带大家学会了在Ubuntu14.04中安装MySQL,没有来得及上课的小伙伴们可以戳这篇文章:如何在Ubuntu14.04中安装mysql,今天给大家分享一下,如何简单的配置MySQL ...
- Js 中的i++ 和 ++i 的区别
首先碰见 i++ 和 ++i 会一脸蒙蔽 感觉没什么区别,都是相加 , 但是 输出的值是不同!!! 来奉上代码来进行比较 var i = 1; var a = i++; //a = 1; 此时i ...
- JAVA学习(一)——基本语法
tips:前端开发写惯了弱类型语言,再来学强类型语言,真的是被各种修饰符.类型声明给整的云里雾里,而且java语法和javascript语言差别还是很大的,所以做好笔记,把一些需要注意的地方记下来是非 ...
- iscsi共享存储的简单配置和应用
1.环境介绍 SCSI(Small Computer System Interface)是块数据传输协议,在存储行业广泛应用,是存储设备最基本的标准协议.从根本上说,iSCSI协议是一种利用IP网络来 ...
- Struts(18)标签
控件标签 Struts 2 的标签有一组标签.更easy控制流程页面运行.下面是重要的Struts2控制标签列表: if /else 标签: 这些标签运行可在每一种语言找到的一种基本条件流程. 'If ...
- NYOJ 203 三国志(Dijkstra+贪心)
三国志 时间限制:3000 ms | 内存限制:65535 KB 难度:5 描写叙述 <三国志>是一款非常经典的经营策略类游戏.我们的小白同学是这款游戏的忠实玩家.如今他把游戏简化一下 ...
- 洛谷P1722 矩阵 II
题目背景 usqwedf 改编系列题. 题目描述 如果你在百忙之中抽空看题,请自动跳到第六行. 众所周知,在中国古代算筹中,红为正,黑为负…… 给定一个1*(2n)的矩阵(usqwedf:这不是一个2 ...
- JavaScript--数据结构算法之链表
数组的缺点:数组的长度固定,增删时比较困难要移动元素,而且数据填满再添加元素比较复杂.js:数组有split(),可以任意的分割.不存在上述问题.主要问题是:js数组都被实现成了对象,和其他语言的数组 ...
- C# Unable to load DLL 'WzCanDll.dll':找不到指定的模块
一.打开app无法加载DLL 我用C++编写的DLL,然后用C#写的界面APP,在自己的电脑上打开没有问题,放在其它电脑上就出现无法加载DLL库的问题,一连接APP就会出现问题,如下图所示: 二.解决 ...