X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fkeyframe.cpp;fp=source%2Fkeyframe.cpp;h=e0d35ad80c7546a74f00754657a283a5e4583520;hp=429d893c1afa513fd351913d66833cfd7c9ccc3f;hb=57fc4142e0b19a21f61c60b00f8310d5d2c27871;hpb=8cbb77df13c4a0e6d6ae0f8b32913cf7e5b2f59c diff --git a/source/keyframe.cpp b/source/keyframe.cpp index 429d893c..e0d35ad8 100644 --- a/source/keyframe.cpp +++ b/source/keyframe.cpp @@ -1,4 +1,8 @@ +#include #include "keyframe.h" +#include "pose.h" + +using namespace std; namespace Msp { namespace GL { @@ -8,15 +12,48 @@ void KeyFrame::set_matrix(const Matrix &m) matrix = m; } +void KeyFrame::set_pose(const Pose &p) +{ + pose = &p; + pose.keep(); +} + + KeyFrame::Loader::Loader(KeyFrame &k): - DataFile::ObjectLoader(k) + DataFile::CollectionObjectLoader(k, 0) { + init(); +} + +KeyFrame::Loader::Loader(KeyFrame &k, Collection &c): + DataFile::CollectionObjectLoader(k, &c) +{ + init(); +} + +void KeyFrame::Loader::init() +{ + add("pose", &Loader::pose); + add("pose", &Loader::pose_inline); add("position", &Loader::position); add("rotation", &Loader::rotation); add("scaling", &Loader::scaling_uniform); add("scaling", &Loader::scaling); } +void KeyFrame::Loader::pose(const string &n) +{ + obj.pose = &get_collection().get(n); + obj.pose.keep(); +} + +void KeyFrame::Loader::pose_inline() +{ + RefPtr p = new Pose; + load_sub(*p, get_collection()); + obj.pose = p; +} + void KeyFrame::Loader::position(float x, float y, float z) { obj.matrix.translate(x, y, z);