Revert "Build script: Don't use external Pugi for OSL"
[blender.git] / source / blender / makesdna / DNA_material_types.h
1 /*
2  * This program is free software; you can redistribute it and/or
3  * modify it under the terms of the GNU General Public License
4  * as published by the Free Software Foundation; either version 2
5  * of the License, or (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software Foundation,
14  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15  *
16  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
17  * All rights reserved.
18  */
19
20 /** \file
21  * \ingroup DNA
22  */
23
24 #ifndef __DNA_MATERIAL_TYPES_H__
25 #define __DNA_MATERIAL_TYPES_H__
26
27 #include "DNA_defs.h"
28 #include "DNA_ID.h"
29 #include "DNA_listBase.h"
30
31 #ifndef MAX_MTEX
32 #  define MAX_MTEX 18
33 #endif
34
35 struct AnimData;
36 struct Image;
37 struct Ipo;
38 struct bNodeTree;
39
40 /* WATCH IT: change type? also make changes in ipo.h  */
41
42 typedef struct TexPaintSlot {
43   /** Image to be painted on. */
44   struct Image *ima;
45   /** Customdata index for uv layer, MAX_NAM.E*/
46   char *uvname;
47   /** Do we have a valid image and UV map. */
48   int valid;
49   /** Copy of node inteporlation setting. */
50   int interp;
51 } TexPaintSlot;
52
53 typedef struct MaterialGPencilStyle {
54   /** Texture image for strokes. */
55   struct Image *sima;
56   /** Texture image for filling. */
57   struct Image *ima;
58   /** Color for paint and strokes (alpha included). */
59   float stroke_rgba[4];
60   /** Color that should be used for drawing "fills" for strokes (alpha included). */
61   float fill_rgba[4];
62   /** Secondary color used for gradients and other stuff. */
63   float mix_rgba[4];
64   /** Settings. */
65   short flag;
66   /** Custom index for passes. */
67   short index;
68   /** Style for drawing strokes (used to select shader type). */
69   short stroke_style;
70   /** Style for filling areas (used to select shader type). */
71   short fill_style;
72   /** Factor used to define shader behavior (several uses). */
73   float mix_factor;
74   /** Angle used for gradients orientation. */
75   float gradient_angle;
76   /** Radius for radial gradients. */
77   float gradient_radius;
78   /** Cheesboard size. */
79   float pattern_gridsize;
80   /** Uv coordinates scale. */
81   float gradient_scale[2];
82   /** Factor to shift filling in 2d space. */
83   float gradient_shift[2];
84   /** Angle used for texture orientation. */
85   float texture_angle;
86   /** Texture scale (separated of uv scale). */
87   float texture_scale[2];
88   /** Factor to shift texture in 2d space. */
89   float texture_offset[2];
90   /** Texture opacity. */
91   float texture_opacity;
92   /** Pixel size for uv along the stroke. */
93   float texture_pixsize;
94   /** Drawing mode (line or dots). */
95   int mode;
96
97   /** Type of gradient. */
98   int gradient_type;
99
100   /** Factor used to mix texture and stroke color. */
101   float mix_stroke_factor;
102   /** Mode used to align Dots and Boxes with stroke drawing path and object rotation */
103   int alignment_mode;
104   char _pad[4];
105 } MaterialGPencilStyle;
106
107 /* MaterialGPencilStyle->flag */
108 typedef enum eMaterialGPencilStyle_Flag {
109   /* Fill Texture is a pattern */
110   GP_STYLE_FILL_PATTERN = (1 << 0),
111   /* don't display color */
112   GP_STYLE_COLOR_HIDE = (1 << 1),
113   /* protected from further editing */
114   GP_STYLE_COLOR_LOCKED = (1 << 2),
115   /* do onion skinning */
116   GP_STYLE_COLOR_ONIONSKIN = (1 << 3),
117   /* clamp texture */
118   GP_STYLE_COLOR_TEX_CLAMP = (1 << 4),
119   /* mix fill texture */
120   GP_STYLE_FILL_TEX_MIX = (1 << 5),
121   /* Flip fill colors */
122   GP_STYLE_COLOR_FLIP_FILL = (1 << 6),
123   /* Stroke Texture is a pattern */
124   GP_STYLE_STROKE_PATTERN = (1 << 7),
125   /* Stroke show main switch */
126   GP_STYLE_STROKE_SHOW = (1 << 8),
127   /* Fill  show main switch */
128   GP_STYLE_FILL_SHOW = (1 << 9),
129   /* mix stroke texture */
130   GP_STYLE_STROKE_TEX_MIX = (1 << 11),
131 } eMaterialGPencilStyle_Flag;
132
133 typedef enum eMaterialGPencilStyle_Mode {
134   GP_STYLE_MODE_LINE = 0, /* line */
135   GP_STYLE_MODE_DOTS = 1, /* dots */
136   GP_STYLE_MODE_BOX = 2,  /* rectangles */
137 } eMaterialGPencilStyle_Mode;
138
139 typedef struct Material {
140   ID id;
141   /** Animation data (must be immediately after id for utilities to use it). */
142   struct AnimData *adt;
143
144   short flag;
145   char _pad1[2];
146
147   /* Colors from Blender Internal that we are still using. */
148   float r, g, b, a;
149   float specr, specg, specb;
150   float alpha DNA_DEPRECATED;
151   float ray_mirror DNA_DEPRECATED;
152   float spec;
153   /** Renamed and inversed to roughness. */
154   float gloss_mir DNA_DEPRECATED;
155   float roughness;
156   float metallic;
157
158   /** Nodes */
159   char use_nodes;
160
161   /** Preview render. */
162   char pr_type;
163   short pr_texture;
164   short pr_flag;
165
166   /** Index for render passes. */
167   short index;
168
169   struct bNodeTree *nodetree;
170   /** Old animation system, deprecated for 2.5. */
171   struct Ipo *ipo DNA_DEPRECATED;
172   struct PreviewImage *preview;
173
174   /* Freestyle line settings. */
175   float line_col[4];
176   short line_priority;
177   short vcol_alpha;
178
179   /* Texture painting slots. */
180   short paint_active_slot;
181   short paint_clone_slot;
182   short tot_slots;
183   char _pad2[2];
184
185   /* Transparency. */
186   float alpha_threshold;
187   float refract_depth;
188   char blend_method;
189   char blend_shadow;
190   char blend_flag;
191   char _pad3[1];
192
193   /**
194    * Cached slots for texture painting, must be refreshed in
195    * refresh_texpaint_image_cache before using.
196    */
197   struct TexPaintSlot *texpaintslot;
198
199   /** Runtime cache for GLSL materials. */
200   ListBase gpumaterial;
201
202   /** Grease pencil color. */
203   struct MaterialGPencilStyle *gp_style;
204 } Material;
205
206 /* **************** MATERIAL ********************* */
207
208 /* maximum number of materials per material array.
209  * (on object, mesh, light, etc.). limited by
210  * short mat_nr in verts, faces.
211  * -1 because for active material we store the index + 1 */
212 #define MAXMAT (32767 - 1)
213
214 /* flag */
215 /* for render */
216 /* #define MA_IS_USED      (1 << 0) */ /* UNUSED */
217                                        /* for dopesheet */
218 #define MA_DS_EXPAND (1 << 1)
219 /* for dopesheet (texture stack expander)
220  * NOTE: this must have the same value as other texture stacks,
221  * otherwise anim-editors will not read correctly
222  */
223 #define MA_DS_SHOW_TEXS (1 << 2)
224
225 /* ramps */
226 #define MA_RAMP_BLEND 0
227 #define MA_RAMP_ADD 1
228 #define MA_RAMP_MULT 2
229 #define MA_RAMP_SUB 3
230 #define MA_RAMP_SCREEN 4
231 #define MA_RAMP_DIV 5
232 #define MA_RAMP_DIFF 6
233 #define MA_RAMP_DARK 7
234 #define MA_RAMP_LIGHT 8
235 #define MA_RAMP_OVERLAY 9
236 #define MA_RAMP_DODGE 10
237 #define MA_RAMP_BURN 11
238 #define MA_RAMP_HUE 12
239 #define MA_RAMP_SAT 13
240 #define MA_RAMP_VAL 14
241 #define MA_RAMP_COLOR 15
242 #define MA_RAMP_SOFT 16
243 #define MA_RAMP_LINEAR 17
244
245 /* texco */
246 #define TEXCO_ORCO (1 << 0)
247 /* #define TEXCO_REFL      (1 << 1) */ /* deprecated */
248 /* #define TEXCO_NORM      (1 << 2) */ /* deprecated */
249 #define TEXCO_GLOB (1 << 3)
250 #define TEXCO_UV (1 << 4)
251 #define TEXCO_OBJECT (1 << 5)
252 /* #define TEXCO_LAVECTOR  (1 << 6) */ /* deprecated */
253 /* #define TEXCO_VIEW      (1 << 7) */ /* deprecated */
254 /* #define TEXCO_STICKY   (1 << 8) */  /* deprecated */
255 /* #define TEXCO_OSA       (1 << 9) */ /* deprecated */
256 #define TEXCO_WINDOW (1 << 10)
257 /* #define NEED_UV         (1 << 11) */ /* deprecated */
258 /* #define TEXCO_TANGENT   (1 << 12) */ /* deprecated */
259 /* still stored in vertex->accum, 1 D */
260 #define TEXCO_STRAND (1 << 13)
261 /** strand is used for normal materials, particle for halo materials */
262 #define TEXCO_PARTICLE (1 << 13)
263 /* #define TEXCO_STRESS    (1 << 14) */ /* deprecated */
264 /* #define TEXCO_SPEED     (1 << 15) */ /* deprecated */
265
266 /* mapto */
267 #define MAP_COL (1 << 0)
268 #define MAP_ALPHA (1 << 7)
269
270 /* pmapto */
271 /* init */
272 #define MAP_PA_INIT ((1 << 5) - 1)
273 #define MAP_PA_TIME (1 << 0)
274 #define MAP_PA_LIFE (1 << 1)
275 #define MAP_PA_DENS (1 << 2)
276 #define MAP_PA_SIZE (1 << 3)
277 #define MAP_PA_LENGTH (1 << 4)
278 /* reset */
279 #define MAP_PA_IVEL (1 << 5)
280 /* physics */
281 #define MAP_PA_PVEL (1 << 6)
282 /* path cache */
283 #define MAP_PA_CLUMP (1 << 7)
284 #define MAP_PA_KINK (1 << 8)
285 #define MAP_PA_ROUGH (1 << 9)
286 #define MAP_PA_FREQ (1 << 10)
287
288 /* pr_type */
289 #define MA_FLAT 0
290 #define MA_SPHERE 1
291 #define MA_CUBE 2
292 #define MA_SHADERBALL 3
293 #define MA_SPHERE_A 4 /* Used for icon renders only. */
294 #define MA_TEXTURE 5
295 #define MA_LAMP 6
296 #define MA_SKY 7
297 #define MA_HAIR 10
298 #define MA_ATMOS 11
299 #define MA_CLOTH 12
300 #define MA_FLUID 13
301
302 /* pr_flag */
303 #define MA_PREVIEW_WORLD (1 << 0)
304
305 /* blend_method */
306 enum {
307   MA_BM_SOLID,
308   MA_BM_ADD,
309   MA_BM_MULTIPLY,
310   MA_BM_CLIP,
311   MA_BM_HASHED,
312   MA_BM_BLEND,
313 };
314
315 /* blend_flag */
316 enum {
317   MA_BL_HIDE_BACKFACE = (1 << 0),
318   MA_BL_SS_REFRACTION = (1 << 1),
319   MA_BL_CULL_BACKFACE = (1 << 2),
320   MA_BL_TRANSLUCENCY = (1 << 3),
321 };
322
323 /* blend_shadow */
324 enum {
325   MA_BS_NONE = 0,
326   MA_BS_SOLID,
327   MA_BS_CLIP,
328   MA_BS_HASHED,
329 };
330
331 /* Grease Pencil Stroke styles */
332 enum {
333   GP_STYLE_STROKE_STYLE_SOLID = 0,
334   GP_STYLE_STROKE_STYLE_TEXTURE,
335 };
336
337 /* Grease Pencil Fill styles */
338 enum {
339   GP_STYLE_FILL_STYLE_SOLID = 0,
340   GP_STYLE_FILL_STYLE_GRADIENT,
341   GP_STYLE_FILL_STYLE_CHESSBOARD,
342   GP_STYLE_FILL_STYLE_TEXTURE,
343 };
344
345 /* Grease Pencil Gradient Types */
346 enum {
347   GP_STYLE_GRADIENT_LINEAR = 0,
348   GP_STYLE_GRADIENT_RADIAL,
349 };
350
351 /* Grease Pencil Follow Drawing Modes */
352 enum {
353   GP_STYLE_FOLLOW_PATH = 0,
354   GP_STYLE_FOLLOW_OBJ,
355   GP_STYLE_FOLLOW_FIXED,
356 };
357 #endif