kinect2.0开发(一) 读取深度图像

原创 2015年11月19日 17:33:09

代码运行环境

本代码为运行在windows8 64位系统上,采用vs2013集成开发环境,编译为win32程序
利用opencv库显示图像

运行前准备

1.安装Microsoft kinect2.0 SDK
2.配置opencv环境变量
参考以下步骤
http://tanghenxin.blog.163.com/blog/static/213511105201421244826743/
3.将kinect.h的库文件Kinect20.lib包含进去
包含目录: C:\Program Files\Microsoft SDKs\Kinect\v2.0_1409\inc
库目录:C:\Program Files\Microsoft SDKs\Kinect\v2.0_1409\Lib\x86

读取深度图像步骤

  1. 获取kinect传感器
  2. 打开传感器
  3. 获取深度信息传感器
  4. 打开深度帧读取器
  5. 获得最近的一帧
  6. 将深度信息转换为MAT格式
  7. 用opencv的imshow显示
  8. 回收和释放内存

代码如下:

// kinectSensorTest.cpp : 定义控制台应用程序的入口点。
//

#include <stdio.h>
#include <Kinect.h>
#include <windows.h>
#include <highgui.h>
#include <cv.h>

using namespace cv;

// 转换depth图像到cv::Mat
Mat ConvertMat(const UINT16* pBuffer, int nWidth, int nHeight)
{
    Mat img(nHeight, nWidth, CV_8UC1);
    uchar* p_mat = img.data;//指向头指针

    const UINT16* pBufferEnd = pBuffer + (nWidth * nHeight);//指向最后一个元素的指针

    while (pBuffer < pBufferEnd)//16位最大值为65536
    {
        *p_mat++ = *pBuffer++ /65536.0 * 256;
    }
    return img;
}
int main()
{
    IKinectSensor*          m_pKinectSensor;
    IDepthFrameReader*      m_pDepthFrameReader;
    IDepthFrame* pDepthFrame = NULL;
    IFrameDescription* pFrameDescription = NULL;
    IDepthFrameSource* pDepthFrameSource = NULL;

    HRESULT hr = GetDefaultKinectSensor(&m_pKinectSensor);//获取默认kinect传感器
    assert(hr >= 0);
    printf("打开kinect传感器成功\n");

    hr = m_pKinectSensor->Open();//打开传感器
    assert(hr >= 0);
    hr = m_pKinectSensor->get_DepthFrameSource(&pDepthFrameSource);//获得深度信息传感器
    assert(hr >= 0);
    hr = pDepthFrameSource->OpenReader(&m_pDepthFrameReader);//打开深度信息帧读取器
    assert(hr >= 0);

    while (hr < 0 || pDepthFrame == NULL)
        hr = m_pDepthFrameReader->AcquireLatestFrame(&pDepthFrame);//由于有时候获取不到,因此循环获取最近的帧

    assert(hr >= 0);
    hr = pDepthFrame->get_FrameDescription(&pFrameDescription);//获取帧的像素信息(宽和高)
    int depth_width, depth_height;
    pFrameDescription->get_Width(&depth_width);
    pFrameDescription->get_Height(&depth_height);
    printf("width=%d height=%d\n", depth_width, depth_height);

    USHORT nDepthMinReliableDistance = 0;//获取最大、最小深度距离信息
    USHORT nDepthMaxReliableDistance = 0;
    assert(hr >= 0);
    hr = pDepthFrame->get_DepthMinReliableDistance(&nDepthMinReliableDistance);
    assert(hr >= 0);
    hr = pDepthFrame->get_DepthMaxReliableDistance(&nDepthMaxReliableDistance);

    printf("nDepthMinReliableDistance=%d nDepthMaxReliableDistance=%d\n", nDepthMinReliableDistance, nDepthMaxReliableDistance);

    UINT nBufferSize_depth = 0;
    UINT16 *pBuffer_depth = NULL;
    pDepthFrame->AccessUnderlyingBuffer(&nBufferSize_depth, &pBuffer_depth);//获取图像像素个数和指向图像的指针


    //转换为MAT格式
    Mat depthImg_show = ConvertMat(pBuffer_depth, depth_width, depth_height);//转换为8位的mat


    equalizeHist(depthImg_show, depthImg_show);//均衡化,为了提高显示效果

    imwrite("MyFirstKinectImg.jpg", depthImg_show);//保存图片
    //用opencv显示

    namedWindow("display");

    imshow("display", depthImg_show);

    if (27 == waitKey(0))
    return 0;
}

实验结果如图:
这里写图片描述

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

关于Kinect深度图和彩色图像提取

初学使用OpenNi开发Kinect,首先拿过来还是玩一下怎么提取图像数据。Kinect上有一个红外发射器,当驱动Kinect时发射红外扫描视场范围,红外接收器接收到物体反射回来的红外光,经过内部芯片...
  • Lixam
  • Lixam
  • 2012年05月24日 22:38
  • 8160

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Kinect 2 SDK + OpenCV 获取深度彩色图像

感谢有钱到老板

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Kinect v2.0如何获取彩色图像和深度图像

首先,下载最新的Kinect 2 SDK  http://www.microsoft.com/en-us/kinectforwindows/develop/downloads-docs.aspx下载之...

kinect2.0+opencv获取图像和深度图像

参考这篇博客的程序,http://blog.csdn.net/yongshengsilingsa/article/details/37935975 //师兄写的获取深度信息的程序,并且将深度信息存储为...
  • lgdnr
  • lgdnr
  • 2015年12月26日 17:11
  • 2239

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

获取kinect的颜色图像和深度图像(网上资料的整合)

在使用OpenNI来驱动读取kinect数据时,我们需要了解context object这个名词。查看了下OpenNI UserGuide文档,简单翻译下这个名词的意思:   Context是open...

Kinect开发教程二:OpenNI读取深度图像与彩色图像并显示

细心的朋友肯定已经发现Kinect上长了三只眼睛,其中一个是彩色摄像头,另外两个深度摄像头,一个负责发射红外光,一个负责接收,这样,我们便能通过Kinect得到一幅彩色图像和一幅深度图像。如果大家对K...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:kinect2.0开发(一) 读取深度图像
举报原因:
原因补充:

(最多只允许输入30个字)