mirror of
https://github.com/opencv/opencv.git
synced 2025-01-18 14:13:15 +08:00
90 lines
3.3 KiB
TeX
90 lines
3.3 KiB
TeX
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
% %
|
|
% C++ %
|
|
% %
|
|
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
|
|
|
|
\ifCpp
|
|
\section{Using Kinect sensor.}
|
|
|
|
Kinect sensor is supported through \texttt{VideoCapture} class. Depth map, rgb image and some other formats of Kinect
|
|
output can be retrieved by using familiar interface of \texttt{VideoCapture}.\par
|
|
|
|
In order to use Kinect with OpenCV you should do the following preliminary steps:\newline
|
|
1) Install OpenNI library and PrimeSensor Module for OpenNI from here \url{http://www.openni.org/downloadfiles}.
|
|
The installation should be done to default folders listed in the instructions of these products:
|
|
\begin{lstlisting}
|
|
OpenNI:
|
|
Linux & MacOSX:
|
|
Libs into: /usr/lib
|
|
Includes into: /usr/include/ni
|
|
Windows:
|
|
Libs into: c:/Program Files/OpenNI/Lib
|
|
Includes into: c:/Program Files/OpenNI/Include
|
|
PrimeSensor Module:
|
|
Linux & MacOSX:
|
|
Bins into: /usr/bin
|
|
Windows:
|
|
Bins into: c:/Program Files/Prime Sense/Sensor/Bin
|
|
\end{lstlisting}
|
|
If one or both products were installed to the other folders, the user should change corresponding CMake variables
|
|
(\texttt{OPENNI\_LIB\_DIR}, \texttt{OPENNI\_INCLUDE\_DIR} or/and
|
|
\texttt{OPENNI\_PRIME\_SENSOR\_MODULE\_BIN\_DIR}).\newline
|
|
2) Configure OpenCV with OpenNI support by setting \texttt{WITH\_OPENNI} flag in CMake. If OpenNI
|
|
is found in default install folders OpenCV will be built with OpenNI library regardless of whether
|
|
PrimeSensor Module is found or not. If PrimeSensor Module was not found you will get a warning
|
|
in CMake log. Without PrimeSensor module OpenCV will be successfully compiled with OpenNI library,
|
|
but \texttt{VideoCapture} object will not grab data from Kinect sensor. \par
|
|
|
|
3) Build OpenCV.\par
|
|
|
|
VideoCapture can retrieve the following Kinect data:
|
|
\begin{lstlisting}
|
|
a.) data given from depth generator:
|
|
OPENNI_DEPTH_MAP - depth values in mm (CV_16UC1)
|
|
OPENNI_POINT_CLOUD_MAP - XYZ in meters (CV_32FC3)
|
|
OPENNI_DISPARITY_MAP - disparity in pixels (CV_8UC1)
|
|
OPENNI_DISPARITY_MAP_32F - disparity in pixels (CV_32FC1)
|
|
OPENNI_VALID_DEPTH_MASK - mask of valid pixels (not ocluded,
|
|
not shaded etc.) (CV_8UC1)
|
|
b.) data given from RGB image generator:
|
|
OPENNI_BGR_IMAGE - color image (CV_8UC3)
|
|
OPENNI_GRAY_IMAGE - gray image (CV_8UC1)
|
|
\end{lstlisting}
|
|
|
|
In order to get depth map from Kinect use \texttt{VideoCapture::operator >>}, e. g.
|
|
\begin{lstlisting}
|
|
VideoCapture capture(0); // or CV_CAP_OPENNI
|
|
for(;;)
|
|
{
|
|
Mat depthMap;
|
|
|
|
capture >> depthMap;
|
|
|
|
if( waitKey( 30 ) >= 0 )
|
|
break;
|
|
}
|
|
\end{lstlisting}
|
|
For getting several Kinect maps use \texttt{VideoCapture::grab + VideoCapture::retrieve}, e.g.
|
|
\begin{lstlisting}
|
|
VideoCapture capture(0); // or CV_CAP_OPENNI
|
|
for(;;)
|
|
{
|
|
Mat depthMap;
|
|
Mat rgbImage
|
|
|
|
capture.grab();
|
|
|
|
capture.retrieve( depthMap, OPENNI_DEPTH_MAP );
|
|
capture.retrieve( bgrImage, OPENNI_BGR_IMAGE );
|
|
|
|
if( waitKey( 30 ) >= 0 )
|
|
break;
|
|
}
|
|
\end{lstlisting}
|
|
|
|
For more information please refer to a kinect example of usage \texttt{kinect\_maps.cpp} in \texttt{sample} folder.
|
|
|
|
\fi
|