rawdata.h
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #ifndef __OPENRAW_RAWDATA_H__
00024 #define __OPENRAW_RAWDATA_H__
00025
00026 #include <vector>
00027
00028 #include <libopenraw/libopenraw.h>
00029 #include <libopenraw++/bitmapdata.h>
00030
00031
00032 namespace OpenRaw {
00033
00034 class RawData
00035 : public BitmapData
00036 {
00037 public:
00038 typedef or_cfa_pattern CfaPattern;
00039 static RawData * getAndExtractRawData(const char* filename,
00040 uint32_t options,
00041 or_error & err);
00042
00043 RawData();
00044 virtual ~RawData();
00045
00046 uint16_t min();
00047 uint16_t max();
00048 void setMin(uint16_t _m);
00049 void setMax(uint16_t _m);
00050
00052 void swap(RawData & with);
00053
00054 virtual void *allocData(const size_t s);
00055 virtual void setDimensions(uint32_t x, uint32_t y);
00056 void setCfaPattern(CfaPattern t);
00057 CfaPattern cfaPattern();
00058 uint32_t compression();
00059 void setCompression(uint32_t c);
00060
00061
00062 void setSlices(const std::vector<uint16_t> & slices);
00063
00065
00067 RawData &append(uint16_t c);
00069 void nextRow();
00070 private:
00071 class Private;
00072 RawData::Private *d;
00073
00075 RawData(const RawData& f);
00077 RawData & operator=(const RawData&);
00078 };
00079
00080 }
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091 #endif