X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Funiform.h;h=f8a59f2a441e5fd2b3ec2ba55cdd604b50ab0477;hb=8eb9a8d90e5597154dab666481037b306b7bbca2;hp=32779ced0a06cc0206a20982ee57ac4d52024335;hpb=f9c15dc04462b2f1eea1d6bdd71e3ba967b1bd8c;p=libs%2Fgl.git diff --git a/source/uniform.h b/source/uniform.h index 32779ced..f8a59f2a 100644 --- a/source/uniform.h +++ b/source/uniform.h @@ -2,6 +2,7 @@ #define MSP_GL_UNIFORM_H_ #include +#include "program.h" namespace Msp { namespace GL { @@ -17,6 +18,7 @@ public: virtual ~Uniform() { } virtual void apply(int) const = 0; + virtual void store(const Program::UniformInfo &, void *) const = 0; virtual Uniform *clone() const = 0; }; @@ -34,7 +36,16 @@ private: public: UniformScalar(Type v): value(v) { } - virtual void apply(int index) const; + virtual void apply(int index) const + { apply(index, 1, &value); } + + static void apply(int, unsigned, const T *); + + virtual void store(const Program::UniformInfo &info, void *buffer) const + { store(info, buffer, &value); } + + static void store(const Program::UniformInfo &, void *buffer, const T *value) + { *reinterpret_cast(buffer) = *value; } virtual UniformScalar *clone() const { return new UniformScalar(value); } @@ -58,7 +69,16 @@ public: UniformVector(const T *vp) { std::copy(vp, vp+vecsize, value); } - virtual void apply(int index) const; + virtual void apply(int index) const + { apply(index, 1, value); } + + static void apply(int index, unsigned size, const T *value); + + virtual void store(const Program::UniformInfo &info, void *buffer) const + { store(info, buffer, value); } + + static void store(const Program::UniformInfo &, void *buffer, const T *value) + { std::copy(value, value+vecsize, reinterpret_cast(buffer)); } virtual UniformVector *clone() const { return new UniformVector(value); } @@ -83,7 +103,19 @@ public: UniformMatrix(const T *vp) { std::copy(vp, vp+rows*cols, value); } - virtual void apply(int index) const; + virtual void apply(int index) const + { apply(index, 1, value); } + + static void apply(int index, unsigned size, const T *value); + + virtual void store(const Program::UniformInfo &info, void *buffer) const + { store(info, buffer, value); } + + static void store(const Program::UniformInfo &info, void *buffer, const T *value) + { + for(unsigned i=0; i::store(info, reinterpret_cast(buffer)+i*info.matrix_stride, value+i*rows); + } virtual UniformMatrix *clone() const { return new UniformMatrix(value); } @@ -91,6 +123,38 @@ public: typedef UniformMatrix UniformMatrix4x4f; + +template +class UniformArray: public Uniform +{ +private: + typedef typename T::BaseType BaseType; + enum { elemsize = sizeof(typename T::Type)/sizeof(typename T::BaseType) }; + + BaseType *values; + unsigned size; + +public: + UniformArray(unsigned n, const BaseType *vp): + size(n) + { + values = new BaseType[elemsize*size]; + std::copy(vp, vp+elemsize*size, values); + } + + virtual void apply(int index) const + { T::apply(index, size, values); } + + virtual void store(const Program::UniformInfo &info, void *buffer) const + { + for(unsigned i=0; i(buffer)+i*info.array_stride, values+i*elemsize); + } + + virtual UniformArray *clone() const + { return new UniformArray(size, values); } +}; + } // namespace GL } // namespace Msp