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

« back to all changes in this revision

Viewing changes to Externals/MayaDataModel/include/MayaDMPolyExtrudeFace.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_POLYEXTRUDEFACE_H__
 
11
#define __MayaDM_POLYEXTRUDEFACE_H__
 
12
#include "MayaDMTypes.h"
 
13
#include "MayaDMConnectables.h"
 
14
#include "MayaDMPolyMoveFace.h"
 
15
namespace MayaDM
 
16
{
 
17
class PolyExtrudeFace : public PolyMoveFace
 
18
{
 
19
public:
 
20
        struct TaperCurve{
 
21
                float taperCurve_Position;
 
22
                float taperCurve_FloatValue;
 
23
                unsigned int taperCurve_Interp;
 
24
                void write(FILE* file) const
 
25
                {
 
26
                        fprintf(file,"%f ", taperCurve_Position);
 
27
                        fprintf(file,"%f ", taperCurve_FloatValue);
 
28
                        fprintf(file,"%i", taperCurve_Interp);
 
29
                }
 
30
        };
 
31
public:
 
32
 
 
33
        PolyExtrudeFace():PolyMoveFace(){}
 
34
        PolyExtrudeFace(FILE* file,const std::string& name,const std::string& parent="",bool shared=false,bool create=true)
 
35
                :PolyMoveFace(file, name, parent, "polyExtrudeFace", shared, create){}
 
36
        virtual ~PolyExtrudeFace(){}
 
37
 
 
38
        void setKeepFacesTogether(bool kft)
 
39
        {
 
40
                if(kft == true) return;
 
41
                fprintf(mFile,"\tsetAttr \".kft\" %i;\n", kft);
 
42
        }
 
43
        void setDivisions(int d)
 
44
        {
 
45
                if(d == 1) return;
 
46
                fprintf(mFile,"\tsetAttr \".d\" %i;\n", d);
 
47
        }
 
48
        void setTwist(double twt)
 
49
        {
 
50
                if(twt == 0) return;
 
51
                fprintf(mFile,"\tsetAttr \".twt\" %f;\n", twt);
 
52
        }
 
53
        void setTaper(double tp)
 
54
        {
 
55
                if(tp == 1.0) return;
 
56
                fprintf(mFile,"\tsetAttr \".tp\" %f;\n", tp);
 
57
        }
 
58
        void setTaperCurve(size_t c_i,const TaperCurve& c)
 
59
        {
 
60
                fprintf(mFile,"\tsetAttr \".c[%i]\" ",c_i);
 
61
                c.write(mFile);
 
62
                fprintf(mFile,";\n");
 
63
        }
 
64
        void setTaperCurve(size_t c_start,size_t c_end,TaperCurve* c)
 
65
        {
 
66
                fprintf(mFile,"\tsetAttr \".c[%i:%i]\" ", c_start,c_end);
 
67
                size_t size = (c_end-c_start)*1+1;
 
68
                for(size_t i=0;i<size;++i)
 
69
                {
 
70
                        c[i].write(mFile);
 
71
                        fprintf(mFile,"\n");
 
72
                }
 
73
                fprintf(mFile,";\n");
 
74
        }
 
75
        void startTaperCurve(size_t c_start,size_t c_end)const
 
76
        {
 
77
                fprintf(mFile,"\tsetAttr \".c[%i:%i]\"",c_start,c_end);
 
78
                fprintf(mFile," -type \"TaperCurve\" ");
 
79
        }
 
80
        void appendTaperCurve(const TaperCurve& c)const
 
81
        {
 
82
                fprintf(mFile," ");
 
83
                c.write(mFile);
 
84
        }
 
85
        void endTaperCurve()const
 
86
        {
 
87
                fprintf(mFile,";\n");
 
88
        }
 
89
        void setTaperCurve_Position(size_t c_i,float cp)
 
90
        {
 
91
                if(cp == 0.0) return;
 
92
                fprintf(mFile,"\tsetAttr \".c[%i].cp\" %f;\n", c_i,cp);
 
93
        }
 
94
        void setTaperCurve_FloatValue(size_t c_i,float cfv)
 
95
        {
 
96
                if(cfv == 0.0) return;
 
97
                fprintf(mFile,"\tsetAttr \".c[%i].cfv\" %f;\n", c_i,cfv);
 
98
        }
 
99
        void setTaperCurve_Interp(size_t c_i,unsigned int ci)
 
100
        {
 
101
                if(ci == 0) return;
 
102
                fprintf(mFile,"\tsetAttr \".c[%i].ci\" %i;\n", c_i,ci);
 
103
        }
 
104
        void setSmoothingAngle(double sma)
 
105
        {
 
106
                if(sma == 3) return;
 
107
                fprintf(mFile,"\tsetAttr \".sma\" %f;\n", sma);
 
108
        }
 
109
        void getKeepFacesTogether()const
 
110
        {
 
111
                fprintf(mFile,"\"%s.kft\"",mName.c_str());
 
112
        }
 
113
        void getDivisions()const
 
114
        {
 
115
                fprintf(mFile,"\"%s.d\"",mName.c_str());
 
116
        }
 
117
        void getInputProfile()const
 
118
        {
 
119
                fprintf(mFile,"\"%s.ipc\"",mName.c_str());
 
120
        }
 
121
        void getTwist()const
 
122
        {
 
123
                fprintf(mFile,"\"%s.twt\"",mName.c_str());
 
124
        }
 
125
        void getTaper()const
 
126
        {
 
127
                fprintf(mFile,"\"%s.tp\"",mName.c_str());
 
128
        }
 
129
        void getTaperCurve(size_t c_i)const
 
130
        {
 
131
                fprintf(mFile,"\"%s.c[%i]\"",mName.c_str(),c_i);
 
132
        }
 
133
        void getTaperCurve()const
 
134
        {
 
135
 
 
136
                fprintf(mFile,"\"%s.c\"",mName.c_str());
 
137
        }
 
138
        void getTaperCurve_Position(size_t c_i)const
 
139
        {
 
140
                fprintf(mFile,"\"%s.c[%i].cp\"",mName.c_str(),c_i);
 
141
        }
 
142
        void getTaperCurve_Position()const
 
143
        {
 
144
 
 
145
                fprintf(mFile,"\"%s.c.cp\"",mName.c_str());
 
146
        }
 
147
        void getTaperCurve_FloatValue(size_t c_i)const
 
148
        {
 
149
                fprintf(mFile,"\"%s.c[%i].cfv\"",mName.c_str(),c_i);
 
150
        }
 
151
        void getTaperCurve_FloatValue()const
 
152
        {
 
153
 
 
154
                fprintf(mFile,"\"%s.c.cfv\"",mName.c_str());
 
155
        }
 
156
        void getTaperCurve_Interp(size_t c_i)const
 
157
        {
 
158
                fprintf(mFile,"\"%s.c[%i].ci\"",mName.c_str(),c_i);
 
159
        }
 
160
        void getTaperCurve_Interp()const
 
161
        {
 
162
 
 
163
                fprintf(mFile,"\"%s.c.ci\"",mName.c_str());
 
164
        }
 
165
        void getSmoothingAngle()const
 
166
        {
 
167
                fprintf(mFile,"\"%s.sma\"",mName.c_str());
 
168
        }
 
169
protected:
 
170
        PolyExtrudeFace(FILE* file,const std::string& name,const std::string& parent,const std::string& nodeType,bool shared=false,bool create=true)
 
171
                :PolyMoveFace(file, name, parent, nodeType, shared, create) {}
 
172
 
 
173
};
 
174
}//namespace MayaDM
 
175
#endif//__MayaDM_POLYEXTRUDEFACE_H__