Skip to content
This repository has been archived by the owner on Feb 4, 2020. It is now read-only.

Latest commit

 

History

History
44 lines (27 loc) · 3.92 KB

README.md

File metadata and controls

44 lines (27 loc) · 3.92 KB

Kinect Wrapper

A C++ YARP library that wraps around Kinect SDK or OpenNI device drivers. The code contained here derives from the code developed in the EFAA EU project.

Installation

Dependencies
Cmaking the project

At cmake time, user can select which library to use by means of USE_KinectSDK, which can be ON (Kinect SDK) or OFF (OpenNI).

If you intend to rely on Kinect SDK, then it is required to setup the environment variable KINECTSDK_DIR pointing to the installed SDK, e.g. "C:\Program Files\Microsoft SDKs\Kinect\vx.y" (don't forget the double quotes).

To any rate, user can choose to build the client part only via BUILD_CLIENT_ONLY cmake variable (FALSE by default).

The project is composed of a library that the user can link against to get access to the client side of the kinectWrapper and a binary implementing the server side. For further details refer to the architecture hereinafter.

Architecture

The main purpose of this YARP wrapper is to abstract from the hardware and provide data neatly and effectively over the network. The resulting gains are threefold: (1) the benefit in controlling the bandwidth while preventing data duplication; (2) the significant facilitation from user standpoint of writing code by means of proxy access to the hardware, with resort to a standard set of YARP API in place of direct calls to a custom set of Kinect API; (3) the possibility to easily scale up with the addition of new modules accessing the device.

The Kinect Wrapper has been designed and implemented adhering to the client-server paradigm, where the server (i.e. KinectServer) takes care of streaming out all the information over YARP ports and the clients (i.e. KinectClient) are light YARP front-end instantiated within the user code that read Kinect data from the network and provide them in a convenient format. To further separate the driver interfacing the Kinect device from the part of the sever dealing with YARP communication, a third abstraction layer has been considered, namely the KinectDriver, and located at lowest level in the wrapper hierarchy with the requirement of providing the KinectServer with the Kinect raw data to be marshaled and sent over the network. The KinectDriver is thus specialized in two implementations: the KinectDriverSDK and the KinectDriverOpenNI, respectively.

The hierarchical structure of the wrapper can be seen in the following diagram:

Diagram of Kinect-Wrapper architecture

In particular, the KinectServer is realized as a periodic thread that initially opens the Kinect device using either the KinectDriverSDK or the KinectDriverOpenNI components; then, at each run, the server reads the information as configured by the user from the driver (depth data only, user skeleton only, RGB images only or combination of them) and sends them over YARP ports. On the client side, the user relies on a set of simple function calls to retrieve such information.

Documentation

Online documentation is available here: http://robotology.github.com/kinect-wrapper.

License

Material included here is Copyright of Istituto Italiano di Tecnologia and EFAA Consortium. kinectWrapper is released under the terms of the GPL v2.0 or later. See the file LICENSE for details.