X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fanimatedobject.cpp;h=390b90b869ce6acc9eb5a5a93a6fbe701776429e;hp=63a25112a769428374e37dd0634251b4f2c2c8b7;hb=HEAD;hpb=0c731643d6363eb4c492e836ffb919cb7c0a3035 diff --git a/source/animatedobject.cpp b/source/animatedobject.cpp deleted file mode 100644 index 63a25112..00000000 --- a/source/animatedobject.cpp +++ /dev/null @@ -1,52 +0,0 @@ -#include -#include -#include "animatedobject.h" -#include "object.h" -#include "programdata.h" -#include "renderer.h" -#include "technique.h" - -using namespace std; - -namespace Msp { -namespace GL { - -AnimatedObject::AnimatedObject(const Object &o): - ObjectInstance(o), - shdata(0) -{ - if(const Technique *tech = object.get_technique()) - if(tech->has_shaders()) - shdata = new ProgramData; -} - -AnimatedObject::~AnimatedObject() -{ - delete shdata; -} - -void AnimatedObject::set_matrix(const Matrix &m) -{ - matrix = m; -} - -void AnimatedObject::set_pose_matrix(unsigned link, const Matrix &m) -{ - if(shdata) - { - if(link*16>=pose_data.size()) - pose_data.resize((link+1)*16); - copy(m.data(), m.data()+16, &pose_data[link*16]); - shdata->uniform_matrix4_array("pose[0]", pose_data.size()/16, &pose_data[0]); - } -} - -void AnimatedObject::setup_render(Renderer &renderer, const Tag &) const -{ - renderer.matrix_stack() *= matrix; - if(shdata) - renderer.add_shader_data(*shdata); -} - -} // namespace GL -} // namespace Msp