00001
00002
00003
00004
00005
00006
00007
00008
00009
00010 #ifndef HxBpoSetPixElt_h
00011 #define HxBpoSetPixElt_h
00012
00013 #include "HxTagList.h"
00014 #include "HxClassName.h"
00015 #include "HxCategories.h"
00016
00017
00018 template<class DstValT, class Src1ValT, class Src2ValT>
00019 class HxBpoSetPixElt
00020 {
00021 public:
00023 typedef HxTagTransInVar TransVarianceCategory;
00024
00025 HxBpoSetPixElt(HxTagList& tags);
00026
00027 DstValT doIt(const Src1ValT& x, const Src2ValT& y)
00028 { DstValT r(x); r.setValue(_dim, y.x()); return r; }
00029
00030 static HxString className()
00031 { return HxString("setPixelElement"); }
00032
00033 private:
00034 int _dim;
00035 };
00036
00037 template<class DstValT, class Src1ValT, class Src2ValT>
00038 inline
00039 HxBpoSetPixElt<DstValT, Src1ValT, Src2ValT>::HxBpoSetPixElt(HxTagList& tags)
00040 {
00041 _dim = HxGetTag(tags, "dimension", int(1));
00042 if (_dim < 0)
00043 _dim = 1;
00044 _dim = ((_dim - 1) % 3) + 1;
00045 }
00046
00047 #endif
00048