AZURE kinect 深度相机配置ubuntu16.04

1.升级cmake

// Download and extract cmake 3.14.5
mkdir ~/temp
cd ~/temp
wget https://cmake.org/files/v3.14/cmake-3.14.5.tar.gz
tar -xzvf cmake-3.14.5.tar.gz
cd cmake-3.14.5/
//Install extracted source
./bootstrap
make -j4
sudo make install
cmake --versionsudo apt-get install jack-tools

2.安装ninja

sudo apt install ninja-build 

3.下载sdk

// 下载Azure Kinect release、1.1.1 版
gitclone -b v1.1.1 https://github.com/microsoft/Azure-Kinect-Sensor-SDK.git

下载relaese 1.1.1是因为目前官方还未提供libdepthengine.so.2.0库文件。
libdepthengine.so.1.0下载地址:
https://download.csdn.net/download/weixin_41628710/11484674
下载libdepthengine.so.1.0后, 放置/usr/lib/x86_64-linux-gnu/文件夹中
 

4.编译安装

mkdir build && cd build
cmake .. -GNinja
ninja
sudo ninja install

 5.编译完成开启k4aviewer无法获取深度视频流,可尝试以下解决方案

sudo add-apt-repository ppa:ubuntu-toolchain-r/test
sudo apt-get update
sudo apt-get install gcc-4.9
sudo apt-get upgrade libstdc++6

下载relaese 1.1.1是因为目前官方还未提供libdepthengine.so.2.0库文件。
libdepthengine.so.1.0下载地址:
https://download.csdn.net/download/weixin_41628710/11484674
下载libdepthengine.so.1.0后, 放置/usr/lib/x86_64-linux-gnu/文件夹中

2下载libdepthengine.so.文件

下载地址为:

https://packages.microsoft.com/ubuntu/18.04/prod/pool/main/libk/

想要去掉管理员权限也能启动:
进入Azure Kinect sdk 源码根目录中 scripts 文件夹,复制99-k4a.rules文件至/etc/udev/rules.d/

sudo ./script/bootstrap-ubuntu.sh. 确保这些依赖都成功安装.

另一种方法是,直接在https://github.com/lemenkov/libyuv.gitgit clone下来,并将clone下来的libyuv文件夹改名为src,放到extern/libyuv/里。

然后在。gitmodules删除libyuv的下载

6.测试

在build文件下

sudo ./bin/k4aviewer

 

7.c++ 代码获取

#include <stdio.h>
#include <stdlib.h>
#include <k4a/k4a.h>
#include <opencv2/opencv.hpp>int main(int argc, char **argv)
{int returnCode = 1;k4a_device_t device = NULL;const int32_t TIMEOUT_IN_MS = 1000;int captureFrameCount;k4a_capture_t capture = NULL;std::cout<<"d1"<<std::endl;uint32_t device_count = k4a_device_get_installed_count();if (device_count == 0){printf("No K4A devices found\n");return 0;}if (K4A_RESULT_SUCCEEDED != k4a_device_open(K4A_DEVICE_DEFAULT, &device)){printf("Failed to open device\n");return 0;}std::cout<<"d2"<<std::endl;k4a_device_configuration_t config = K4A_DEVICE_CONFIG_INIT_DISABLE_ALL;config.color_format = K4A_IMAGE_FORMAT_COLOR_MJPG;config.color_resolution = K4A_COLOR_RESOLUTION_2160P;config.depth_mode = K4A_DEPTH_MODE_NFOV_UNBINNED;config.camera_fps = K4A_FRAMES_PER_SECOND_30;if (K4A_RESULT_SUCCEEDED != k4a_device_start_cameras(device, &config)){printf("Failed to start device\n");return 0;}cv::Mat cv_rgbImage_with_alpha;cv::Mat cv_rgbImage_no_alpha,cv_irImage_8U,cv_depth_8U;std::cout<<"d3"<<std::endl;while (1){k4a_image_t depthImage = NULL, colorImage = NULL, irImage = NULL;switch (k4a_device_get_capture(device, &capture, TIMEOUT_IN_MS)){case K4A_WAIT_RESULT_SUCCEEDED:break;case K4A_WAIT_RESULT_TIMEOUT:printf("Timed out waiting for a capture");continue;break;case K4A_WAIT_RESULT_FAILED:printf("Failed to read a capture");goto Exit;}// std::cout<<"d3"<<std::endl;cv::Mat color;colorImage = k4a_capture_get_color_image(capture);// if(colorImage)// {//      std::cout<<"d5"<<std::endl;// 	int width = k4a_image_get_width_pixels(colorImage);// 	int height = k4a_image_get_height_pixels(colorImage);// 	color = cv::Mat(cv::Size(width, height), CV_8UC4);// 	memcpy(color.data, (void*)k4a_image_get_buffer(colorImage), width * height * 4);//     std::cout<<"dd"<<std::endl;// }cv::Mat depth;depthImage = k4a_capture_get_depth_image(capture);if (depthImage){int width = k4a_image_get_width_pixels(depthImage);int height = k4a_image_get_height_pixels(depthImage);depth = cv::Mat(cv::Size(width, height), CV_16UC1);memcpy(depth.data, (void*)k4a_image_get_buffer(depthImage), width * height * sizeof(int16_t));depth.convertTo(cv_depth_8U, CV_8U, 100 );cv::imshow("depth",cv_depth_8U);}cv::Mat IR_left, IR_right;irImage = k4a_capture_get_ir_image(capture);if (irImage != NULL){//std::cout<<"d5"<<std::endl;int width = k4a_image_get_width_pixels(irImage);int height = k4a_image_get_height_pixels(irImage);cv::Mat IR_left = cv::Mat(cv::Size(width, height), CV_16UC1);memcpy(IR_left.data, (void*)k4a_image_get_buffer(irImage), width * height * sizeof(int16_t));//cv::Mat  cv_irImage = cv::Mat(height, width, CV_16U, (void*)k4a_image_get_buffer(irImage), width * height * sizeof(int16_t));IR_left.convertTo(cv_irImage_8U, CV_8U, 1 );cv::imshow("iii",cv_irImage_8U);if(cv::waitKey(10)==27)break;}if (colorImage)k4a_image_release(colorImage);if (depthImage)k4a_image_release(depthImage);if(irImage)k4a_image_release(irImage);if(capture)k4a_capture_release(capture);cv::waitKey(2);}returnCode = 0;
Exit: if (device != NULL){k4a_device_close(device);}return returnCode;
}

cmakelists.txt


cmake_minimum_required(VERSION 2.8)
set(k4a_DIR /usr/local/lib/cmake) project(WDKinectDKDemo)find_package(k4a REQUIRED)find_package(OpenCV REQUIRED)include_directories( ${CMAKE_CURRENT_LIST_DIR} )
include_directories( ${OpenCV_INCLUDE_DIRS} )add_executable(azureCapture main_demo_Linux.cpp 
)target_link_libraries(azureCapture PRIVATE k4a::k4a ${OpenCV_LIBS})set(CMAKE_CXX_FLAGS "-std=c++11")
set(CMAKE_CXX_STANDARD_REQUIRED TRUE)

 

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

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

相关文章

递归算法的时间复杂度分析

在算法分析中&#xff0c;当一个算法中包含递归调用时&#xff0c;其时间复杂度的分析会转化为一个递归方程求解。实际上&#xff0c;这个问题是数学上求解渐近阶的问题&#xff0c;而递归方程的形式多种多样&#xff0c;其求解方法也是不一而足&#xff0c;比较常用的有以下四…

喜欢爱C/C++的人不要浮躁

1.把C当成一门新的语言学习&#xff08;和C没啥关系&#xff01;真的。2.看《Thinking In C》&#xff0c;不要看《C变成死相》&#xff1b;3.看《The C Programming Language》和《Inside The C Object Model》,不要因为他们很难而我们自己是初学者所以就不看&#xff1b;4.不…

Cloudera Manager agent无法启动,拒绝链接 Failed! trying again in 2 second(s): [Errno 111] Connection refuse

启动agent节点失败&#xff0c;提示拒绝连接&#xff0c;百度一下很多人说解决方式是用ps -ef | grep supervisord查看是否有进程&#xff0c;有的话 kill 掉&#xff08;使用kill -9 会自动拉起进程&#xff0c;使用kill&#xff09;&#xff0c;然后重启即可&#xff0c;kill…

POSIX标准

POSIX的诞生和Unix的发展是密不可分的&#xff0c;电气和电子工程师协会&#xff08;Institute of Electrical and Electronics Engineers&#xff0c;IEEE&#xff09;最初开发 POSIX 标准&#xff0c;是为了提高 UNIX 环境下应用程序的可移植性。Unix于70年代诞生于贝尔实验室…

论文翻译网站

https://tongtianta.site/

C/C++字符串输入方法比较(带回车不带回车输入)

1.scanf charstr[15]; scanf("%s",str); abc 123 1) 不读入空格和回车,从空格处结束 2) 输入字符串长度超过字符数组元素个数不报错 3) 当输入项为字符指针时&#xff0c;指针必须已指向确定的有足够空间的连续存储单元 4) 当为数组元素地址时…

Kafka(六)Kafka基本客户端命令操作

转载自&#xff1a;https://blog.51cto.com/littledevil/2147950 主题管理 创建主题 如果配置了auto.create.topics.enabletrue&#xff08;这也是默认值&#xff09;这样当生产者向一个没有创建的主题发送消息就会自动创建&#xff0c;其分区数量和副本数量也是有默认配置来…

linux平台C++开发基本知识

最近工作中&#xff0c;需要在linux上开发C程序。有了下面的问题。 1&#xff0c;linux平台C开发和win32 C开发有什么区别呢&#xff1f; 2&#xff0c;除了C语言&#xff0c;数据结构等必须的知识外&#xff0c;还需要些了解什么呢&#xff1f; 3&#xff0c;如何在linux平台开…

Impala 调用Hbase 报错 LeaseException

impala调用Hbase表数据操作时&#xff0c;提示 LeaseException 异常&#xff0c;主要原因是hbase数据过大&#xff0c;调用期间没有汇报心跳导致 WARNINGS: LeaseException: org.apache.hadoop.hbase.regionserver.LeaseException: lease -8355984789923245890 does not exist…

js和jsp所有页面跳转总结

Jsp页面跳转和js控制页面跳转的几种方法 Jsp 页面跳转的几种方法 1. RequestDispatcher.forward() 在服务器端起作用,当使用forward()时,Servlet engine传递HTTP请求从当前的Servlet或者是JSP到另外的一个Servlet、JSP 或普通HTML文件,也即你的form提交至a.jsp,在a.jsp用到了fo…

mitmproxy 中间人代理工具,抓包工具,linux抓包工具 mitmproxy 使用

mitmproxy是一个支持HTTP和HTTPS的抓包程序&#xff0c;类似Fiddler、Charles的功能&#xff0c;可以在linux以命令行形式的展示抓包信息 mitmdump&#xff1a;它是mitmproxy的命令行接口&#xff0c;利用它我们可以对接Python脚本&#xff0c;用Python实现监听后的处理。 mitm…

欧拉角转旋转矩阵

//c实现 cv::Mat eulerAnglesToRotationMatrix(cv::Vec3f& theta){// Calculate rotation about x axiscv::Mat R_x (cv::Mat_<double>(3, 3) <<1, 0, 0,0, cos(theta[0]), -sin(theta[0]),0, sin(theta[0]), cos(theta[0]));// Calculate rotation about y a…

C++常见面试题

1.在C 程序中调用被C 编译器编译后的函数&#xff0c;为什么要加extern “C”&#xff1f; 答&#xff1a;首先&#xff0c;extern是C/C语言中表明函数和全局变量作用范围的关键字&#xff0c;该关键字告诉编译器&#xff0c;其声明的函数和变量可以在本模块或其它模块中使用。…

Ajax学习总结+案例

一、AJAX简介 1、Asynchronous JavaScript And XML指异步 JavaScript 及 XML 2、老技术新用法。是基于JavaScript、XML、HTML、CSS新用法 二、同步和异步&#xff08;理解&#xff09; 三、第一个异步请求案例&#xff08;熟悉编码步骤&#xff09; 四、XmlHttpRequest&…

spark 2.2 读取 Hadoop3.0 数据异常 org.apache.hadoop.hdfs.web.HftpFileSystem cannot access its superinterfa

spark 2.2 读取 Hadoop3.0 数据异常 Exception in thread "main" java.lang.IllegalAccessError: class org.apache.hadoop.hdfs.web.HftpFileSystem cannot access its superinterface org.apache.hadoop.hdfs.web.TokenAspect$TokenManagementDelegatorat java.la…

安装open3d python

安装&#xff1a; pip install open3d 测试是否安装成功 python -c "import open3d as o3d"

ajax测试代码

//jsp文件 <% page language"java" contentType"text/html; charsetutf-8"pageEncoding"utf-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> …

Spark 运行内存不足Not enough space to cache rdd in memory,Container killed by YARN for exceeding memory

日志报错&#xff08;WARN类型最后执行成功可以忽略&#xff09;&#xff1a; 19/04/15 12:35:37 INFO memory.MemoryStore: Will not store rdd_2_5119/04/15 12:35:37 WARN memory.MemoryStore: Not enough space to cache rdd_2_51 in memory! (computed 1109.7 MB so far)…

opencv 读取CV_16U图像 c++

cv::Mat depthImage cv::imread("../data1/depth0.png",-1);

Spark 某两个节点数据分析速度慢 - hbase数据删除(分裂) 元信息未删除导致 There is an overlap in the region chain.

基于Hbase2.0&#xff0c;Spark2.2 问题描述 执行Spark处理Hbase数据时&#xff0c;遇到某两个Excutor处理速度特别慢&#xff0c;如图 正常速度10多分钟 左右处理完成&#xff0c; 一个多小时有另外一个处理完成&#xff0c;还有一个在处理中。 分析原因 1.查看hbase数据分…