From 70156963a8f65d21231de88460e6559bd78f770c Mon Sep 17 00:00:00 2001 From: Stéphane Lenclud Date: Sun, 3 Feb 2019 12:13:53 +0100 Subject: Kinect: Fixing massive memory leak after start/stop cycle. --- tracker-kinect-face/tracker.cpp | 89 +++++++++++++++-------------------------- 1 file changed, 32 insertions(+), 57 deletions(-) diff --git a/tracker-kinect-face/tracker.cpp b/tracker-kinect-face/tracker.cpp index 8c2c164d..54a716ac 100644 --- a/tracker-kinect-face/tracker.cpp +++ b/tracker-kinect-face/tracker.cpp @@ -241,82 +241,57 @@ HRESULT KinectFaceTracker::InitializeDefaultSensor() { HRESULT hr; + // Get and open Kinect sensor hr = GetDefaultKinectSensor(&m_pKinectSensor); - if (FAILED(hr)) + if (SUCCEEDED(hr)) { - return hr; + hr = m_pKinectSensor->Open(); } - if (m_pKinectSensor) + // TODO: check if we still need that guy + if (SUCCEEDED(hr)) { - // Initialize Kinect and get color, body and face readers - UniqueInterface pBodyFrameSource; - UniqueInterface pColorFrameSource; - - hr = m_pKinectSensor->Open(); + hr = m_pKinectSensor->get_CoordinateMapper(&m_pCoordinateMapper); + } - if (SUCCEEDED(hr)) - { - hr = m_pKinectSensor->get_CoordinateMapper(&m_pCoordinateMapper); - } + // Create color frame reader + if (SUCCEEDED(hr)) + { + UniqueInterface colorFrameSource; + hr = m_pKinectSensor->get_ColorFrameSource(colorFrameSource.PtrPtr()); + colorFrameSource.Reset(); if (SUCCEEDED(hr)) { - hr = m_pKinectSensor->get_ColorFrameSource(pColorFrameSource.PtrPtr()); - pColorFrameSource.Reset(); + hr = colorFrameSource->OpenReader(&m_pColorFrameReader); } + } - //std::unique_ptr colorFrameSource(pColorFrameSource, SafeRelease); - - if (SUCCEEDED(hr)) - { - //hr = (*pColorFrameSource.PtrPtr())->OpenReader(&m_pColorFrameReader); - hr = pColorFrameSource->OpenReader(&m_pColorFrameReader); - } - - - if (SUCCEEDED(hr)) - { - hr = m_pKinectSensor->get_BodyFrameSource(pBodyFrameSource.PtrPtr()); - pBodyFrameSource.Reset(); - } + // Create body frame reader + if (SUCCEEDED(hr)) + { + UniqueInterface bodyFrameSource; + hr = m_pKinectSensor->get_BodyFrameSource(bodyFrameSource.PtrPtr()); + bodyFrameSource.Reset(); if (SUCCEEDED(hr)) { - hr = pBodyFrameSource->OpenReader(&m_pBodyFrameReader); - } - - if (SUCCEEDED(hr)) - { - // create a face frame source + reader to track each body in the fov - for (int i = 0; i < BODY_COUNT; i++) - { - if (SUCCEEDED(hr)) - { - // create the face frame source by specifying the required face frame features - hr = CreateHighDefinitionFaceFrameSource(m_pKinectSensor, &m_pFaceFrameSource); - } - if (SUCCEEDED(hr)) - { - // open the corresponding reader - hr = m_pFaceFrameSource->OpenReader(&m_pFaceFrameReader); - } - } + hr = bodyFrameSource->OpenReader(&m_pBodyFrameReader); } + } - //pColorFrameSource.Free(); - //pBodyFrameSource.Free(); - //SafeRelease(pColorFrameSource); - //SafeRelease(pBodyFrameSource); - - //SafeRelease(*pBodyFrameSource.PtrPtr()); - //SafeRelease(*pColorFrameSource.PtrPtr()); + // Create HD face frame source + if (SUCCEEDED(hr)) + { + // create the face frame source by specifying the required face frame features + hr = CreateHighDefinitionFaceFrameSource(m_pKinectSensor, &m_pFaceFrameSource); } - if (!m_pKinectSensor || FAILED(hr)) + // Create HD face frame reader + if (SUCCEEDED(hr)) { - //SetStatusMessage(L"No ready Kinect found!", 10000, true); - return E_FAIL; + // open the corresponding reader + hr = m_pFaceFrameSource->OpenReader(&m_pFaceFrameReader); } return hr; -- cgit v1.2.3