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

« back to all changes in this revision

Viewing changes to Externals/MayaDataModel/include/MayaDMLayeredTexture.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_LAYEREDTEXTURE_H__
 
11
#define __MayaDM_LAYEREDTEXTURE_H__
 
12
#include "MayaDMTypes.h"
 
13
#include "MayaDMConnectables.h"
 
14
#include "MayaDMDependNode.h"
 
15
namespace MayaDM
 
16
{
 
17
class LayeredTexture : public DependNode
 
18
{
 
19
public:
 
20
        struct Inputs{
 
21
                float3 color;
 
22
                float alpha;
 
23
                unsigned int blendMode;
 
24
                bool isVisible;
 
25
                void write(FILE* file) const
 
26
                {
 
27
                        color.write(file);
 
28
                        fprintf(file, " ");
 
29
                        fprintf(file,"%f ", alpha);
 
30
                        fprintf(file,"%i ", blendMode);
 
31
                        fprintf(file,"%i", isVisible);
 
32
                }
 
33
        };
 
34
public:
 
35
 
 
36
        LayeredTexture():DependNode(){}
 
37
        LayeredTexture(FILE* file,const std::string& name,const std::string& parent="",bool shared=false,bool create=true)
 
38
                :DependNode(file, name, parent, "layeredTexture", shared, create){}
 
39
        virtual ~LayeredTexture(){}
 
40
 
 
41
        void setInputs(size_t cs_i,const Inputs& cs)
 
42
        {
 
43
                fprintf(mFile,"\tsetAttr \".cs[%i]\" ",cs_i);
 
44
                cs.write(mFile);
 
45
                fprintf(mFile,";\n");
 
46
        }
 
47
        void setInputs(size_t cs_start,size_t cs_end,Inputs* cs)
 
48
        {
 
49
                fprintf(mFile,"\tsetAttr \".cs[%i:%i]\" ", cs_start,cs_end);
 
50
                size_t size = (cs_end-cs_start)*1+1;
 
51
                for(size_t i=0;i<size;++i)
 
52
                {
 
53
                        cs[i].write(mFile);
 
54
                        fprintf(mFile,"\n");
 
55
                }
 
56
                fprintf(mFile,";\n");
 
57
        }
 
58
        void startInputs(size_t cs_start,size_t cs_end)const
 
59
        {
 
60
                fprintf(mFile,"\tsetAttr \".cs[%i:%i]\"",cs_start,cs_end);
 
61
                fprintf(mFile," -type \"Inputs\" ");
 
62
        }
 
63
        void appendInputs(const Inputs& cs)const
 
64
        {
 
65
                fprintf(mFile," ");
 
66
                cs.write(mFile);
 
67
        }
 
68
        void endInputs()const
 
69
        {
 
70
                fprintf(mFile,";\n");
 
71
        }
 
72
        void setColor(size_t cs_i,const float3& c)
 
73
        {
 
74
                fprintf(mFile,"\tsetAttr \".cs[%i].c\" -type \"float3\" ",cs_i);
 
75
                c.write(mFile);
 
76
                fprintf(mFile,";\n");
 
77
        }
 
78
        void setColorR(size_t cs_i,float cr)
 
79
        {
 
80
                if(cr == 0.0) return;
 
81
                fprintf(mFile,"\tsetAttr \".cs[%i].c.cr\" %f;\n", cs_i,cr);
 
82
        }
 
83
        void setColorG(size_t cs_i,float cg)
 
84
        {
 
85
                if(cg == 0.0) return;
 
86
                fprintf(mFile,"\tsetAttr \".cs[%i].c.cg\" %f;\n", cs_i,cg);
 
87
        }
 
88
        void setColorB(size_t cs_i,float cb)
 
89
        {
 
90
                if(cb == 0.0) return;
 
91
                fprintf(mFile,"\tsetAttr \".cs[%i].c.cb\" %f;\n", cs_i,cb);
 
92
        }
 
93
        void setAlpha(size_t cs_i,float a)
 
94
        {
 
95
                if(a == 1.0) return;
 
96
                fprintf(mFile,"\tsetAttr \".cs[%i].a\" %f;\n", cs_i,a);
 
97
        }
 
98
        void setBlendMode(size_t cs_i,unsigned int bm)
 
99
        {
 
100
                if(bm == 1) return;
 
101
                fprintf(mFile,"\tsetAttr \".cs[%i].bm\" %i;\n", cs_i,bm);
 
102
        }
 
103
        void setIsVisible(size_t cs_i,bool iv)
 
104
        {
 
105
                if(iv == true) return;
 
106
                fprintf(mFile,"\tsetAttr \".cs[%i].iv\" %i;\n", cs_i,iv);
 
107
        }
 
108
        void setHardwareColor(const float3& hc)
 
109
        {
 
110
                fprintf(mFile,"\tsetAttr \".hc\" -type \"float3\" ");
 
111
                hc.write(mFile);
 
112
                fprintf(mFile,";\n");
 
113
        }
 
114
        void setHardwareColorR(float hcr)
 
115
        {
 
116
                if(hcr == 0.5) return;
 
117
                fprintf(mFile,"\tsetAttr \".hc.hcr\" %f;\n", hcr);
 
118
        }
 
119
        void setHardwareColorG(float hcg)
 
120
        {
 
121
                if(hcg == 0.5) return;
 
122
                fprintf(mFile,"\tsetAttr \".hc.hcg\" %f;\n", hcg);
 
123
        }
 
124
        void setHardwareColorB(float hcb)
 
125
        {
 
126
                if(hcb == 0.5) return;
 
127
                fprintf(mFile,"\tsetAttr \".hc.hcb\" %f;\n", hcb);
 
128
        }
 
129
        void setAlphaIsLuminance(bool ail)
 
130
        {
 
131
                if(ail == false) return;
 
132
                fprintf(mFile,"\tsetAttr \".ail\" %i;\n", ail);
 
133
        }
 
134
        void getInputs(size_t cs_i)const
 
135
        {
 
136
                fprintf(mFile,"\"%s.cs[%i]\"",mName.c_str(),cs_i);
 
137
        }
 
138
        void getInputs()const
 
139
        {
 
140
 
 
141
                fprintf(mFile,"\"%s.cs\"",mName.c_str());
 
142
        }
 
143
        void getColor(size_t cs_i)const
 
144
        {
 
145
                fprintf(mFile,"\"%s.cs[%i].c\"",mName.c_str(),cs_i);
 
146
        }
 
147
        void getColor()const
 
148
        {
 
149
 
 
150
                fprintf(mFile,"\"%s.cs.c\"",mName.c_str());
 
151
        }
 
152
        void getColorR(size_t cs_i)const
 
153
        {
 
154
                fprintf(mFile,"\"%s.cs[%i].c.cr\"",mName.c_str(),cs_i);
 
155
        }
 
156
        void getColorR()const
 
157
        {
 
158
 
 
159
                fprintf(mFile,"\"%s.cs.c.cr\"",mName.c_str());
 
160
        }
 
161
        void getColorG(size_t cs_i)const
 
162
        {
 
163
                fprintf(mFile,"\"%s.cs[%i].c.cg\"",mName.c_str(),cs_i);
 
164
        }
 
165
        void getColorG()const
 
166
        {
 
167
 
 
168
                fprintf(mFile,"\"%s.cs.c.cg\"",mName.c_str());
 
169
        }
 
170
        void getColorB(size_t cs_i)const
 
171
        {
 
172
                fprintf(mFile,"\"%s.cs[%i].c.cb\"",mName.c_str(),cs_i);
 
173
        }
 
174
        void getColorB()const
 
175
        {
 
176
 
 
177
                fprintf(mFile,"\"%s.cs.c.cb\"",mName.c_str());
 
178
        }
 
179
        void getAlpha(size_t cs_i)const
 
180
        {
 
181
                fprintf(mFile,"\"%s.cs[%i].a\"",mName.c_str(),cs_i);
 
182
        }
 
183
        void getAlpha()const
 
184
        {
 
185
 
 
186
                fprintf(mFile,"\"%s.cs.a\"",mName.c_str());
 
187
        }
 
188
        void getBlendMode(size_t cs_i)const
 
189
        {
 
190
                fprintf(mFile,"\"%s.cs[%i].bm\"",mName.c_str(),cs_i);
 
191
        }
 
192
        void getBlendMode()const
 
193
        {
 
194
 
 
195
                fprintf(mFile,"\"%s.cs.bm\"",mName.c_str());
 
196
        }
 
197
        void getIsVisible(size_t cs_i)const
 
198
        {
 
199
                fprintf(mFile,"\"%s.cs[%i].iv\"",mName.c_str(),cs_i);
 
200
        }
 
201
        void getIsVisible()const
 
202
        {
 
203
 
 
204
                fprintf(mFile,"\"%s.cs.iv\"",mName.c_str());
 
205
        }
 
206
        void getOutColor()const
 
207
        {
 
208
                fprintf(mFile,"\"%s.oc\"",mName.c_str());
 
209
        }
 
210
        void getOutColorR()const
 
211
        {
 
212
                fprintf(mFile,"\"%s.oc.ocr\"",mName.c_str());
 
213
        }
 
214
        void getOutColorG()const
 
215
        {
 
216
                fprintf(mFile,"\"%s.oc.ocg\"",mName.c_str());
 
217
        }
 
218
        void getOutColorB()const
 
219
        {
 
220
                fprintf(mFile,"\"%s.oc.ocb\"",mName.c_str());
 
221
        }
 
222
        void getOutAlpha()const
 
223
        {
 
224
                fprintf(mFile,"\"%s.oa\"",mName.c_str());
 
225
        }
 
226
        void getAlphaIsLuminance()const
 
227
        {
 
228
                fprintf(mFile,"\"%s.ail\"",mName.c_str());
 
229
        }
 
230
        void getOutTransparency()const
 
231
        {
 
232
                fprintf(mFile,"\"%s.ot\"",mName.c_str());
 
233
        }
 
234
        void getOutTransparencyR()const
 
235
        {
 
236
                fprintf(mFile,"\"%s.ot.otr\"",mName.c_str());
 
237
        }
 
238
        void getOutTransparencyG()const
 
239
        {
 
240
                fprintf(mFile,"\"%s.ot.otg\"",mName.c_str());
 
241
        }
 
242
        void getOutTransparencyB()const
 
243
        {
 
244
                fprintf(mFile,"\"%s.ot.otb\"",mName.c_str());
 
245
        }
 
246
protected:
 
247
        LayeredTexture(FILE* file,const std::string& name,const std::string& parent,const std::string& nodeType,bool shared=false,bool create=true)
 
248
                :DependNode(file, name, parent, nodeType, shared, create) {}
 
249
 
 
250
};
 
251
}//namespace MayaDM
 
252
#endif//__MayaDM_LAYEREDTEXTURE_H__