Kinect for windows 开发入门 八:景深数据获取和使用 下

2024-06-12 18:32

本文主要是介绍Kinect for windows 开发入门 八:景深数据获取和使用 下,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景知识

1.  前面已经有提到,所谓直方图就是不同深度的像素分布图。

2.  Player id只有在打开SkeletonStream的时候才会产生。

SkeletonStream skeletonStream =kinectSensor.SkeletonStream;

       skeletonStream.Enable();

Playerid是动态分配的,同一个人走出视线再回来id会改变。Playerid也不是从0开始,从小到大排序的。

3.  如何计算人体的高度和宽度。如下图所示,根据Player id和深度数据,我们可以获取到人体的平均深度d。根据Kinect支持的水平角度(57度)和d,我们可以通过如下的两个直角三角形计算出人体所在切面的1/2实际宽度d *Pi * (57度/2)/180度 得到b。根据DepthStream的分辨率中的横向像素总数和人体所占像素,可以知道人体所占切面比例r。然后b*2* r就得到了人体的宽度。

比如,人体深度为2m,分辨率为1024 * 768,人体所占横向像素平均为300,那么人体的宽度为(2m * Pi * 28.5度 / 180 度)* 2 * (300 / 1024)=0.58米。对于高度的计算也是一样的。

 

示例代码

1.  直方图

       privatevoidCreateDepthHistogram(short[] pixelData, DepthImageFrame frame)

        {

            int[] depths = newint[4096];

 

            DepthHistogram.Children.Clear();

 

            int depth = 0;

            int max = 0;

            for (int i = 0; i <pixelData.Length; i++)

            {

                depth = pixelData[i] >> DepthImageFrame.PlayerIndexBitmaskWidth;

                if (depth > 0 && depth < 4096)

                {

                   depths[depth]++;

                    max = depths[depth] >max ? depths[depth] : max;

                }

            }

 

            for (int index = 0; index <depths.Length; index++)

            {

                if (depths[index] > 0)

               {

                    Rectangle rect = newRectangle();

                    rect.Fill = Brushes.DarkBlue;

                    rect.Width =DepthHistogram.ActualWidth / 4096;

                    rect.Height =DepthHistogram.ActualHeight * ((double)depths[index]/ max);

                    rect.Margin = newThickness(1, 0, 1, 0);

                    rect.VerticalAlignment =System.Windows.VerticalAlignment.Bottom;

                   DepthHistogram.Children.Add(rect);

                }

            }

        }

2.  抠像

       privatevoid CatchPlayer(short[] pixelData, DepthImageFrame frame)

        {

            int playId = 0;

            byte[] playerPixelData = newbyte[frame.Width * frame.Height *4];

            for (int i = 0; i <pixelData.Length; i++)

            {

                playId = pixelData[i] & DepthImageFrame.PlayerIndexBitmask;

                if (playId > 0)

                {

                    ShowThePlayerId.Text = string.Format("PlayerId:{0}", playId.ToString());

                    playerPixelData[i * 4] = (byte)0;

                    playerPixelData[i * 4 + 1]= (byte)0;

                    playerPixelData[i * 4 + 2]= (byte)255;

                }

                else

                {

                    playerPixelData[i * 4] = (byte)0;

                    playerPixelData[i * 4 + 1]= (byte)0;

                    playerPixelData[i * 4 + 2]= (byte)0;

                }

            }

 

            this.playerImageBitmap.WritePixels(this.playerImageBitmapRect, playerPixelData, frame.Width * 4, 0);

        }

3.  计算高度宽度

       privatevoidCaculateHightAndWidth(DepthImageFrame frame)

        {

            double avgDepth = 0.0;

            int sumDepth = 0;

            int pixelCount = 0;

            int minX = frame.Width;

            int maxX = 0;

            int minY = frame.Height;

            int maxY = 0;

 

            for (int i = 0; i < frame.Width;i++)

            {

                for (int j = 0; j < frame.Height;j++)

                {

                    if (playerData[i,j] <= 0)

                    {

                        continue;

                    }

 

                    pixelCount++;

                    minX = i < minX ? i :minX;

                    maxX = i > maxX ? i :maxX;

                    minY = j < minY ? j :minY;

                    maxY = j > maxY ? j :maxY;

 

                    sumDepth += playerData[i,j];

                }

            }

 

            if (pixelCount <= 0)

            {

                return;

            }

 

            int widthPixel = maxX - minX;

            int heightPixel = maxY - minY;

 

            avgDepth = sumDepth / pixelCount;

 

            double actualWidth = avgDepth * 28.5 * 3.14159 * 2 / 180;

            double actualHeight = avgDepth * 21.5 * 3.14159 * 2 /180;

            double width = actualWidth * widthPixel / frame.Width;

           double height = actualHeight * heightPixel /frame.Height;

 

            ShowThePlayerWidthAndHeight.Text = string.Format("Player width:{0} \nPlayerHeight:{1}",width, height);

        }

 

效果演示

1.  直方图,展示统一深度出现的次数。

如图所示,人,椅子,背景三个高峰

2.  抠像

playerid 不为0的像素显示为红色。

3.  深度宽度

很粗劣的用最大值减最小值计算出来的。偏差比较大。实际高度应该是1.6米。不过,我们的目的是展示如何计算。

这篇关于Kinect for windows 开发入门 八:景深数据获取和使用 下的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Windows 上如果忘记了 MySQL 密码 重置密码的两种方法

《Windows上如果忘记了MySQL密码重置密码的两种方法》:本文主要介绍Windows上如果忘记了MySQL密码重置密码的两种方法,本文通过两种方法结合实例代码给大家介绍的非常详细,感... 目录方法 1:以跳过权限验证模式启动 mysql 并重置密码方法 2:使用 my.ini 文件的临时配置在 Wi

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http