2
Copyright (c) 2008-2009 NetAllied Systems GmbH
4
This file is part of MayaDataModel.
6
Licensed under the MIT Open Source License,
7
for details please see LICENSE file or the website
8
http://www.opensource.org/licenses/mit-license.php
10
#ifndef __MayaDM_DAGPOSE_H__
11
#define __MayaDM_DAGPOSE_H__
12
#include "MayaDMTypes.h"
13
#include "MayaDMConnectables.h"
14
#include "MayaDMDependNode.h"
17
class DagPose : public DependNode
22
DagPose():DependNode(){}
23
DagPose(FILE* file,const std::string& name,const std::string& parent="",bool shared=false,bool create=true)
24
:DependNode(file, name, parent, "dagPose", shared, create){}
27
void setWorldMatrix(size_t wm_i,const matrix& wm)
29
if(wm == identity) return;
30
fprintf(mFile,"\tsetAttr \".wm[%i]\" -type \"matrix\" ",wm_i);
34
void setWorldMatrix(size_t wm_start,size_t wm_end,matrix* wm)
36
fprintf(mFile,"\tsetAttr \".wm[%i:%i]\" ", wm_start,wm_end);
37
size_t size = (wm_end-wm_start)*1+1;
38
for(size_t i=0;i<size;++i)
45
void startWorldMatrix(size_t wm_start,size_t wm_end)const
47
fprintf(mFile,"\tsetAttr \".wm[%i:%i]\"",wm_start,wm_end);
48
fprintf(mFile," -type \"matrix\" ");
50
void appendWorldMatrix(const matrix& wm)const
55
void endWorldMatrix()const
59
void setXformMatrix(size_t xm_i,const matrix& xm)
61
if(xm == identity) return;
62
fprintf(mFile,"\tsetAttr \".xm[%i]\" -type \"matrix\" ",xm_i);
66
void setXformMatrix(size_t xm_start,size_t xm_end,matrix* xm)
68
fprintf(mFile,"\tsetAttr \".xm[%i:%i]\" ", xm_start,xm_end);
69
size_t size = (xm_end-xm_start)*1+1;
70
for(size_t i=0;i<size;++i)
77
void startXformMatrix(size_t xm_start,size_t xm_end)const
79
fprintf(mFile,"\tsetAttr \".xm[%i:%i]\"",xm_start,xm_end);
80
fprintf(mFile," -type \"matrix\" ");
82
void appendXformMatrix(const matrix& xm)const
87
void endXformMatrix()const
91
void setGlobal(size_t g_i,bool g)
93
if(g == false) return;
94
fprintf(mFile,"\tsetAttr \".g[%i]\" %i;\n", g_i,g);
96
void setGlobal(size_t g_start,size_t g_end,bool* g)
98
fprintf(mFile,"\tsetAttr \".g[%i:%i]\" ", g_start,g_end);
99
size_t size = (g_end-g_start)*1+1;
100
for(size_t i=0;i<size;++i)
102
fprintf(mFile,"%i",g[i]);
103
if(i+1<size) fprintf(mFile," ");
105
fprintf(mFile,";\n");
107
void startGlobal(size_t g_start,size_t g_end)const
109
fprintf(mFile,"\tsetAttr \".g[%i:%i]\"",g_start,g_end);
111
void appendGlobal(bool g)const
113
fprintf(mFile," %i",g);
115
void endGlobal()const
117
fprintf(mFile,";\n");
119
void setBindPose(bool bp)
121
if(bp == false) return;
122
fprintf(mFile,"\tsetAttr \".bp\" %i;\n", bp);
124
void getWorldMatrix(size_t wm_i)const
126
fprintf(mFile,"\"%s.wm[%i]\"",mName.c_str(),wm_i);
128
void getWorldMatrix()const
131
fprintf(mFile,"\"%s.wm\"",mName.c_str());
133
void getMembers(size_t m_i)const
135
fprintf(mFile,"\"%s.m[%i]\"",mName.c_str(),m_i);
137
void getMembers()const
140
fprintf(mFile,"\"%s.m\"",mName.c_str());
142
void getParents(size_t p_i)const
144
fprintf(mFile,"\"%s.p[%i]\"",mName.c_str(),p_i);
146
void getParents()const
149
fprintf(mFile,"\"%s.p\"",mName.c_str());
153
fprintf(mFile,"\"%s.w\"",mName.c_str());
156
DagPose(FILE* file,const std::string& name,const std::string& parent,const std::string& nodeType,bool shared=false,bool create=true)
157
:DependNode(file, name, parent, nodeType, shared, create) {}
161
#endif//__MayaDM_DAGPOSE_H__