X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fbuilders%2Fvertexarraybuilder.cpp;h=3afe9a40e2bf22c48869207ef9b73235c9dd784b;hp=7bc31b22f9d50e3b11c2a4dbce22c9b4dfb0cfee;hb=d493917dbc215cd6ba3f8773a52a289d9f14380d;hpb=a3cc9f4469153396c7ad0868f3cbb2d2f698d710;ds=sidebyside diff --git a/source/builders/vertexarraybuilder.cpp b/source/builders/vertexarraybuilder.cpp index 7bc31b22..3afe9a40 100644 --- a/source/builders/vertexarraybuilder.cpp +++ b/source/builders/vertexarraybuilder.cpp @@ -1,6 +1,8 @@ #include "vertexarray.h" #include "vertexarraybuilder.h" +using namespace std; + namespace Msp { namespace GL { @@ -10,31 +12,49 @@ VertexArrayBuilder::VertexArrayBuilder(VertexArray &a): void VertexArrayBuilder::vertex_(const Vector4 &vtx) { - float *ptr = array.append(); + char *ptr = array.append(); const VertexFormat &format = array.get_format(); - for(const unsigned char *a=format.begin(); a!=format.end(); ++a) + for(const UInt16 *a=format.begin(); a!=format.end(); ++a) { unsigned sem = get_attribute_semantic(*a); - unsigned sz = get_attribute_size(*a); - if(sem>=attr.size()) - ptr += sz; - else if(*a==COLOR4_UBYTE) + DataType type = get_attribute_source_type(*a); + unsigned cc = get_attribute_component_count(*a); + + if(sem(attr[sem].x*255); - u.c[1] = static_cast(attr[sem].y*255); - u.c[2] = static_cast(attr[sem].z*255); - u.c[3] = static_cast(attr[sem].w*255); - *ptr++ = u.f; + const Vector4 &value = (sem==0 ? vtx : attr[sem]); + if(type==UNSIGNED_BYTE) + store_attribute(ptr, value, cc); + else if(type==BYTE) + store_attribute(ptr, value, cc); + else if(type==UNSIGNED_SHORT) + store_attribute(ptr, value, cc); + else if(type==SHORT) + store_attribute(ptr, value, cc); + else if(type==UNSIGNED_INT) + store_attribute(ptr, value, cc); + else if(type==INT) + store_attribute(ptr, value, cc); + else if(type==FLOAT) + store_attribute(ptr, value, cc); } + + ptr += get_attribute_size(*a); + } +} + +template +void VertexArrayBuilder::store_attribute(char *ptr, const Vector4 &value, unsigned count) +{ + T *tptr = reinterpret_cast(ptr); + for(unsigned i=0; i::is_integer) + *tptr++ = value[i]; + else if(numeric_limits::is_signed) + *tptr++ = round(min(max(value[i], -1.0f), 1.0f)*numeric_limits::max()); else - { - const Vector4 &v = (sem==0 ? vtx : attr[sem]); - *ptr++ = v.x; - if(sz>=2) *ptr++ = v.y; - if(sz>=3) *ptr++ = v.z; - if(sz>=4) *ptr++ = v.w; - } + *tptr++ = round(min(max(value[i], 0.0f), 1.0f)*numeric_limits::max()); } }