计算机视觉
图像处理

Android手机摄像头实现长度测量

前言:该项目创作于几年前,当时采用的技术和开发环境想必现在已经得到了大大的改进,欢迎有了解最新技术进展的同行来交流指点。

android手机摄像头实现长度测量

1.功能简介
使用手机摄像头拍摄目标物体两个角度的图片,运用两视点几何的原理得到物体的三维坐标点,从而实现无接触测量距离。2.软件特点

移动:运行在Android智能手机上,随时随地可以使用。
实用:我们身上不会带上尺子,但手机却是随身携带的物品,如果需要测量,拿出手机拍两幅物体的照片就能够得到长度信息;另外有的时候条件不允许接触测量,比如危险物品、贵重物品以及难以触及的物品,但使用这款软件就无需接触实现距离的测量。
易用:分别从两个角度拍摄物体的两幅图片,选择始点和终点,程序就会计算出两点的距离展示给用户。

3.系统设计

实现方法——古典+现代:

使用初等凸透镜成像公式?
理想情况,假定f可变焦、成像点清晰
实际情况,焦距一般固定,三维物体距离不同,无法在f下得到清晰像点,清晰不好判断、坐标系统不好固定。
3.1射影几何与计算机视觉对极几何
3基于针孔摄像头模型,空间中一点M到像平面点m的映射要经过投影矩阵P的转换(如下图),sm=K[R | T]M,其中K是摄像头参数矩阵,R、T是摄像头坐标系相对于世界坐标系的旋转和平移矩阵,sm是像点的齐次坐标。

空间物体点通过两个投影矩阵投影到左右两幅图像上,根据三维重构的理论,只需要得到这两个投影矩阵以及两个像点在图像上的坐标就可以使用三角法定位目标点三维坐标。
根据投影矩阵的构成,获取摄像头参数矩阵K、拍摄第二幅图像时候摄像头经历的刚体变换——旋转和平移 (R | T)矩阵是整个系统实现的关键。

3.2获取手机摄像头参数矩阵K:

使用张正友标定法”Flexible Camera Calibration ByViewing a Plane From Unknown Orientations”,这个方法操作比较容易,只需要做一幅黑白棋盘(显示器打开这样一幅图片也可以),用手机摄像头从不同角度拍摄大约10幅棋盘 的图片,使用他们算法实现的标定程序就可以得到摄像头参数矩阵。

如果以拍摄第一幅图的摄像机坐标系作为参考坐标系,那么第一个摄像头位置的R就是单位矩阵I,T没有平移为零。
运用对极几何的理论,第二个位置的R和T可以利用两幅图片的对应关系求出来,只要找到7对以上的匹配点就可以把两幅图像的内在关系计算出来,当然匹配的点越多越准确,后继的操作也就越精准。

3.3对应点匹配

人工目测匹配    优点:确保100%准确       缺点:费时,匹配的点少
算法自动匹配    优点:快速,匹配点多     缺点:复杂环境下匹配不准确

3.4计算R和T

使用匹配的特征点对计算出基本矩阵F,根据匹配点的数目可以选择使用7点法、8点法、RANSAC等计算F的算法
计算本质矩阵E,E等于K的转置矩阵左乘F再左乘K

对E进行SVD分解,得到的U矩阵的最后一列乘以单值即为平移向量T,U矩阵左乘反对称矩阵再左乘V转置矩阵即得到旋转矩阵R。

3.5Android手机上的实现

因为只需要选择七个点就足够计算本质矩阵,进入选点界面后可以看到七个彩色小点排成北斗七星形状,通过触摸移动这些小点到特征明显的位置比如角 点。为了实现实时处理,核心运算代码会调用到OpenCv(开源计算机视觉库),编写好C++程序之后通过NDK把源代码编译成可以供Android端 java程序调用的动态链接库。

使用方法

1)从两个不同角度拍摄目标。
2)在第一幅图片上移动彩色小点,选择七个处于三维空间的点;右图需找到和左图相匹配的七个点。

3)点击测量距离按钮得到7个点两两以厘米为单位的实际距离,并返回第一和第二个点之间的距离。

 

 

使用手机摄像头拍摄目标物体两个角度的图片,运用两视点几何的原理得到物体的三维坐标点,从而实现无接触测量距离。摄像头标定、图像特征点匹配、计算基本矩阵和本质矩阵、SVD分解得到旋转平移矩阵、使用三角法计算目标点的三维坐标,计算距离。

文中的图片无法显现,可下载pdf版,下载地址:

!!温馨提示: 此处需要评论本文后才能查看.

转载注明来源:CV视觉网 » Android手机摄像头实现长度测量

分享到:更多 ()
扫描二维码,给作者 打赏
pay_weixinpay_weixin

请选择你看完该文章的感受:

2不错 4超赞 1无聊 0扯淡 0不解 2路过

评论 4

评论前必须登录!

 

  1. #4

    了解下实现

    sxc_guy1个月前 (03-19)
  2. #3

    很好

    shijiajin2年前 (2017-03-01)
  3. #2

    检测矩形怎么弄

    libin2年前 (2017-02-27)
  4. #1

    之前接触过这方面的,想看下实现速度以及实现精度。

    westlife3962年前 (2016-12-14)