diff options
author | Stéphane Lenclud <github@lenclud.com> | 2019-04-16 12:23:22 +0200 |
---|---|---|
committer | Stéphane Lenclud <github@lenclud.com> | 2019-04-24 18:46:12 +0200 |
commit | 1fb6122dce1a5bc117e925006d87828a52cfecb6 (patch) | |
tree | 0c6250bc59b93cdc92a4df75ab77d0e88690e8b2 /tracker-kinect-face/camera_kinect_ir.cpp | |
parent | 5e2f6182f41d7c027f58b110bc8c6e539a50ac2c (diff) |
Easy Tracker: Cheap way to dramatically improve CPU usage. Now displaying FPS info on frame preview.
Diffstat (limited to 'tracker-kinect-face/camera_kinect_ir.cpp')
-rw-r--r-- | tracker-kinect-face/camera_kinect_ir.cpp | 40 |
1 files changed, 21 insertions, 19 deletions
diff --git a/tracker-kinect-face/camera_kinect_ir.cpp b/tracker-kinect-face/camera_kinect_ir.cpp index 77621076..e170b15a 100644 --- a/tracker-kinect-face/camera_kinect_ir.cpp +++ b/tracker-kinect-face/camera_kinect_ir.cpp @@ -96,8 +96,8 @@ std::tuple<const video::impl::frame&, bool> CameraKinectIr::get_frame() new_frame = get_frame_(iMatFrame); iFrame.data = iMatFrame.ptr(); - iFrame.width = 512; - iFrame.height = 424; + iFrame.width = iWidth; + iFrame.height = iHeight; iFrame.stride = cv::Mat::AUTO_STEP; iFrame.channels = iMatFrame.channels(); iFrame.channelSize = iMatFrame.elemSize1(); @@ -115,6 +115,9 @@ inline void SafeRelease(Interface *& pInterfaceToRelease) } } +/// +/// +/// bool CameraKinectIr::start(info& aInfo) { stop(); @@ -162,8 +165,8 @@ bool CameraKinectIr::start(info& aInfo) if (success) { // Provide frame info - aInfo.width = width; - aInfo.height = height; + aInfo.width = iWidth; + aInfo.height = iHeight; CameraIntrinsics intrinsics; hr = iCoordinateMapper->GetDepthCameraIntrinsics(&intrinsics); @@ -223,13 +226,7 @@ bool CameraKinectIr::get_frame_(cv::Mat& aFrame) if (SUCCEEDED(hr)) { - INT64 nTime = 0; - UINT nBufferSize = 0; - UINT16 *pBuffer = NULL; - - hr = iInfraredFrame->get_RelativeTime(&nTime); - - if (first_frame) + if (iFirstFrame) { IFrameDescription* frameDescription = NULL; @@ -238,28 +235,33 @@ bool CameraKinectIr::get_frame_(cv::Mat& aFrame) hr = iInfraredFrame->get_FrameDescription(&frameDescription); } - // TODO: should not request those info for a every frame really if (SUCCEEDED(hr)) { - hr = frameDescription->get_Width(&width); + hr = frameDescription->get_Width(&iWidth); } if (SUCCEEDED(hr)) { - hr = frameDescription->get_Height(&height); + hr = frameDescription->get_Height(&iHeight); } if (SUCCEEDED(hr)) { - hr = frameDescription->get_DiagonalFieldOfView(&fov); + hr = frameDescription->get_DiagonalFieldOfView(&iFov); } if (SUCCEEDED(hr)) - first_frame = false; - + { + iFirstFrame = false; + } + SafeRelease(frameDescription); } - + + + UINT nBufferSize = 0; + UINT16 *pBuffer = NULL; + if (SUCCEEDED(hr)) { hr = iInfraredFrame->AccessUnderlyingBuffer(&nBufferSize, &pBuffer); @@ -268,7 +270,7 @@ bool CameraKinectIr::get_frame_(cv::Mat& aFrame) if (SUCCEEDED(hr)) { // Create an OpenCV matrix with our 16-bits IR buffer - aFrame = cv::Mat(height, width, CV_16UC1, pBuffer, cv::Mat::AUTO_STEP); + aFrame = cv::Mat(iHeight, iWidth, CV_16UC1, pBuffer, cv::Mat::AUTO_STEP); // Any processing of the frame is left to the user success = true; } |