官术网_书友最值得收藏!

Introduction

In this chapter, we will introduce primary datatypes of the OpenNI and the NiTE along with some basic information about how to access and select a data stream. Then we will try to show you some examples of events triggered by devices such as connecting or disconnecting an OpenNI supported device from computer.

But first, let's get some background about the whole OpenNI's principle first.

The OpenNI object

OpenNI object is the starting point of everything in the framework. Using the OpenNI class we can access a list of connected devices as well as the version of OpenNI itself. Then using this information we can access a device object and read data.

This class uses the singleton pattern, which means there is only one instance of this class and all of its methods are static.

Also in OpenNI 2 we have the ability to register two callback functions by OpenNI object for capturing device connected and device disconnected events.

The device object

Device object is representing the actual physical device where each device supports a number of sensors (for example, depth, color, and IR) that can be accessed using Device object. We need to ask for access to a device before using its sensor's output. Also using this object, we can access some device-wide settings. Read more in Chapter 4, More about Low-level Outputs.

The VideoStream object

Using the VideoStream object we can access the output data of color, IR, and depth sensors. VideoStream in the new version of OpenNI supports event-based reading that gives us the ability to register a callback function to execute when a new frame of data becomes available.

Sharing devices between applications

Unlike OpenNI 1.x, where we could share a device between two or more applications at the same time, we can't share a sensor's output at all with OpenNI 2.x. In the new design, the first application always locks the device; not only is there no way for the second app to change settings of sensors, there is no way to even use the output of locked sensors in any way as well.

VideoStream paused state

Most of the time, a sensor will not start producing data output when initialized until the programmer asks it to start generating data using the openni:VideoStream::start() function. Also it is possible to stop a stream from generating data using the openni:VideoStream::stop() function.

主站蜘蛛池模板: 两当县| 华容县| 荔浦县| 诸城市| 陵川县| 兴安县| 陆川县| 甘德县| 桐乡市| 垫江县| 屏东市| 苏尼特左旗| 扶沟县| 茂名市| 高陵县| 金秀| 塔河县| 金寨县| 东兴市| 平阴县| 文水县| 远安县| 鄂托克前旗| 全椒县| 肥东县| 东丰县| 左云县| 鄂温| 庆城县| 大竹县| 修武县| 林甸县| 博湖县| 鄯善县| 金川县| 遂川县| 台南县| 武城县| 泊头市| 阿勒泰市| 宿松县|