使用OpenCV VideoCapture获取Kinect图像

2024-03-15 21:18

本文主要是介绍使用OpenCV VideoCapture获取Kinect图像,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        与OpenNI兼容的深度传感器(Kinect, XtionPRO,...)被VideoCapture类支持, 深度图像,RGB图像和其他种类的输出可以使用类似于VideoCapture的接口retrieve。为了使用OpenCV的深度传感器,你需要完成下面的步骤:

1.安装OpenNI 库(从http://www.openni.org/downloadfiles下载)和针对OpenNI的PrimeSensor组件(从https://github.com/avin2/SensorKinect 下载)。安装需要按照指导放在默认的文件夹下。

2. 在CMake中设置WITH_OPENNI标志,用OpenNI配置OpenCV。如果没有发现PrimeSensor 组件,但发现OpenNI在安装文件下(查看CMake log 下状态OpenNI PrimeSensor Modules),OpenCV将与OpenNI库一起编译(查看CMake log下状态OpenNI)。没有PrimeSensor module OpenCV 将和OpenNI库一起成功编译,但是VideoCapture对象却无法从Kinect传感器抓取图像

3.编译OpenCV

VideoCapture 可以retrieve下列数据:

1.从depth generator取数据

OPENNI_DEPTH_MAP - depth values in mm(CV_16UC1)

OPENNI_POINT_CLOUD_MAP- XYZ in meters(CV_32FC3)

OPENNI_DISPARITY_MAP - disparity in pixels(CV_8UC1)

OPENNI_DISPARITY_MAP_32F - disparity in pixels (CV_32FC1)

OPENNI_VALID_DEPTH_MASK - mask of valid pixels (not ocluded, not shaded etc.) (CV_8UC1)

2.从RGB image generator得到的数据

OPENNI_BGR_IMAGE - color image (CV_8UC3)
OPENNI_GRAY_IMAGE - gray image (CV_8UC1)

为了得到从深度传感器得到深度图像,使用VideoCapture::operator >>, 例如

for(;;)
{
Mat depthMap;
capture >> depthMap;
if( waitKey( 30 ) >= 0 )
break;
}

得到几幅数据图使用VideoCapture::grab和VideoCapture::retrieve,例如

VideoCapture capture(0); // or CV_CAP_OPENNI
for(;;)
{
Mat depthMap;
Mat rgbImage
capture.grab();
capture.retrieve( depthMap, OPENNI_DEPTH_MAP );
capture.retrieve( bgrImage, OPENNI_BGR_IMAGE );
if( waitKey( 30 ) >= 0 )
break;
}

设置和读取传感器的特性,使用VideoCapture::set 和 VideoCapture::get,例如

VideoCapture capture( CV_CAP_OPENNI );
capture.set( CV_CAP_OPENNI_IMAGE_GENERATOR_OUTPUT_MODE, CV_CAP_OPENNI_VGA_30HZ );
cout << "FPS " << capture.get( CV_CAP_OPENNI_IMAGE_GENERATOR+CV_CAP_PROP_FPS ) << endl;

由于有两种传感器数据生成器被支持,有对应的两个标志

 CV_CAP_OPENNI_IMAGE_GENERATOR –访问the image generator 属性的标志.
 CV_CAP_OPENNI_DEPTH_GENERATOR – 访问 the depth generator 属性的标志. 默认设置

一些深度传感器(例如XtionPRO)没有image generator,可以通CV_CAP_OPENNI_IMAGE_GENERATOR_PRESENT属性查看。

bool isImageGeneratorPresent = capture.get( CV_CAP_PROP_OPENNI_IMAGE_GENERATOR_PRESENT ) != 0; // or == 1

定义生成器类型 的标志必须和特定的生成器属性相一致,下列相机的特性通过OpenNI接口被支持:

image generatior:

CV_CAP_PROP_OPENNI_OUTPUT_MODE

三种输出模式被支持: CV_CAP_OPENNI_VGA_30HZ 缺省(VGA resolution with 30 FPS),
CV_CAP_OPENNI_SXGA_15HZ ( SXGA resolution with 15 FPS)
and CV_CAP_OPENNI_SXGA_30HZ (SXGA resolution with 30 FPS, 被XtionPRO Live支持); 

深度传感器

CV_CAP_PROP_OPENNI_REGISTRATION – 表示深度图像投影到image map

适用的新特性

– CV_CAP_PROP_OPENNI_FRAME_MAX_DEPTH – Kinect支持的最大深度 mm.
– CV_CAP_PROP_OPENNI_BASELINE – 基线值 mm.
– CV_CAP_PROP_OPENNI_FOCAL_LENGTH –焦距.
– CV_CAP_PROP_FRAME_WIDTH – 帧宽.
– CV_CAP_PROP_FRAME_HEIGHT – 帧高.
– CV_CAP_PROP_FPS – 帧速.

组合generator type+property定义成一个单个标志

CV_CAP_OPENNI_IMAGE_GENERATOR_OUTPUT_MODE = CV_CAP_OPENNI_IMAGE_GENERATOR +
CV_CAP_PROP_OPENNI_OUTPUT_MODE


CV_CAP_OPENNI_DEPTH_GENERATOR_BASELINE = CV_CAP_OPENNI_DEPTH_GENERATOR +
CV_CAP_PROP_OPENNI_BASELINE

CV_CAP_OPENNI_DEPTH_GENERATOR_FOCAL_LENGTH = CV_CAP_OPENNI_DEPTH_GENERATOR +
CV_CAP_PROP_OPENNI_FOCAL_LENGTH

CV_CAP_OPENNI_DEPTH_GENERATOR_REGISTRATION = CV_CAP_OPENNI_DEPTH_GENERATOR +
CV_CAP_PROP_OPENNI_REGISTRATION


http://blog.csdn.net/dragonfly90/article/details/8025558

这篇关于使用OpenCV VideoCapture获取Kinect图像的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/813288

相关文章

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

C#使用SQLite进行大数据量高效处理的代码示例

《C#使用SQLite进行大数据量高效处理的代码示例》在软件开发中,高效处理大数据量是一个常见且具有挑战性的任务,SQLite因其零配置、嵌入式、跨平台的特性,成为许多开发者的首选数据库,本文将深入探... 目录前言准备工作数据实体核心技术批量插入:从乌龟到猎豹的蜕变分页查询:加载百万数据异步处理:拒绝界面

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

Python使用自带的base64库进行base64编码和解码

《Python使用自带的base64库进行base64编码和解码》在Python中,处理数据的编码和解码是数据传输和存储中非常普遍的需求,其中,Base64是一种常用的编码方案,本文我将详细介绍如何使... 目录引言使用python的base64库进行编码和解码编码函数解码函数Base64编码的应用场景注意

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3