Kinect2.0-空间长度测量

1.

鼠标左键按下选择起点,拖动鼠标,左键放开,确定终点。

img_b8681109536af93105198fdf88c4965a.png
实现效果1

img_622b2e0506dc262aa9ac91fe11028b27.png
实现效果2

2.

在linux下使用libfreenect2开源多平台驱动来获取kinect2.0的传感器信息,得到深度信息,并通过libfreenect2提供的getPointXYZ函数,来得到相机坐标系中某一点的空间坐标。

img_4f64dedc4df690d57aef4191c8780d73.png

3.

运用鼠标操作函数(setMouseCallback),来获取画面中的两个点,并用直线将他们连接起来,通过(2)中的方法得到两点的空间坐标:A(x1,y1,z1),B(x2,y2,z2)。通过简单计算,便可以求得两点的实际距离。



4.

关键代码:

    while(!protonect_shutdown){listener.waitForNewFrame(frames);libfreenect2::Frame *rgb = frames[libfreenect2::Frame::Color];libfreenect2::Frame *depth = frames[libfreenect2::Frame::Depth];cv::Mat(rgb->height, rgb->width, CV_8UC4, rgb->data).copyTo(rgbmat);cv::Mat(depth->height, depth->width, CV_32FC1, depth->data).copyTo(depthmat);cv::Mat(registered.height, registered.width, CV_8UC4, registered.data).copyTo(rgbd);registration->apply(rgb, depth, &undistorted, &registered, true, &depth2rgb);cv::Mat(registered.height, registered.width, CV_8UC4, registered.data).copyTo(rgbd);//resize(rgbmat, dst1, Size(), c, d, INTER_NEAREST);inRange(depthmat,Scalar(a),Scalar(b),dst);//morphologyEx(dst,dst,MORPH_OPEN,kernel);findContours(dst,contours,hireachy,RETR_EXTERNAL,CHAIN_APPROX_SIMPLE,Point(0,0));if (contours.size() > 0){double maxArea=0;for (int i = 0; i < contours.size(); i++){double area = contourArea(contours[static_cast<int>(i)]);if (area > maxArea){maxArea = area;rect = boundingRect(contours[static_cast<int>(i)]);minEnclosingCircle(contours[static_cast<int>(i)], center, radius);}}}setMouseCallback("main",on_MouseHandle);     // 鼠标操作registration->getPointXYZ(&undistorted, pt11.y, pt11.x,x1, y1, z1);  // 像素坐标转化为空间坐标registration->getPointXYZ(&undistorted,pt21.y,pt21.x,x2, y2, z2);//rectangle(rgbd, rect, Scalar(0,255,0),2);line(rgbd, pt11, pt21, Scalar(0,255,0));   //  划线l = sqrt(pow((x1-x2),2) + pow((y1-y2),2) + pow((z1-z2),2));cout << "length:" << l << "m" <<endl;   // 输出长度sprintf(str, "%.4lf", l);putText(rgbd, str1, pt21, FONT_HERSHEY_COMPLEX, 1,Scalar(0, 0, 255), 1);putText(rgbd, str, pt21, FONT_HERSHEY_COMPLEX, 1,Scalar(0, 0, 255), 1);circle(rgbd, pt11, 1, Scalar(255,255,0), 2);circle(rgbd, pt21, 1, Scalar(255,255,0), 2);cv::imshow("catch",dst);cv::imshow("depth", depthmat /4500.0);cv::imshow("main", rgbd);int key = cv::waitKey(1);protonect_shutdown = protonect_shutdown || (key > 0 && ((key & 0xFF) == 27)); // shutdown on escapelistener.release(frames);}dev->stop();dev->close();delete registration;#endifstd::cout << "stop!" << std::endl;return 0;
}void on_MouseHandle(int event, int x, int y, int flags, void* ustc)
{if (event == EVENT_LBUTTONDOWN){Point pt1 = Point(x, y);pt11 = pt1;}else if (event == EVENT_LBUTTONUP){Point pt2 = Point(x, y);pt21 = pt2;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/450850.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

带数据库的智能合约

编写使用数据库的智能合约 前面一直在捣鼓EOS网络搭建的相关东西。然而今天比较不走运的是&#xff0c;兴致勃勃的把源码版本升到4.0&#xff0c;在编译的时候如我所猜想的出现了一系列问题&#xff0c;正一筹莫展的时候&#xff0c;导师突然问了我一个关于合约如何操作数据库的…

没有完美的软件:编程永远不容易

摘要&#xff1a;很多人想用十全十美来修饰一样东西&#xff0c;比如软件&#xff0c;对于客户来说&#xff0c;当然希望他们的软件能做到完美。虽然很多专家说利用一些规范可以让软件达到更好&#xff01;但是在现实开发中&#xff0c;真的会有那么完美的软件吗&#xff1f; 最…

Eclipse断点调试出现Source not found

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 我的情况是和网上说的都不一样&#xff0c;我真的也没有想到这么坑&#xff0c; 我居然无意写了一个死循环&#xff0c;dao/mapper调sql…

Memory Compression这到底是个什么东西?

Memory Compression这到底是个什么东西&#xff1f; Memory Compression这个进程&#xff0c;经过我的查询说是内存压缩功能&#xff0c;作用是压缩内存让内存占用更低&#xff0c;但是为什么这个进程疯狂占用我的内存&#xff0c;我用的Win10 8G&#xff0c;通过资源监视器查看…

MySQL 5.6 for Windows 解压缩版配置安装

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 MySQL是一个小巧玲珑但功能强大的数据库&#xff0c;目前十分流行。但是官网给出的安装包有两种格式&#xff0c;一个是msi格式&#xf…

safari的一些问题

1、图片过大时&#xff0c;在webview中是不会加载显示的。2、如果是通过一个地址返回的base64数据给image&#xff0c;记住要在后台进行base64_decode解析数据&#xff0c;这样才是真实的图片数据&#xff0c;后台保存数据的时候不要保存"data:image/png;base64,"这一…

代码审查“思维导图”

摘要&#xff1a;随着人们对软件质量要求的不断提高&#xff0c;软件开发的每一个环节都应该得到十足的重视&#xff0c;俗话说&#xff1a;“细节决定成败”&#xff0c;就此&#xff0c;本文提供了一个代码审查“思维导图”&#xff0c;希望对所有码农们有所帮助。 代码审查&…

thinkCMF----导航高亮显示

导航高亮显示&#xff0c;有多种方法&#xff0c;这里给出一个简单的表示下&#xff1a; <a href"__ROOT__"><span class"text db">网站首页</span><span class"eng db">HOME</span> </a> …

The absolute uri: http://java.sun.com/jsp/jstl/core cannot be resolved in either web.xml or the jar

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 tomcat启动报务后访问页面报错&#xff1a; org.apache.jasper.JasperException: The absolute uri: http://java.sun.com/jsp/jstl/co…

优秀程序员和一般程序员差别在哪?

摘要&#xff1a;在这个世界上有两种程序员&#xff1a;Day Programmers&#xff08;白班程序员&#xff09;和Night Programmers&#xff08;夜猫子程序员&#xff09;&#xff0c;你知道优秀程序员和一般程序员有哪些差别吗&#xff1f;你又是哪一类型的呢&#xff1f;俗话说…

7. Oracle数据加载和卸载

在日常工作中&#xff1b;经常会遇到这样的需求&#xff1a; Oracle 数据表跟文本或者文件格式进行交互&#xff1b;即将指定文件内容导入对应的 Oracle 数据表中&#xff1b;或者从 Oracle 数据表导出。其他数据库中的表跟Oracle数据库进行交互。若是少量数据&#xff1b;可选…

Navicat工具导出mySQL数据库某个视图结构的.sql脚本

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 用Navicat工具怎么都导不出来mySQL数据库的某个视图.sql脚本&#xff0c;即使导出来也只是包含视图记录&#xff0c;不包含视图结构。经…

瞧瞧苹果OS X如何干掉Linux

摘要&#xff1a;如果你去过Facebook或者其它一些创业类科技公司&#xff0c;你会发现随处可见的Mac&#xff0c;无论是CEO还是开发者&#xff0c;都可能在使用Mac。而以往很受IT人士青睐的Linux好像在消失&#xff0c;这是真的吗&#xff1f;苹果OS X是如何干掉Linux的&#x…

超全十大经典排序算法及其分析

文章目录0.算法概述0.1 算法分类0.2 算法复杂度0.3 相关概念1. 冒泡排序&#xff08;Bubble Sort&#xff09;1.1 算法描述&#xff1a;1.2 图解演示1.3 代码实现1.4 优化过程1.5 性能分析2. 选择排序&#xff08;Selection Sort&#xff09;2.1 算法描述&#xff1a;2.2 图解演…

eclipse安装JAVA反编译插件

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程。 前言&#xff1a;在实际的开发中几乎都会使用到一些框架来辅助项目的开发工作&#xff0c;对于一些框架的代码我们总怀有一些好奇之心&a…

noip2014生活大爆炸版石头剪刀布

题目描述 石头剪刀布是常见的猜拳游戏:石头胜剪刀,剪刀胜布,布胜石头。如果两个人出拳一 样&#xff0c;则不分胜负。在《生活大爆炸》第二季第8集中出现了一种石头剪刀布的升级版游戏。 升级版游戏在传统的石头剪刀布游戏的基础上,增加了两个新手势: 斯波克:《星际迷航》主角之…

初识react(二) 实现一个简版的html+redux.js的demo

回顾 初识react(一) 揭开jsx语法和虚拟DOM面纱初识react(二) 实现一个简版的htmlredux.js的demo初识react(三)在 react中使用redux来实现简版计数器初识react(四) react中异步解决方案之 redux-saga初识react(五) 数据流终极解决方案 dva(零配置)前言 首先纠正个误区&#xff0…

12个有趣的C语言面试题

摘要&#xff1a;12个C语言面试题&#xff0c;涉及指针、进程、运算、结构体、函数、内存&#xff0c;看看你能做出几个&#xff01; 1.gets()函数 问&#xff1a;请找出下面代码里的问题&#xff1a; #include<stdio.h> int main(void) { char buff[10]; memset…

超全Typora快速入门

文章目录一.Typora快速入门1.代码块2.标题3.字体4.引用5.水平分割线6.图片插入7.超链接8.列表9.表格10.任务列表11.数学表达式12.生成目录13.表情符号14.定义脚注15.文件导出16.主题修改17.修改主题背景图片18.设置背景透明度19.Typora 插入图片调整大小20.字体和颜色21.页内跳…

聊聊毕业设计系列 --- 系统实现

效果展示 github moment-server github地址 moment github地址 moment-manage github地址 articles 聊聊毕业设计系列 --- 项目介绍 聊聊毕业设计系列 --- 系统实现 前言 在上一篇文章中&#xff0c;主要是对项目做了介绍&#xff0c;并且对系统分析和系统设计做了大概的介绍。…