MITK-IGT
IGT Extension of MITK
Loading...
Searching...
No Matches
mitkToFCameraPMDRawDataDevice.h
Go to the documentation of this file.
1/*============================================================================
2
3The Medical Imaging Interaction Toolkit (MITK)
4
5Copyright (c) German Cancer Research Center (DKFZ)
6All rights reserved.
7
8Use of this source code is governed by a 3-clause BSD license that can be
9found in the LICENSE file.
10
11============================================================================*/
12#ifndef mitkToFCameraPMDRawDataDevice_h
13#define mitkToFCameraPMDRawDataDevice_h
14
15#include <MitkPMDExports.h>
16#include "mitkToFCameraDevice.h"
19
20namespace mitk
21{
30 class MITKPMD_EXPORT ToFCameraPMDRawDataDevice : public ToFCameraDevice
31 {
32 public:
33
35
37
39
40 itkSetMacro(ChannelSize, int);
41 itkGetMacro(ChannelSize, int);
45 virtual bool OnConnectCamera();
49 virtual bool DisconnectCamera();
54 virtual void StartCamera();
58 virtual void StopCamera();
62 virtual void UpdateCamera();
66 virtual bool IsCameraActive();
73 virtual void GetAmplitudes(float* amplitudeArray, int& imageSequence);
79 virtual void GetIntensities(float* intensityArray, int& imageSequence);
85 virtual void GetDistances(float* distanceArray, int& imageSequence);
96 virtual void GetAllImages(float* distanceArray, float* amplitudeArray, float* intensityArray, char* sourceDataArray,
97 int requiredImageSequence, int& capturedImageSequence, unsigned char* rgbDataArray=nullptr);
101 ToFCameraPMDController::Pointer GetController();
102
103 virtual void GetChannelSourceData(short* /*sourceData*/, vtkShortArray* /*vtkChannelArray*/ ){};
104
108 virtual void SetProperty( const char *propertyKey, BaseProperty* propertyValue );
109
110 protected:
111
113
115
119 virtual void AllocateSourceData();
120
124 virtual void CleanUpSourceData();
125
129 virtual void AllocatePixelArrays();
133 virtual void CleanupPixelArrays();
137 static ITK_THREAD_RETURN_TYPE Acquire(void* pInfoStruct);
138
143
152 void XYAxisFlipImage( float* imageData, float* &flippedData, int xAxis, int yAxis, int dimension = 1 );
153
154 //member variables
155 ToFCameraPMDController::Pointer m_Controller;
156 ThreadedToFRawDataReconstruction::Pointer m_RawDataSource;
162
163 private:
164 int m_ChannelSize;
165
166 };
167} //END mitk namespace
168#endif
Virtual interface and base class for all Time-of-Flight devices.
Interface for all representations of PMD ToF devices. ToFCameraPMDDevice internally holds an instance...
ToFCameraPMDController::Pointer m_Controller
corresponding CameraController
short * m_ShortSourceData
array holding the current PMD raw data
unsigned int m_OriginControllerWidth
holds the original controller width
void GetNextPos()
moves the position pointer m_CurrentPos to the next position in the buffer if that's not the next fre...
mitkClassMacro(ToFCameraPMDRawDataDevice, ToFCameraDevice)
char ** m_SourceDataBuffer
buffer holding the last acquired images
ThreadedToFRawDataReconstruction::Pointer m_RawDataSource
virtual void GetChannelSourceData(short *, vtkShortArray *)
char * m_SourceDataArray
array holding the current PMD source data
unsigned int m_OriginControllerHeight
holds the original controller height
IGT Exceptions.