1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
|
/****************************************************************************
* *
* OpenNI 1.x Alpha *
* Copyright (C) 2011 PrimeSense Ltd. *
* *
* This file is part of OpenNI. *
* *
* OpenNI is free software: you can redistribute it and/or modify *
* it under the terms of the GNU Lesser General Public License as published *
* by the Free Software Foundation, either version 3 of the License, or *
* (at your option) any later version. *
* *
* OpenNI is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU Lesser General Public License for more details. *
* *
* You should have received a copy of the GNU Lesser General Public License *
* along with OpenNI. If not, see <http://www.gnu.org/licenses/>. *
* *
****************************************************************************/
#include "MockImageGenerator.h"
#include <XnPropNames.h>
#include <XnLog.h>
MockImageGenerator::MockImageGenerator(xn::Context& context, const XnChar* strName) :
MockMapGenerator(context, strName),
m_pixelFormat(XN_PIXEL_FORMAT_RGB24)
{
xnOSMemSet(&m_supportedPixelFormats, 0, sizeof(m_supportedPixelFormats));
}
MockImageGenerator::~MockImageGenerator()
{
}
XnStatus MockImageGenerator::SetIntProperty(const XnChar* strName, XnUInt64 nValue)
{
XnStatus nRetVal = XN_STATUS_OK;
if (strcmp(strName, XN_PROP_PIXEL_FORMAT) == 0)
{
nRetVal = SetPixelFormat((XnPixelFormat)nValue);
XN_IS_STATUS_OK(nRetVal);
}
else
{
return MockMapGenerator::SetIntProperty(strName, nValue);
}
return XN_STATUS_OK;
}
XnStatus MockImageGenerator::SetGeneralProperty(const XnChar* strName, XnUInt32 nBufferSize, const void* pBuffer)
{
if (strcmp(strName, XN_PROP_SUPPORTED_PIXEL_FORMATS) == 0)
{
if (nBufferSize != sizeof(m_supportedPixelFormats))
{
XN_ASSERT(FALSE);
XN_LOG_ERROR_RETURN(XN_STATUS_INVALID_BUFFER_SIZE, XN_MASK_OPEN_NI, "Cannot set XN_PROP_SUPPORTED_PIXEL_FORMATS - buffer size is incorrect");
}
xnOSMemCopy(&m_supportedPixelFormats, pBuffer, nBufferSize);
}
else
{
return MockMapGenerator::SetGeneralProperty(strName, nBufferSize, pBuffer);
}
return XN_STATUS_OK;
}
XnUInt8* MockImageGenerator::GetImageMap()
{
return (XnUInt8*)GetData();;
}
XnBool MockImageGenerator::IsPixelFormatSupported(XnPixelFormat format)
{
switch (format)
{
case XN_PIXEL_FORMAT_RGB24:
return m_supportedPixelFormats.m_bRGB24;
case XN_PIXEL_FORMAT_YUV422:
return m_supportedPixelFormats.m_bYUV422;
case XN_PIXEL_FORMAT_GRAYSCALE_8_BIT:
return m_supportedPixelFormats.m_bGrayscale8Bit;
case XN_PIXEL_FORMAT_GRAYSCALE_16_BIT:
return m_supportedPixelFormats.m_bGrayscale16Bit;
case XN_PIXEL_FORMAT_MJPEG:
return m_supportedPixelFormats.m_bMJPEG;
default:
XN_ASSERT(FALSE);
return FALSE;
}
}
XnStatus MockImageGenerator::SetPixelFormat(XnPixelFormat format)
{
XnStatus nRetVal = XN_STATUS_OK;
if (m_pixelFormat != format)
{
m_pixelFormat = format;
nRetVal = m_pixelFormatChangeEvent.Raise();
XN_IS_STATUS_OK(nRetVal);
}
return XN_STATUS_OK;
}
XnPixelFormat MockImageGenerator::GetPixelFormat()
{
return m_pixelFormat;
}
XnStatus MockImageGenerator::RegisterToPixelFormatChange(XnModuleStateChangedHandler handler, void* pCookie, XnCallbackHandle& hCallback)
{
return m_pixelFormatChangeEvent.Register(handler, pCookie, hCallback);
}
void MockImageGenerator::UnregisterFromPixelFormatChange(XnCallbackHandle hCallback)
{
m_pixelFormatChangeEvent.Unregister(hCallback);
}
|