~ubuntu-branches/ubuntu/wily/opencollada/wily

« back to all changes in this revision

Viewing changes to Externals/MayaDataModel/include/MayaDMWtAddMatrix.h

  • Committer: Package Import Robot
  • Author(s): Matteo F. Vescovi
  • Date: 2015-05-14 17:23:27 UTC
  • Revision ID: package-import@ubuntu.com-20150514172327-f862u8envms01fra
Tags: upstream-0.1.0~20140703.ddf8f47+dfsg1
ImportĀ upstreamĀ versionĀ 0.1.0~20140703.ddf8f47+dfsg1

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
    Copyright (c) 2008-2009 NetAllied Systems GmbH
 
3
 
 
4
    This file is part of MayaDataModel.
 
5
 
 
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
 
9
*/
 
10
#ifndef __MayaDM_WTADDMATRIX_H__
 
11
#define __MayaDM_WTADDMATRIX_H__
 
12
#include "MayaDMTypes.h"
 
13
#include "MayaDMConnectables.h"
 
14
#include "MayaDMDependNode.h"
 
15
namespace MayaDM
 
16
{
 
17
class WtAddMatrix : public DependNode
 
18
{
 
19
public:
 
20
        struct WtMatrix{
 
21
                matrix matrixIn;
 
22
                double weightIn;
 
23
                void write(FILE* file) const
 
24
                {
 
25
                        matrixIn.write(file);
 
26
                        fprintf(file, " ");
 
27
                        fprintf(file,"%f", weightIn);
 
28
                }
 
29
        };
 
30
public:
 
31
 
 
32
        WtAddMatrix():DependNode(){}
 
33
        WtAddMatrix(FILE* file,const std::string& name,const std::string& parent="",bool shared=false,bool create=true)
 
34
                :DependNode(file, name, parent, "wtAddMatrix", shared, create){}
 
35
        virtual ~WtAddMatrix(){}
 
36
 
 
37
        void setWtMatrix(size_t i_i,const WtMatrix& i_)
 
38
        {
 
39
                fprintf(mFile,"\tsetAttr \".i[%i]\" ",i_i);
 
40
                i_.write(mFile);
 
41
                fprintf(mFile,";\n");
 
42
        }
 
43
        void setWtMatrix(size_t i_start,size_t i_end,WtMatrix* i_)
 
44
        {
 
45
                fprintf(mFile,"\tsetAttr \".i[%i:%i]\" ", i_start,i_end);
 
46
                size_t size = (i_end-i_start)*1+1;
 
47
                for(size_t i=0;i<size;++i)
 
48
                {
 
49
                        i_[i].write(mFile);
 
50
                        fprintf(mFile,"\n");
 
51
                }
 
52
                fprintf(mFile,";\n");
 
53
        }
 
54
        void startWtMatrix(size_t i_start,size_t i_end)const
 
55
        {
 
56
                fprintf(mFile,"\tsetAttr \".i[%i:%i]\"",i_start,i_end);
 
57
                fprintf(mFile," -type \"WtMatrix\" ");
 
58
        }
 
59
        void appendWtMatrix(const WtMatrix& i)const
 
60
        {
 
61
                fprintf(mFile," ");
 
62
                i.write(mFile);
 
63
        }
 
64
        void endWtMatrix()const
 
65
        {
 
66
                fprintf(mFile,";\n");
 
67
        }
 
68
        void setMatrixIn(size_t i_i,const matrix& m)
 
69
        {
 
70
                if(m == identity) return;
 
71
                fprintf(mFile,"\tsetAttr \".i[%i].m\" -type \"matrix\" ",i_i);
 
72
                m.write(mFile);
 
73
                fprintf(mFile,";\n");
 
74
        }
 
75
        void setWeightIn(size_t i_i,double w)
 
76
        {
 
77
                if(w == 0.0) return;
 
78
                fprintf(mFile,"\tsetAttr \".i[%i].w\" %f;\n", i_i,w);
 
79
        }
 
80
        void getWtMatrix(size_t i_i)const
 
81
        {
 
82
                fprintf(mFile,"\"%s.i[%i]\"",mName.c_str(),i_i);
 
83
        }
 
84
        void getWtMatrix()const
 
85
        {
 
86
 
 
87
                fprintf(mFile,"\"%s.i\"",mName.c_str());
 
88
        }
 
89
        void getMatrixIn(size_t i_i)const
 
90
        {
 
91
                fprintf(mFile,"\"%s.i[%i].m\"",mName.c_str(),i_i);
 
92
        }
 
93
        void getMatrixIn()const
 
94
        {
 
95
 
 
96
                fprintf(mFile,"\"%s.i.m\"",mName.c_str());
 
97
        }
 
98
        void getWeightIn(size_t i_i)const
 
99
        {
 
100
                fprintf(mFile,"\"%s.i[%i].w\"",mName.c_str(),i_i);
 
101
        }
 
102
        void getWeightIn()const
 
103
        {
 
104
 
 
105
                fprintf(mFile,"\"%s.i.w\"",mName.c_str());
 
106
        }
 
107
        void getMatrixSum()const
 
108
        {
 
109
                fprintf(mFile,"\"%s.o\"",mName.c_str());
 
110
        }
 
111
protected:
 
112
        WtAddMatrix(FILE* file,const std::string& name,const std::string& parent,const std::string& nodeType,bool shared=false,bool create=true)
 
113
                :DependNode(file, name, parent, nodeType, shared, create) {}
 
114
 
 
115
};
 
116
}//namespace MayaDM
 
117
#endif//__MayaDM_WTADDMATRIX_H__