22 #ifndef __XNBITSET_H__
23 #define __XNBITSET_H__
36 return m_array.
Reserve((nBits >> 5) + 1);
42 return m_array.
SetSize((nBits >> 5) + 1, 0);
48 XnUInt32 nArrayIndex = (nIndex >> 5);
49 XnUInt32 nMask = (1 << ((~nIndex) & 0x1F));
50 XnUInt32 nOldVal = nArrayIndex < m_array.
GetSize() ? m_array[nArrayIndex] : 0;
51 XnUInt32 nNewVal = bValue ? (nOldVal | nMask) : (nOldVal & (~nMask));
52 XnStatus nRetVal = m_array.
Set(nArrayIndex, nNewVal, 0);
54 m_nSize =
XN_MAX(m_nSize, nIndex + 1);
59 XnBool
IsSet(XnUInt32 nIndex)
const
61 XnUInt32 nArrayIndex = (nIndex >> 5);
62 if (nArrayIndex >= m_array.
GetSize())
66 return (m_array[nArrayIndex] & (1 << ((~nIndex) & 0x1F))) ?
TRUE :
FALSE;
74 m_nSize = (nSizeInDwords << 5);
82 XnUInt32 nSizeInDwords =
XN_MAX(1, nSizeInBytes >> 2);
85 for (XnUInt32 nDwordIdx = 0, nByteIdx = 0; nDwordIdx < nSizeInDwords; nDwordIdx++, nByteIdx += 4)
87 m_array[nDwordIdx] = ((pData[nByteIdx] << 24) | (pData[nByteIdx + 1] << 16) | (pData[nByteIdx + 2] << 8) | pData[nByteIdx + 3] );
89 m_nSize = (nSizeInBytes << 3);
135 #endif // __XNBITSET_H__