X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcapsule.cpp;h=f00f6ca2dc146bb661adf5b03697b880e0d81824;hb=8e9d872c2ba8dc633d29a673ba93adf38d262a5c;hp=86f5d57a8d50d0f42f2cc2c5ea76e6012910c3e1;hpb=bbfb79181f716736df413f463b55825866400ed8;p=libs%2Fgl.git diff --git a/source/capsule.cpp b/source/capsule.cpp index 86f5d57a..f00f6ca2 100644 --- a/source/capsule.cpp +++ b/source/capsule.cpp @@ -1,10 +1,3 @@ -/* $Id$ - -This file is part of libmspgl -Copyright © 2011 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #include #include "capsule.h" #include "primitivebuilder.h" @@ -31,23 +24,15 @@ void CapsuleBuilder::build(PrimitiveBuilder &builder) const { float u_scale = 1.0/segments; float v_scale = 1/(length+radius*M_PI); - if(tex_fit!=STRETCH) - { - float l1 = radius*M_PI*2; - float l2 = length+radius*M_PI; - if((l1rings/2 ? 0.5 : -0.5); - float v = (i*radius*M_PI/rings+(i>rings/2 ? length : 0))*v_scale; + float v = ((i>rings/2 ? i-1 : i)*radius*M_PI/(rings-1)+(i>rings/2 ? length : 0))*v_scale; float ra = (i>rings/2 ? i-1 : i)*M_PI/(rings-1); float rc = cos(ra); float rs = sin(ra); @@ -57,10 +42,10 @@ void CapsuleBuilder::build(PrimitiveBuilder &builder) const float sc = cos(sa); float ss = sin(sa); builder.normal(rs*sc, rs*ss, -rc); - if(tangent_attr) + if(generate_tbn) { - builder.attrib(tangent_attr, -ss, sc, 0); - builder.attrib(binormal_attr, rc*sc, rc*ss, rs); + builder.tangent(-ss, sc, 0); + builder.binormal(rc*sc, rc*ss, rs); } builder.texcoord(j*u_scale, v); builder.vertex(rs*sc*radius, rs*ss*radius, cz-rc*radius); @@ -68,7 +53,7 @@ void CapsuleBuilder::build(PrimitiveBuilder &builder) const } builder.normal(0, 0, 1); builder.texcoord(0.5, (length+radius*M_PI)*v_scale); - builder.vertex(0, 0, length/2-radius); + builder.vertex(0, 0, length/2+radius); for(unsigned i=0; i