X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fbuilders%2Fvertexarraybuilder.cpp;h=c9a1f3bc8c5c5d8a751705fdfb3603ad196a7e6f;hp=3afe9a40e2bf22c48869207ef9b73235c9dd784b;hb=006bdb4f8660098fc524dcca80b24c943c65b249;hpb=d493917dbc215cd6ba3f8773a52a289d9f14380d diff --git a/source/builders/vertexarraybuilder.cpp b/source/builders/vertexarraybuilder.cpp index 3afe9a40..c9a1f3bc 100644 --- a/source/builders/vertexarraybuilder.cpp +++ b/source/builders/vertexarraybuilder.cpp @@ -13,43 +13,43 @@ VertexArrayBuilder::VertexArrayBuilder(VertexArray &a): void VertexArrayBuilder::vertex_(const Vector4 &vtx) { char *ptr = array.append(); - const VertexFormat &format = array.get_format(); - for(const UInt16 *a=format.begin(); a!=format.end(); ++a) + for(VertexAttribute a: array.get_format()) { - unsigned sem = get_attribute_semantic(*a); - DataType type = get_attribute_source_type(*a); - unsigned cc = get_attribute_component_count(*a); + unsigned sem = get_attribute_semantic(a); + bool integer = is_integer_attribute(a); + DataType type = get_attribute_source_type(a); + unsigned cc = get_attribute_component_count(a); if(sem(ptr, value, cc); + store_attribute(ptr, value, !integer, cc); else if(type==BYTE) - store_attribute(ptr, value, cc); + store_attribute(ptr, value, !integer, cc); else if(type==UNSIGNED_SHORT) - store_attribute(ptr, value, cc); + store_attribute(ptr, value, !integer, cc); else if(type==SHORT) - store_attribute(ptr, value, cc); + store_attribute(ptr, value, !integer, cc); else if(type==UNSIGNED_INT) - store_attribute(ptr, value, cc); + store_attribute(ptr, value, !integer, cc); else if(type==INT) - store_attribute(ptr, value, cc); + store_attribute(ptr, value, !integer, cc); else if(type==FLOAT) - store_attribute(ptr, value, cc); + store_attribute(ptr, value, false, cc); } - ptr += get_attribute_size(*a); + ptr += get_attribute_size(a); } } template -void VertexArrayBuilder::store_attribute(char *ptr, const Vector4 &value, unsigned count) +void VertexArrayBuilder::store_attribute(char *ptr, const Vector4 &value, bool normalize, unsigned count) { T *tptr = reinterpret_cast(ptr); for(unsigned i=0; i::is_integer) + if(!numeric_limits::is_integer || !normalize) *tptr++ = value[i]; else if(numeric_limits::is_signed) *tptr++ = round(min(max(value[i], -1.0f), 1.0f)*numeric_limits::max());