00001 #ifndef __DRAGO_H__
00002 #define __DRAGO_H__
00003
00004 #include <stdint.h>
00005 #include "processor.h"
00006
00007 namespace logmap {
00008
00009 class Drago : public spectral::Processor
00010 {
00011 public:
00012 Drago();
00013 virtual ~Drago();
00014
00015 protected:
00016
00017
00018
00019 virtual uint32_t GetInterface(
00020 std::list<std::pair<uint32_t, uint32_t> > &mandatory,
00021 std::list<std::pair<uint32_t, uint32_t> > &optional) const;
00022
00023
00024 virtual bool SetImage(uint32_t type, const spectral::Image *img);
00025
00026
00027 virtual void SetParameters(const spectral::Parameters *);
00028
00029
00030 virtual spectral::Image *Process(void);
00031
00032
00033 virtual void ClearImage(uint32_t type);
00034
00035 protected:
00036
00037
00038 virtual void GetParameters(spectral::Parameters *) const;
00039
00040 private:
00041 float GetAdaptation(spectral::Image *img, uint32_t num_samples, float &max);
00042
00043 const spectral::Image *m_picture;
00044
00045 float m_b;
00046 float m_exposure;
00047 int32_t m_samples;
00048 };
00049
00050 }
00051
00052 #endif