Azure Kinect sdk 入门,简单使用深度相机

 首先要安装·azure Kinect dk传感器和人体跟踪的软件

先安装传感器:Azure-Kinect-Sensor-SDK/usage.md at develop · microsoft/Azure-Kinect-Sensor-SDK · GitHub

在这个网址里下载,

点击红笔画出来的地方,下载安装,记住安装路径,建议默认安装。

点击后就会出现

这个窗口,然后点绿色的按钮,打开设备,前提是先将相机连接在电脑上,相机后面的小白灯一直亮着就代表可以了。

再点击start按钮就好了

这样就打开了。

配置一下在visual studio里的环境。

先创建一个项目,然后右键项目找到“管理NuGet程序包”这个选项,点进去

在浏览里面搜索Microsoft.Azure.Kinect.Sensor安装一下。

安装成功后在项目下面会有packages.config文件,就是安装成功了

然后添加头文件k4a.h,默认的路径为"C:\Program Files\Azure Kinect SDK v1.4.1\sdk\include\k4a\k4a.h"

然后添加头文件目录和库文件目录,这里记得先创建一个cpp文件

项目右键,找到属性,上面的平台改为x64

C++常规里,找到附加包含目录,加入sdk里include的路径

在链接器里找到附加库目录,加入sdk里的lib路径,默认路径为C:\Program Files\Azure Kinect SDK v1.4.1\sdk\windows-desktop\amd64\release\lib

链接器,输入,找到附加依赖项,添加k4a.lib就行了

添加完后记得点下面的应用,然后点击确定。

全部完成后运行一下下面的代码

#pragma comment(lib, "k4a.lib")
#include <k4a/k4a.h>#include <stdio.h>
#include <stdlib.h>int main()
{uint32_t count = k4a_device_get_installed_count();if (count == 0){printf("No k4a devices attached!\n");return 1;}// Open the first plugged in Kinect devicek4a_device_t device = NULL;if (K4A_FAILED(k4a_device_open(K4A_DEVICE_DEFAULT, &device))){printf("Failed to open k4a device!\n");return 1;}// Get the size of the serial numbersize_t serial_size = 0;k4a_device_get_serialnum(device, NULL, &serial_size);// Allocate memory for the serial, then acquire itchar *serial = (char*)(malloc(serial_size));k4a_device_get_serialnum(device, serial, &serial_size);printf("Opened device: %s\n", serial);free(serial);// Configure a stream of 4096x3072 BRGA color data at 15 frames per secondk4a_device_configuration_t config = K4A_DEVICE_CONFIG_INIT_DISABLE_ALL;config.camera_fps       = K4A_FRAMES_PER_SECOND_15;config.color_format     = K4A_IMAGE_FORMAT_COLOR_BGRA32;config.color_resolution = K4A_COLOR_RESOLUTION_3072P;// Start the camera with the given configurationif (K4A_FAILED(k4a_device_start_cameras(device, &config))){printf("Failed to start cameras!\n");k4a_device_close(device);return 1;}// Camera capture and application specific code would go here// Shut down the camera when finished with application logick4a_device_stop_cameras(device);k4a_device_close(device);return 0;
}

运行结果正常就是以上了

安装人体跟踪的软件

用这个网站Azure Kinect 人体跟踪 SDK 下载 | Microsoft Learn,下载最新版本,点击msi就直接下载了,也是建议默认安装

安装成功后找到安装位置,或者直接点击菜单键,

找到这个exe程序,点击运行

然后就是visual studio的环境配置了

首先和之前一样,先找到“管理NuGet程序包”,搜索Microsoft.Azure.Kinect,下载第二个,第一个已经下过了。

下完后是这样的

然后添加头文件,找到k4abt.h的文件路径,默认为"C:\Program Files\Azure Kinect Body Tracking SDK\sdk\include\k4abt.h"

然后配置库文件

C++常规里,找到附加包含目录,加入sdk里include的路径

链接器——常规——附加库目录,加入sdk的lib路径,默认为C:\Program Files\Azure Kinect Body Tracking SDK\sdk\windows-desktop\amd64\release\lib

链接器——输入——依赖附加项,添加k4abt.lib

记得点应用,之后就好了

#include <stdio.h>
#include <stdlib.h>#include <k4a/k4a.h>
#include <k4abt.h>#define VERIFY(result, error)                                                                            \if(result != K4A_RESULT_SUCCEEDED)                                                                   \{                                                                                                    \printf("%s \n - (File: %s, Function: %s, Line: %d)\n", error, __FILE__, __FUNCTION__, __LINE__); \exit(1);                                                                                         \}                                                                                                    \int main()
{k4a_device_t device = NULL;VERIFY(k4a_device_open(0, &device), "Open K4A Device failed!");// Start camera. Make sure depth camera is enabled.k4a_device_configuration_t deviceConfig = K4A_DEVICE_CONFIG_INIT_DISABLE_ALL;deviceConfig.depth_mode = K4A_DEPTH_MODE_NFOV_UNBINNED;deviceConfig.color_resolution = K4A_COLOR_RESOLUTION_OFF;VERIFY(k4a_device_start_cameras(device, &deviceConfig), "Start K4A cameras failed!");k4a_calibration_t sensor_calibration;VERIFY(k4a_device_get_calibration(device, deviceConfig.depth_mode, deviceConfig.color_resolution, &sensor_calibration),"Get depth camera calibration failed!");k4abt_tracker_t tracker = NULL;k4abt_tracker_configuration_t tracker_config = K4ABT_TRACKER_CONFIG_DEFAULT;VERIFY(k4abt_tracker_create(&sensor_calibration, tracker_config, &tracker), "Body tracker initialization failed!");int frame_count = 0;do{k4a_capture_t sensor_capture;k4a_wait_result_t get_capture_result = k4a_device_get_capture(device, &sensor_capture, K4A_WAIT_INFINITE);if (get_capture_result == K4A_WAIT_RESULT_SUCCEEDED){frame_count++;k4a_wait_result_t queue_capture_result = k4abt_tracker_enqueue_capture(tracker, sensor_capture, K4A_WAIT_INFINITE);k4a_capture_release(sensor_capture); // Remember to release the sensor capture once you finish using itif (queue_capture_result == K4A_WAIT_RESULT_TIMEOUT){// It should never hit timeout when K4A_WAIT_INFINITE is set.printf("Error! Add capture to tracker process queue timeout!\n");break;}else if (queue_capture_result == K4A_WAIT_RESULT_FAILED){printf("Error! Add capture to tracker process queue failed!\n");break;}k4abt_frame_t body_frame = NULL;k4a_wait_result_t pop_frame_result = k4abt_tracker_pop_result(tracker, &body_frame, K4A_WAIT_INFINITE);if (pop_frame_result == K4A_WAIT_RESULT_SUCCEEDED){// Successfully popped the body tracking result. Start your processingsize_t num_bodies = k4abt_frame_get_num_bodies(body_frame);printf("%zu bodies are detected!\n", num_bodies);k4abt_frame_release(body_frame); // Remember to release the body frame once you finish using it}else if (pop_frame_result == K4A_WAIT_RESULT_TIMEOUT){//  It should never hit timeout when K4A_WAIT_INFINITE is set.printf("Error! Pop body frame result timeout!\n");break;}else{printf("Pop body frame result failed!\n");break;}}else if (get_capture_result == K4A_WAIT_RESULT_TIMEOUT){// It should never hit time out when K4A_WAIT_INFINITE is set.printf("Error! Get depth frame time out!\n");break;}else{printf("Get depth capture returned error: %d\n", get_capture_result);break;}} while (frame_count < 100);printf("Finished body tracking processing!\n");k4abt_tracker_shutdown(tracker);k4abt_tracker_destroy(tracker);k4a_device_stop_cameras(device);k4a_device_close(device);return 0;

运行结果就是这样的

 以上就是auzre kinect sdk的简单入门了

参考文章:

Azure Kinect DK 文档 | Microsoft Learn

(5条消息) Kinect Azure DK入门学习(二)——生成第一个应用程序_azure kinect dk开发教程_流水L的博客-CSDN博客

(5条消息) Kinect Azure DK入门学习(三)——设置人体跟踪SDK + 生成第一个人体跟踪应用程序_流水L的博客-CSDN博客

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

入门级数码相机

为了满足不同层次顾客的购买要求&#xff0c;小编今天给大家交上一篇家用DC完全导购。从200万像素到800万像中间&#xff0c;分别选取了几款各级别中值得推荐的DC为大家推荐。在这里先给朋友们提一下目前数码相机市场相素与价位之间的简单联系。 目前&#xff0c;200万像素的数…

【计算机视觉-从入门到精通系列】 第二章 相机模型

2.1 针孔模型 计算机视觉是一门研究如何让计算机“看”世界的学科。人要看到世界需要眼睛&#xff0c;计算机要看到世界同样也需要“眼睛”&#xff0c;计算机的“眼睛”主要就是相机。实际应用中&#xff0c;相机的种类纷繁复杂&#xff0c;包括手机和平板电脑的相机&#xff…

5分钟入门Cinemachine智能相机系统

摘要&#xff1a;相机是Unity世界的眼睛&#xff0c;一个智能相机更是能帮咱们节省大把的时间和精力。Cinemachine现在已经大量应用到各种项目中&#xff0c;如果你还没有用过Cinemachine&#xff0c;墙裂建议你来体验一下。 你好&#xff0c;我是跟着大智学Unity的萌新&#x…

立体视觉入门指南(1):坐标系与相机参数

亲爱的同学们&#xff0c;我们的世界是3D世界&#xff0c;我们的双眼能够观测三维信息&#xff0c;帮助我们感知距离&#xff0c;导航避障&#xff0c;从而翱翔于天地之间。而当今世界是智能化的世界&#xff0c;我们的科学家们探索各种机器智能技术&#xff0c;让机器能够拥有…

camera学习入门指南

等待补充。 1.背景介绍 近年来&#xff0c;随着消费电子领域市场的快速增长&#xff0c;如安防、图像等领域&#xff0c;camera市场得到了快速发展。智能手机这几年以拍照作为主打卖点&#xff0c;带动了camera&#xff08;CCM&#xff09;出货。 具体可以看电子行业分析或者券…

机器视觉——入门基础(三)——相机镜头选型

目录 相机选型 分辨率、快门、帧率、色彩、靶面、接口 镜头选型 分辨率、靶面、焦距、接口、光圈畸变工作距离 常用计算示例 相机选型 分辨率、快门、帧率、色彩、靶面、接口 镜头选型 分辨率、靶面、焦距、接口、光圈畸变工作距离 常用计算示例 1. 面阵相机和镜头选型 已…

划重点!| 必须了解的工业相机入门级知识

工业相机是机器视觉系统的核心部件&#xff0c;其相关基础知识是行业内人员必须熟知的。那么分辨率、像素深度、行频、信噪比具体是指什么&#xff1f;CCD和CMOS又该如何去进行选择&#xff1f;今天我们就对这些内容进行一个简单的梳理&#xff0c;希望能够帮助大家了解更多。 …

机器视觉——入门基础(一)—— 相机篇

目录 一&#xff0c;相机就是CCD么&#xff1f; 二&#xff0c;像素。 三&#xff0c;像素直径。 四&#xff0c;CCD的大小。 五&#xff0c;快门速度。 六&#xff0c;增益。 七&#xff0c;1D相机&#xff08;线扫描相机&#xff09; 八&#xff0c;3D相机。 九&…

IP 协议的相关特性和数据链路层相关知识总结

目录 IP 协议的相关特性 一、IP协议的特性 二、 IP协议数据报格式 三、 IP协议的主要功能 1. 地址管理 动态分配 IP地址 NAT机制 NAT背景下的通信 IPV6 2. 路由控制​​​​​​​ 3.IP报文的分片与重组 数据链路层相关知识 1、以太网协议&#xff08;Ethernet&#xff09; 2.M…

掌握Python的X篇_28_python包管理工具pip命令

本篇将会介绍在实际使用python中最能节省效率的内容&#xff0c;利用第三方库拿来就用。 文章目录 1. pip命令是什么2. pip相关操作2.1 list2.2 install2.3 uninstall2.4 导出和导入2.4.1 freeze命令2.4.2 “-r” 3. 国内镜像4. Python Packges Index网站 1. pip命令是什么 p…

DiskGenius分区移动硬盘

打开DiskGenius 右键点击1T&#xff08;实际显示是900多G&#xff09;的移动硬盘&#xff0c;选择快速分区 分区个数按自己需要来选&#xff0c;卷标也按自己需要来修改&#xff0c;取消主分区的勾选框&#xff0c;因为是移动硬盘&#xff0c;不需要转操作系统&#xff0c;所以…

AUtoCAD Civil 3D-曲面-原始数据处理

Civil3D中&#xff0c;曲面是最重要的一个对象之一。曲面涉及到的知识点比较多&#xff0c;作为一个刚接触Civil3D的学习者&#xff0c;可能对于各种概念和各种概念之间的关系比较迷惑。这篇文章及梳理下曲面的一些重要的概念框架。 1、 曲面的分类 曲面可以分为四种类型&…

如何将卫星影像或者航拍影像叠加到CAD设计图上(Auto CAD版)

同步视频教程&#xff1a;卫星图像应用到AutoCAD工程设计&#xff08;套合、叠加、配准&#xff09;-Bigemap GIS Office 视频教程&#xff1a;如何选择中央子午线或者分度带 第一步 工具准备 BIGEMAP地图下载器&#xff1a;Bigemap系列产品-GIS行业基础软件kml\shp 相关教…

AutoCAD套合(叠加)卫星影像和矢量路网数据-CAD配准

BIGEMAP无偏移影像叠加配准&#xff08;Auto CAD版&#xff09; ​ 同步视频教程&#xff1a;http://www.iqiyi.com/w_19rubyfogh.html 专题地图制作视频教程&#xff1a;http://www.iqiyi.com/w_19rvlbep4l.html#vfrm16-1-1-1 下载&#xff1a;全国路网数据、全国水系矢量 …

cad图转成shp文件并把其平面坐标投影配准成大地坐标(配准针对没有底图的情况)

所需工具:arcmap,supermap(这里安装过程就不写了,网上一堆,自行搜搜吧。) 一、先将cad图转成shp文件 打开arcmap中,在图层中加入数据。 在arcmap中导入cad图后,选择需要的要素导出。比如,这里需要面要素,右击面要素,选择数据,点击导出数据。 选择将要导出shp文件…

history记录日期时间和日志记录操作

history命令能查看到操作日期和时间的配置方法&#xff1a; 1&#xff09;在/etc/profile文件中添加一行&#xff1a; export HISTTIMEFORMAT"%F %T whoami " 2&#xff09;保存后&#xff0c;执行加载命令&#xff1a; source /etc/profile 3&#xff09;然后检…

ASP.NET Core - 缓存之分布式缓存

分布式缓存是由多个应用服务器共享的缓存&#xff0c;通常作为访问它的应用服务器的外部服务进行维护。 分布式缓存可以提高 ASP.NET Core 应用的性能和可伸缩性&#xff0c;尤其是当应用由云服务或服务器场托管时。 与其他将缓存数据存储在单个应用服务器上的缓存方案相比&am…

【SWAT水文模型】SWATCUP率定参数实例-以洮河流域为例

SWATCUP率定参数实例 以SWATCUP首次模拟结果为例&#xff0c;具体模拟结果如下&#xff1a; 模拟参数结果如下&#xff1a; Parameter_Name Fitted_Value Min_value Max_value 1:R__CN2.mgt -0.180000 -0.200000 0.200000 2:V__SUR…

深入浅出流批一体理论篇——数据架构的演进

一、前大数据时代 人人都知道罗马不是一天建成的&#xff0c;但没人告诉过你罗马是怎样一天天建成的。你看见罗马时&#xff0c;它就已经是罗马了。当我进阿里时&#xff0c;正是这样的感觉。我没有经历过阿里数据架构&#xff08;包括平台工具&#xff09;从0到1的过程。我相…

linux镜像下载与安装

https://www.kernel.org/ 中国科技大学网站&#xff1a;http://centos.ustc.edu.cn/centos/ 清华大学网站&#xff1a;https://mirrors.tuna.tsinghua.edu.cn/centos/7/isos/ http://mirror.centos.org/centos/7/isos/ Centos7.6 安装 1、引导进入安装界面后&#xff0c;选择安…