Kinect SDK v2预览版,获取数据的基本流程的说明。以及取得Color图像的示例程序的介绍。

上一节,是关于当前型号Kinect for Windows(后面称作Kinect v1)和次世代型的Kinect for Windows的开发者预览版(后面称作Kinect v2 预览版)的配置比较和介绍。
从这一节开始,是Kinect的各种数据的取得方法的比较和介绍。
 
Color Camera
Kinect和通常的Web摄像头一样,搭载了 Color Camera,可以取得Color图像。关于Camera,Kinect v1的分辨率是640×480,Kinect v2分辨率大幅提升到1920×1080。这次,要介绍从Color Camer取得图像的方法。
 
数据取得的流程
Kinect SDK v1和Kinect SDK v2预览版取得数据的基本流程。
这里表示的是最基础的流程,在Kinect SDK 在v2预览版里,有把多个「Source」「Reader」一齐处理的API,和这里介绍的数据获取的流程也会有差异。
图1是Kinect SDK v1和Kinect SDK v2预览版的数据取得流程
Kinect SDK v1,是从「Sensor」打开「Stream」,从「Stream」取得「Frame」,从「Frame」取得数据这样的流程。
到了Kinect SDK v2预览版,是从「Sensor」取得「Source」,从「Source」打开「Reader」,从「Reader」取得「Frame」,从「Frame」取得数据这样的流程。
 
  每个Kinect SDK v2预览版的「Source」,都有一个从Kinect取得Color和Depth的1个数据流,这点和Kinect SDK v1的「Stream」是一样的。
 
  Kinect SDK v2预览版,追加了「Reader」的阶段。「Reader」能打开1个「Source」多次。通过这个配置,多线程的应用上,不需要把取得的数据拷贝到其他线程处理。也有多个应用可以从同一个传感器取得数据的优点。
(注:因为Color Camera和Depth Camera是分离的,所以Color、Depth和Skeleton数据流也是各自独立的,API通过Event来通知App是否有数据更新。通常为了效率,对每一个数据流都使用单独的线程来等待Event,然后处理数据。在之前的v1中,Frame是独立的,取出后数据就被Drop掉了,所以想在Depth里读取Color之类的操作,必须使用内存拷贝,而多线程读写数据又会需要互斥锁,十分影响效率;还有一个办法是通过NuiSetFrameEndEvent,也就是c#接口中的AllFrameReady事件,但是这样等待所有数据不仅太局限而且效率很低。)
 
示例程序
  Kinect SDK v2预览版取得Color画像的示例程序的展示,图1展示的是数据取得阶段的摘录解说。这个示例程序的全部内容,在下面的github里公开了。
这个示例程序为了处理图像数据,使用了OpenCV。OpenCV的详细内容可以参考下面的信息。
「Sensor」
取得「Sensor」
  1. // Sensor
    IKinectSensor* pSensor; ……
    HRESULT hResult = S_OK;
    hResult = GetDefaultKinectSensor( &pSensor ); ……
    if( FAILED( hResult ) ){
    std::cerr << "Error : GetDefaultKinectSensor" << std::endl;
    return -;
    }
    hResult = pSensor->Open(); ……
    if( FAILED( hResult ) ){
    std::cerr << "Error : IKinectSensor::Open()" << std::endl;
    return -;
    }
    列表1.1 相当于图1「Sensor」的部分
    1 处理Kinect v2预览版的Sensor接口。
    2 取得默认的Sensor。
    3 打开Sensor。
 
「Source」
 从「Sensor」取得「Source」。
  1. // Source
    IColorFrameSource* pColorSource; ……
    hResult = pSensor->get_ColorFrameSource( &pColorSource ); ……
    if( FAILED( hResult ) ){
    std::cerr << "Error : IKinectSensor::get_ColorFrameSource()" << std::endl;
    return -;
    }
    列表1.2 相当于图1「Source」的部分
    1 获取Color Frame的Source接口。
    2 从Sensor取得Source。
「Reader」
「Source」从打开「Reader」。
  1. // Reader
    IColorFrameReader* pColorReader; ……
    hResult = pColorSource->OpenReader( &pColorReader ); ……
    if( FAILED( hResult ) ){
    std::cerr << "Error : IColorFrameSource::OpenReader()" << std::endl;
    return -;
    }
    列表1.3 相当于图1「Reader」的部分
    1 获取Color Frame的Reader接口。
    2 从Source打开Reader。
「Frame」~「Data」
从「Reader」取得最新的「Frame」。
  1. int width = ;   ……
    int height = ; ……
    unsigned int bufferSize = width * height * * sizeof( unsigned char ); ……
    cv::Mat bufferMat( height, width, CV_8UC4 ); ……
    cv::Mat colorMat( height / , width / , CV_8UC4 ); ……
    cv::namedWindow( "Color" );
    while( ){
    // Frame
    IColorFrame* pColorFrame=nullptr; ……
    hResult=pColorReader->AcquireLatestFrame( &pColorFrame ); ……
    if( SUCCEEDED( hResult ) ){
    hResult = pColorFrame->CopyConvertedFrameDataToArray( bufferSize, reinterpret_cast<BYTE*>( bufferMat.data ), ColorImageFormat_Bgra ); ……
    if( SUCCEEDED( hResult ) ){
    cv::resize( bufferMat, colorMat, cv::Size(), 0.5, 0.5 ); ……
    }
    }
    SafeRelease( pColorFrame );
    // Show Window
    cv::imshow( "Color", colorMat );
    if( cv::waitKey( ) == VK_ESCAPE ){
    break;
    }
    }
    列表1.4 相当于图1「Frame」,「Data」的部分
    1 Color图像的尺寸(1920×1080)。
       这里为了简化说明,画像尺寸用硬编码来设定,示例程序可以从Source取得着Frame信息。
    2 Color图像的数据尺寸。
    3 为了处理Color图像,准备OpenCV的cv::Mat。
     「bufferMat」是原始的图像数据,「colorMat」是Resize图像数据的处理。 
     「CV_8UC4」,是无符号8bit整数(8U),4个channel(C4)并列来表现1个像素的数据格式。
    4 取得Color图像的Frame接口。
    5 从Reader取得最新的Frame。
    6 从Frame取得Color图像。
       默认的格式是YUY2(亮度与色差表现的格式),不过可以经过简单处理变换为BGRA。
    7 缩小为长宽各一半的尺寸(960×540)。
  从「Frame」取得Color图像的数据时,Kinect SDK v1是预先指定图像尺寸和格式,Kinect SDK v2不能指定图像尺寸。因此,取得数据后可以按任意形状来整理。
  取出的Color图像直接显示的话尺寸太大(1920×1080),在这里采用了OpenCV的resize命令(cv::resize()),缩小为长宽各一半的尺寸(960×540)。(注:阅读理解时不要受这一段缩放代码的干扰,仅仅就是为了考虑在显示器上显示的方便观察,没别的意义。)
  取出的Color图像的数据如果指定的是BGRA格式,就会像图2一样的排列着。蓝(B),绿(G),红(R),和无效值(A)的共计32bit构成1像素。
图2 Color图像的数据排列
 
运行结果
运行这个示例程序的话,就会像图3那样,显示从Kinect v2预览版中取得的Color图像。
总结
本节介绍了从Kinect SDK v2预览版中取得数据的基本流程和取得Color图像的示例程序,下一节将介绍取得Depth数据的示例程序。
 

【翻译】Kinect v2程序设计(C++) Color篇的更多相关文章

  1. 【翻译】Kinect v2程序设计(C++) Body 篇

    Kinect SDK v2预览版的主要功能的使用介绍,基本上完成了.这次,是关于取得Body(人体姿势)方法的说明.   上一节,是使用Kinect SDK v2预览版从Kinect v2预览版取得B ...

  2. 【翻译】Kinect v2程序设计(C++-) AudioBeam篇

    Kinect v2,Microphone Array可以用来对于水平面音源方向的推测(AudioBeam)和语音识别(Speech Recognition).这一节是介绍如何取得AudioBeam. ...

  3. 【翻译】Kinect v2程序设计(C++) BodyIndex篇

    通过Kinect SDK v2预览版,取得BodyIndex(人体区域)的方法和示例代码. 上一节,介绍了从Kinect v2预览版用Kinect SDK v2预览版获取Depth数据的方法.   这 ...

  4. 【翻译】Kinect v2程序设计(C++) Depth编

    Kinect SDK v2预览版,取得Depth数据的方法说明. 上一节,介绍了通过使用Kinect for Windows SDK v2预览版(以下简称为,Kinect SDK v2预览版)从Kin ...

  5. 【翻译】Kinect v1和Kinect v2的彻底比较

      本连载主要是比较Kinect for Windows的现行版(v1)和次世代型的开发者预览版(v2),以C++开发者为背景介绍进化的硬件和软件.本文主要是对传感的配置和运行条件进行彻底的比较.   ...

  6. 【计算机视觉】深度相机(五)--Kinect v2.0

    原文:http://blog.csdn.NET/qq1175421841/article/details/50412994 ----微软Build2012大会:Kinect for Windows P ...

  7. Ubuntu_ROS中应用kinect v2笔记

    Ubuntu_ROS中应用kinect v2笔记 个人觉得最重要的资料如下: 1. Microsoft Kinect v2 Driver Released http://www.ros.org/new ...

  8. 【计算机视觉】深度相机(六)--Kinect v2.0 手势样本库制作

    目录为1.如何使用Kinect Studio录制手势剪辑:2.如何使用Visual Gesture Builder创建手势项目:3.如何在我的C#程序中使用手势:4.关于录制.剪辑手势过程中的注意事项 ...

  9. Kinect v2.0 for windows开发环境说明

    官方文档里是这些: Supported Operating Systems and Architectures The following operating systems and architec ...

随机推荐

  1. BaseActivity与BaseFragment的封装

    这篇博客主要是从BaseActivity与BaseFragment的封装开始,总结我们在实战开发中关于Fragment的注意事项以及心得体会. 先看以下效果图: 这里模拟的是用户登录模块,你可能会说, ...

  2. 烟大 Contest1024 - 《挑战编程》第一章:入门 Problem A: The 3n + 1 problem(水题)

    Problem A: The 3n + 1 problem Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 14  Solved: 6[Submit][St ...

  3. hdu 1010:Tempter of the Bone(DFS + 奇偶剪枝)

    Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Othe ...

  4. Struts2文件上传和下载(原理)

    转自:http://zhou568xiao.iteye.com/blog/220732 1.    文件上传的原理:表单元素的enctype属性指定的是表单数据的编码方式,该属性有3个值:1)     ...

  5. AppInventor学习笔记(三)——油漆桶应用学习

    一.组件设置 1.画笔颜色选项 选取3个Button,然后改名为红.黄.绿三种颜色,然后进行相应属性的设置. 在这里有个问题就是如何放在一行.. 将3个按钮放进这个方框里面就可以变成一行了. 2.画布 ...

  6. 关于phpstudy安装的问题

    1.最常见的就是80端口冲突.如果是安装在服务器的话,有些服务器已经默认安装了iis,所以会有冲突.关闭iis即可. 2.明明装了vc9运行库,但错误还是不行.如果你是整个项目copy过来的,可能就会 ...

  7. 只用CSS美化选择框

    只用CSS美化选择框 2012-03-02 11:04 by iBlog, 26240 阅读, 14 评论, 收藏, 编辑 <本文译自Style a Select Box Using Only ...

  8. 2016.6.17 计算机网络复习要点之PPP协议

    点对点协议PPP是目前使用最广泛的数据链路层协议. 1.PPP协议的特点: **我们知道因特网用户通常需要连接到某个ISP才能接入到因特网,PPP协议就是用计算机和ISP进行通信时所使用的数据链路层协 ...

  9. BZOJ1085 [SCOI2005]骑士精神(IDA*)

    IDA*是IDS的基础上加上满足A*算法的估值函数来剪枝的搜索算法. 这题代码量挺少的,可以看出整个IDA*的框架: #include<cstdio> #include<cstrin ...

  10. [Unity2D]脚本的使用规则

    Unity2D的游戏脚本可以使用3中开发语言来编写:C#,JavaScript和BOO.你可以选择你熟悉的编程语言来编写,通常C#语言的编程功能会更加强大一些,成为首选的语言.在Unity2D中使用C ...