Fix #32930: texture colors in material nodes (blender internal) are brighter than...
[blender-staging.git] / source / blender / makesrna / intern / rna_color.c
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * Contributor(s): Blender Foundation (2008).
19  *
20  * ***** END GPL LICENSE BLOCK *****
21  */
22
23 /** \file blender/makesrna/intern/rna_color.c
24  *  \ingroup RNA
25  */
26
27
28 #include <stdlib.h>
29 #include <stdio.h>
30
31 #include "RNA_define.h"
32 #include "rna_internal.h"
33
34 #include "DNA_color_types.h"
35 #include "DNA_texture_types.h"
36
37 #include "WM_api.h"
38 #include "WM_types.h"
39
40 #ifdef RNA_RUNTIME
41
42 #include "RNA_access.h"
43
44 #include "DNA_image_types.h"
45 #include "DNA_material_types.h"
46 #include "DNA_movieclip_types.h"
47 #include "DNA_node_types.h"
48
49 #include "MEM_guardedalloc.h"
50
51 #include "BKE_colortools.h"
52 #include "BKE_depsgraph.h"
53 #include "BKE_image.h"
54 #include "BKE_movieclip.h"
55 #include "BKE_node.h"
56 #include "BKE_texture.h"
57
58 #include "ED_node.h"
59
60 #include "IMB_colormanagement.h"
61
62 static int rna_CurveMapping_curves_length(PointerRNA *ptr)
63 {
64         CurveMapping *cumap = (CurveMapping *)ptr->data;
65         int len;
66
67         for (len = 0; len < CM_TOT; len++)
68                 if (!cumap->cm[len].curve)
69                         break;
70         
71         return len;
72 }
73
74 static void rna_CurveMapping_curves_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
75 {
76         CurveMapping *cumap = (CurveMapping *)ptr->data;
77
78         rna_iterator_array_begin(iter, cumap->cm, sizeof(CurveMap), rna_CurveMapping_curves_length(ptr), 0, NULL);
79 }
80
81 static void rna_CurveMapping_clip_set(PointerRNA *ptr, int value)
82 {
83         CurveMapping *cumap = (CurveMapping *)ptr->data;
84
85         if (value) cumap->flag |= CUMA_DO_CLIP;
86         else cumap->flag &= ~CUMA_DO_CLIP;
87
88         curvemapping_changed(cumap, FALSE);
89 }
90
91 static void rna_CurveMapping_black_level_set(PointerRNA *ptr, const float *values)
92 {
93         CurveMapping *cumap = (CurveMapping *)ptr->data;
94         cumap->black[0] = values[0];
95         cumap->black[1] = values[1];
96         cumap->black[2] = values[2];
97         curvemapping_set_black_white(cumap, NULL, NULL);
98 }
99
100 static void rna_CurveMapping_white_level_set(PointerRNA *ptr, const float *values)
101 {
102         CurveMapping *cumap = (CurveMapping *)ptr->data;
103         cumap->white[0] = values[0];
104         cumap->white[1] = values[1];
105         cumap->white[2] = values[2];
106         curvemapping_set_black_white(cumap, NULL, NULL);
107 }
108
109 static void rna_CurveMapping_clipminx_range(PointerRNA *ptr, float *min, float *max, float *softmin, float *softmax)
110 {
111         CurveMapping *cumap = (CurveMapping *)ptr->data;
112
113         *min = -100.0f;
114         *max = cumap->clipr.xmax;
115 }
116
117 static void rna_CurveMapping_clipminy_range(PointerRNA *ptr, float *min, float *max, float *softmin, float *softmax)
118 {
119         CurveMapping *cumap = (CurveMapping *)ptr->data;
120
121         *min = -100.0f;
122         *max = cumap->clipr.ymax;
123 }
124
125 static void rna_CurveMapping_clipmaxx_range(PointerRNA *ptr, float *min, float *max, float *softmin, float *softmax)
126 {
127         CurveMapping *cumap = (CurveMapping *)ptr->data;
128
129         *min = cumap->clipr.xmin;
130         *max = 100.0f;
131 }
132
133 static void rna_CurveMapping_clipmaxy_range(PointerRNA *ptr, float *min, float *max, float *softmin, float *softmax)
134 {
135         CurveMapping *cumap = (CurveMapping *)ptr->data;
136
137         *min = cumap->clipr.ymin;
138         *max = 100.0f;
139 }
140
141
142 static char *rna_ColorRamp_path(PointerRNA *ptr)
143 {
144         char *path = NULL;
145         
146         /* handle the cases where a single datablock may have 2 ramp types */
147         if (ptr->id.data) {
148                 ID *id = ptr->id.data;
149                 
150                 switch (GS(id->name)) {
151                         case ID_MA: /* material has 2 cases - diffuse and specular */
152                         {
153                                 Material *ma = (Material *)id;
154                                 
155                                 if (ptr->data == ma->ramp_col)
156                                         path = BLI_strdup("diffuse_ramp");
157                                 else if (ptr->data == ma->ramp_spec)
158                                         path = BLI_strdup("specular_ramp");
159                                 break;
160                         }
161                         
162                         case ID_NT:
163                         {
164                                 bNodeTree *ntree = (bNodeTree *)id;
165                                 bNode *node;
166                                 PointerRNA node_ptr;
167                                 char *node_path;
168                                 
169                                 for (node = ntree->nodes.first; node; node = node->next) {
170                                         if (ELEM3(node->type, SH_NODE_VALTORGB, CMP_NODE_VALTORGB, TEX_NODE_VALTORGB)) {
171                                                 if (node->storage == ptr->data) {
172                                                         /* all node color ramp properties called 'color_ramp'
173                                                          * prepend path from ID to the node
174                                                          */
175                                                         RNA_pointer_create(id, &RNA_Node, node, &node_ptr);
176                                                         node_path = RNA_path_from_ID_to_struct(&node_ptr);
177                                                         path = BLI_sprintfN("%s.color_ramp", node_path);
178                                                         MEM_freeN(node_path);
179                                                 }
180                                         }
181                                 }
182                                 break;
183                         }
184                         
185                         default:
186                                 /* everything else just uses 'color_ramp' */
187                                 path = BLI_strdup("color_ramp");
188                                 break;
189                 }
190         }
191         else {
192                 /* everything else just uses 'color_ramp' */
193                 path = BLI_strdup("color_ramp");
194         }
195         
196         return path;
197 }
198
199 static char *rna_ColorRampElement_path(PointerRNA *ptr)
200 {
201         PointerRNA ramp_ptr;
202         PropertyRNA *prop;
203         char *path = NULL;
204         int index;
205         
206         /* helper macro for use here to try and get the path
207          *      - this calls the standard code for getting a path to a texture...
208          */
209
210 #define COLRAMP_GETPATH                                                       \
211 {                                                                             \
212         prop = RNA_struct_find_property(&ramp_ptr, "elements");                   \
213         if (prop) {                                                               \
214                 index = RNA_property_collection_lookup_index(&ramp_ptr, prop, ptr);   \
215                 if (index >= 0) {                                                     \
216                         char *texture_path = rna_ColorRamp_path(&ramp_ptr);               \
217                         path = BLI_sprintfN("%s.elements[%d]", texture_path, index);      \
218                         MEM_freeN(texture_path);                                          \
219                 }                                                                     \
220         }                                                                         \
221 } (void)0
222
223         /* determine the path from the ID-block to the ramp */
224         /* FIXME: this is a very slow way to do it, but it will have to suffice... */
225         if (ptr->id.data) {
226                 ID *id = ptr->id.data;
227                 
228                 switch (GS(id->name)) {
229                         case ID_MA: /* 2 cases for material - diffuse and spec */
230                         {
231                                 Material *ma = (Material *)id;
232                                 
233                                 /* try diffuse first */
234                                 if (ma->ramp_col) {
235                                         RNA_pointer_create(id, &RNA_ColorRamp, ma->ramp_col, &ramp_ptr);
236                                         COLRAMP_GETPATH;
237                                 }
238                                 /* try specular if not diffuse */
239                                 if (!path && ma->ramp_spec) {
240                                         RNA_pointer_create(id, &RNA_ColorRamp, ma->ramp_spec, &ramp_ptr);
241                                         COLRAMP_GETPATH;
242                                 }
243                         }
244                         break;
245                                 
246                         case ID_NT:
247                         {
248                                 bNodeTree *ntree = (bNodeTree *)id;
249                                 bNode *node;
250                                 
251                                 for (node = ntree->nodes.first; node; node = node->next) {
252                                         if (ELEM3(node->type, SH_NODE_VALTORGB, CMP_NODE_VALTORGB, TEX_NODE_VALTORGB)) {
253                                                 RNA_pointer_create(id, &RNA_ColorRamp, node->storage, &ramp_ptr);
254                                                 COLRAMP_GETPATH;
255                                         }
256                                 }
257                         }
258                         break;
259                                 
260                         default: /* everything else should have a "color_ramp" property */
261                         {
262                                 /* create pointer to the ID block, and try to resolve "color_ramp" pointer */
263                                 RNA_id_pointer_create(id, &ramp_ptr);
264                                 if (RNA_path_resolve(&ramp_ptr, "color_ramp", &ramp_ptr, &prop)) {
265                                         COLRAMP_GETPATH;
266                                 }
267                         }
268                 }
269         }
270         
271         /* cleanup the macro we defined */
272 #undef COLRAMP_GETPATH
273         
274         return path;
275 }
276
277 static void rna_ColorRamp_update(Main *bmain, Scene *UNUSED(scene), PointerRNA *ptr)
278 {
279         if (ptr->id.data) {
280                 ID *id = ptr->id.data;
281                 
282                 switch (GS(id->name)) {
283                         case ID_MA:
284                         {
285                                 Material *ma = ptr->id.data;
286                                 
287                                 DAG_id_tag_update(&ma->id, 0);
288                                 WM_main_add_notifier(NC_MATERIAL | ND_SHADING_DRAW, ma);
289                         }
290                         break;
291                         case ID_NT:
292                         {
293                                 bNodeTree *ntree = (bNodeTree *)id;
294                                 bNode *node;
295
296                                 for (node = ntree->nodes.first; node; node = node->next) {
297                                         if (ELEM3(node->type, SH_NODE_VALTORGB, CMP_NODE_VALTORGB, TEX_NODE_VALTORGB)) {
298                                                 ED_node_generic_update(bmain, ntree, node);
299                                         }
300                                 }
301                         }
302                         break;
303                         case ID_TE:
304                         {
305                                 Tex *tex = ptr->id.data;
306
307                                 DAG_id_tag_update(&tex->id, 0);
308                                 WM_main_add_notifier(NC_TEXTURE, tex);
309                         }
310                         break;
311                         default:
312                                 break;
313                 }
314         }
315 }
316
317 void rna_ColorRamp_eval(struct ColorBand *coba, float position, float color[4])
318 {
319         do_colorband(coba, position, color);
320 }
321
322 static CBData *rna_ColorRampElement_new(struct ColorBand *coba, ReportList *reports, float position)
323 {
324         CBData *element = colorband_element_add(coba, position);
325
326         if (element == NULL)
327                 BKE_reportf(reports, RPT_ERROR, "Unable to add element to colorband (limit %d)", MAXCOLORBAND);
328
329         return element;
330 }
331
332 static void rna_ColorRampElement_remove(struct ColorBand *coba, ReportList *reports, CBData *element)
333 {
334         int index = (int)(element - coba->data);
335         if (colorband_element_remove(coba, index) == 0)
336                 BKE_report(reports, RPT_ERROR, "Element not found in element collection or last element");
337
338 }
339
340 static void rna_Scopes_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
341 {
342         Scopes *s = (Scopes *)ptr->data;
343         s->ok = 0;
344 }
345
346 static int rna_ColorManagedDisplaySettings_display_device_get(struct PointerRNA *ptr)
347 {
348         ColorManagedDisplaySettings *display = (ColorManagedDisplaySettings *) ptr->data;
349
350         return IMB_colormanagement_display_get_named_index(display->display_device);
351 }
352
353 static void rna_ColorManagedDisplaySettings_display_device_set(struct PointerRNA *ptr, int value)
354 {
355         ColorManagedDisplaySettings *display = (ColorManagedDisplaySettings *) ptr->data;
356         const char *name = IMB_colormanagement_display_get_indexed_name(value);
357
358         if (name) {
359                 BLI_strncpy(display->display_device, name, sizeof(display->display_device));
360         }
361 }
362
363 static EnumPropertyItem *rna_ColorManagedDisplaySettings_display_device_itemf(bContext *C, PointerRNA *ptr, PropertyRNA *UNUSED(prop), int *free)
364 {
365         EnumPropertyItem *items = NULL;
366         int totitem = 0;
367
368         IMB_colormanagement_display_items_add(&items, &totitem);
369         RNA_enum_item_end(&items, &totitem);
370
371         *free = TRUE;
372
373         return items;
374 }
375
376 static void rna_ColorManagedDisplaySettings_display_device_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
377 {
378         ID *id = ptr->id.data;
379
380         if (!id)
381                 return;
382
383         if (GS(id->name) == ID_SCE) {
384                 Scene *scene = (Scene *) id;
385
386                 IMB_colormanagement_validate_settings(&scene->display_settings, &scene->view_settings);
387
388                 WM_main_add_notifier(NC_SCENE | ND_SEQUENCER, NULL);
389         }
390 }
391
392 static int rna_ColorManagedViewSettings_view_transform_get(PointerRNA *ptr)
393 {
394         ColorManagedViewSettings *view = (ColorManagedViewSettings *) ptr->data;
395
396         return IMB_colormanagement_view_get_named_index(view->view_transform);
397 }
398
399 static void rna_ColorManagedViewSettings_view_transform_set(PointerRNA *ptr, int value)
400 {
401         ColorManagedViewSettings *view = (ColorManagedViewSettings *) ptr->data;
402
403         const char *name = IMB_colormanagement_view_get_indexed_name(value);
404
405         if (name) {
406                 BLI_strncpy(view->view_transform, name, sizeof(view->view_transform));
407         }
408 }
409
410 static EnumPropertyItem* rna_ColorManagedViewSettings_view_transform_itemf(bContext *C, PointerRNA *ptr, PropertyRNA *UNUSED(prop), int *free)
411 {
412         Scene *scene = CTX_data_scene(C);
413         EnumPropertyItem *items = NULL;
414         ColorManagedDisplaySettings *display_settings = &scene->display_settings;
415         int totitem = 0;
416
417         IMB_colormanagement_view_items_add(&items, &totitem, display_settings->display_device);
418         RNA_enum_item_end(&items, &totitem);
419
420         *free = TRUE;
421         return items;
422 }
423
424 static void rna_ColorManagedViewSettings_use_curves_set(PointerRNA *ptr, int value)
425 {
426         ColorManagedViewSettings *view_settings = (ColorManagedViewSettings *) ptr->data;
427
428         if (value) {
429                 view_settings->flag |= COLORMANAGE_VIEW_USE_CURVES;
430
431                 if (view_settings->curve_mapping == NULL) {
432                         view_settings->curve_mapping = curvemapping_add(4, 0.0f, 0.0f, 1.0f, 1.0f);
433                 }
434         }
435         else {
436                 view_settings->flag &= ~COLORMANAGE_VIEW_USE_CURVES;
437         }
438 }
439
440 static int rna_ColorManagedColorspaceSettings_colorspace_get(struct PointerRNA *ptr)
441 {
442         ColorManagedColorspaceSettings *colorspace = (ColorManagedColorspaceSettings *) ptr->data;
443
444         return IMB_colormanagement_colorspace_get_named_index(colorspace->name);
445 }
446
447 static void rna_ColorManagedColorspaceSettings_colorspace_set(struct PointerRNA *ptr, int value)
448 {
449         ColorManagedColorspaceSettings *colorspace = (ColorManagedColorspaceSettings *) ptr->data;
450         const char *name = IMB_colormanagement_colorspace_get_indexed_name(value);
451
452         if (name) {
453                 BLI_strncpy(colorspace->name, name, sizeof(colorspace->name));
454         }
455 }
456
457 static EnumPropertyItem *rna_ColorManagedColorspaceSettings_colorspace_itemf(bContext *C, PointerRNA *ptr, PropertyRNA *UNUSED(prop), int *free)
458 {
459         EnumPropertyItem *items = NULL;
460         int totitem = 0;
461
462         IMB_colormanagement_colorspace_items_add(&items, &totitem);
463         RNA_enum_item_end(&items, &totitem);
464
465         *free = TRUE;
466
467         return items;
468 }
469
470 static void rna_ColorManagedColorspaceSettings_reload_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
471 {
472         ID *id = ptr->id.data;
473
474         if (GS(id->name) == ID_IM) {
475                 Image *ima = (Image *) id;
476
477                 DAG_id_tag_update(&ima->id, 0);
478
479                 BKE_image_signal(ima, NULL, IMA_SIGNAL_COLORMANAGE);
480
481                 WM_main_add_notifier(NC_IMAGE | ND_DISPLAY, &ima->id);
482                 WM_main_add_notifier(NC_IMAGE | NA_EDITED, &ima->id);
483         }
484         else if (GS(id->name) == ID_MC) {
485                 MovieClip *clip = (MovieClip *) id;
486
487                 BKE_movieclip_reload(clip);
488
489                 WM_main_add_notifier(NC_MOVIECLIP | ND_DISPLAY, &clip->id);
490                 WM_main_add_notifier(NC_MOVIECLIP | NA_EDITED, &clip->id);
491         }
492 }
493
494 static void rna_ColorManagement_update(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
495 {
496         ID *id = ptr->id.data;
497
498         if (!id)
499                 return;
500
501         if (GS(id->name) == ID_SCE) {
502                 WM_main_add_notifier(NC_SCENE | ND_SEQUENCER, NULL);
503         }
504 }
505
506 /* this function only exists because #curvemap_evaluateF uses a 'const' qualifier */
507 static float rna_CurveMap_evaluateF(struct CurveMap *cuma, float value)
508 {
509         return curvemap_evaluateF(cuma, value);
510 }
511
512 #else
513
514 static void rna_def_curvemappoint(BlenderRNA *brna)
515 {
516         StructRNA *srna;
517         PropertyRNA *prop;
518         static EnumPropertyItem prop_handle_type_items[] = {
519                 {0, "AUTO", 0, "Auto Handle", ""},
520                 {CUMA_VECTOR, "VECTOR", 0, "Vector Handle", ""},
521                 {0, NULL, 0, NULL, NULL}
522         };
523
524         srna = RNA_def_struct(brna, "CurveMapPoint", NULL);
525         RNA_def_struct_ui_text(srna, "CurveMapPoint", "Point of a curve used for a curve mapping");
526
527         prop = RNA_def_property(srna, "location", PROP_FLOAT, PROP_XYZ);
528         RNA_def_property_float_sdna(prop, NULL, "x");
529         RNA_def_property_array(prop, 2);
530         RNA_def_property_ui_text(prop, "Location", "X/Y coordinates of the curve point");
531
532         prop = RNA_def_property(srna, "handle_type", PROP_ENUM, PROP_NONE);
533         RNA_def_property_enum_bitflag_sdna(prop, NULL, "flag");
534         RNA_def_property_enum_items(prop, prop_handle_type_items);
535         RNA_def_property_ui_text(prop, "Handle Type", "Curve interpolation at this point: Bezier or vector");
536
537         prop = RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
538         RNA_def_property_boolean_sdna(prop, NULL, "flag", CUMA_SELECT);
539         RNA_def_property_ui_text(prop, "Select", "Selection state of the curve point");
540 }
541
542 static void rna_def_curvemap_points_api(BlenderRNA *brna, PropertyRNA *cprop)
543 {
544         StructRNA *srna;
545         PropertyRNA *parm;
546         FunctionRNA *func;
547
548         RNA_def_property_srna(cprop, "CurveMapPoints");
549         srna = RNA_def_struct(brna, "CurveMapPoints", NULL);
550         RNA_def_struct_sdna(srna, "CurveMap");
551         RNA_def_struct_ui_text(srna, "Curve Map Point", "Collection of Curve Map Points");
552
553         func = RNA_def_function(srna, "new", "curvemap_insert");
554         RNA_def_function_ui_description(func, "Add point to CurveMap");
555         parm = RNA_def_float(func, "position", 0.0f, -FLT_MAX, FLT_MAX, "Position", "Position to add point", -FLT_MAX, FLT_MAX);
556         RNA_def_property_flag(parm, PROP_REQUIRED);
557         parm = RNA_def_float(func, "value", 0.0f, -FLT_MAX, FLT_MAX, "Value", "Value of point", -FLT_MAX, FLT_MAX);
558         RNA_def_property_flag(parm, PROP_REQUIRED);
559         parm = RNA_def_pointer(func, "point", "CurveMapPoint", "", "New point");
560         RNA_def_function_return(func, parm);
561
562         func = RNA_def_function(srna, "remove", "curvemap_remove_point");
563         RNA_def_function_ui_description(func, "Delete point from CurveMap");
564         parm = RNA_def_pointer(func, "point", "CurveMapPoint", "", "PointElement to remove");
565         RNA_def_property_flag(parm, PROP_REQUIRED | PROP_NEVER_NULL);
566 }
567
568 static void rna_def_curvemap(BlenderRNA *brna)
569 {
570         StructRNA *srna;
571         PropertyRNA *prop, *parm;
572         FunctionRNA *func;
573
574         static EnumPropertyItem prop_extend_items[] = {
575                 {0, "HORIZONTAL", 0, "Horizontal", ""},
576                 {CUMA_EXTEND_EXTRAPOLATE, "EXTRAPOLATED", 0, "Extrapolated", ""},
577                 {0, NULL, 0, NULL, NULL}
578         };
579
580         srna = RNA_def_struct(brna, "CurveMap", NULL);
581         RNA_def_struct_ui_text(srna, "CurveMap", "Curve in a curve mapping");
582
583         prop = RNA_def_property(srna, "extend", PROP_ENUM, PROP_NONE);
584         RNA_def_property_enum_bitflag_sdna(prop, NULL, "flag");
585         RNA_def_property_enum_items(prop, prop_extend_items);
586         RNA_def_property_ui_text(prop, "Extend", "Extrapolate the curve or extend it horizontally");
587
588         prop = RNA_def_property(srna, "points", PROP_COLLECTION, PROP_NONE);
589         RNA_def_property_collection_sdna(prop, NULL, "curve", "totpoint");
590         RNA_def_property_struct_type(prop, "CurveMapPoint");
591         RNA_def_property_ui_text(prop, "Points", "");
592         rna_def_curvemap_points_api(brna, prop);
593
594         func = RNA_def_function(srna, "evaluate", "rna_CurveMap_evaluateF");
595         RNA_def_function_ui_description(func, "Evaluate curve at given location");
596         parm = RNA_def_float(func, "position", 0.0f, -FLT_MAX, FLT_MAX, "Position", "Position to evaluate curve at", -FLT_MAX, FLT_MAX);
597         RNA_def_property_flag(parm, PROP_REQUIRED);
598         parm = RNA_def_float(func, "value", 0.0f, -FLT_MAX, FLT_MAX, "Value", "Value of curve at given location", -FLT_MAX, FLT_MAX);
599         RNA_def_function_return(func, parm);
600 }
601
602 static void rna_def_curvemapping(BlenderRNA *brna)
603 {
604         StructRNA *srna;
605         PropertyRNA *prop;
606         FunctionRNA *func;
607
608         srna = RNA_def_struct(brna, "CurveMapping", NULL);
609         RNA_def_struct_ui_text(srna, "CurveMapping",
610                                "Curve mapping to map color, vector and scalar values to other values using "
611                                "a user defined curve");
612         
613         prop = RNA_def_property(srna, "use_clip", PROP_BOOLEAN, PROP_NONE);
614         RNA_def_property_boolean_sdna(prop, NULL, "flag", CUMA_DO_CLIP);
615         RNA_def_property_ui_text(prop, "Clip", "Force the curve view to fit a defined boundary");
616         RNA_def_property_boolean_funcs(prop, NULL, "rna_CurveMapping_clip_set");
617
618         prop = RNA_def_property(srna, "clip_min_x", PROP_FLOAT, PROP_NONE);
619         RNA_def_property_float_sdna(prop, NULL, "clipr.xmin");
620         RNA_def_property_range(prop, -100.0f, 100.0f);
621         RNA_def_property_ui_text(prop, "Clip Min X", "");
622         RNA_def_property_float_funcs(prop, NULL, NULL, "rna_CurveMapping_clipminx_range");
623
624         prop = RNA_def_property(srna, "clip_min_y", PROP_FLOAT, PROP_NONE);
625         RNA_def_property_float_sdna(prop, NULL, "clipr.ymin");
626         RNA_def_property_range(prop, -100.0f, 100.0f);
627         RNA_def_property_ui_text(prop, "Clip Min Y", "");
628         RNA_def_property_float_funcs(prop, NULL, NULL, "rna_CurveMapping_clipminy_range");
629
630         prop = RNA_def_property(srna, "clip_max_x", PROP_FLOAT, PROP_NONE);
631         RNA_def_property_float_sdna(prop, NULL, "clipr.xmax");
632         RNA_def_property_range(prop, -100.0f, 100.0f);
633         RNA_def_property_ui_text(prop, "Clip Max X", "");
634         RNA_def_property_float_funcs(prop, NULL, NULL, "rna_CurveMapping_clipmaxx_range");
635
636         prop = RNA_def_property(srna, "clip_max_y", PROP_FLOAT, PROP_NONE);
637         RNA_def_property_float_sdna(prop, NULL, "clipr.ymax");
638         RNA_def_property_range(prop, -100.0f, 100.0f);
639         RNA_def_property_ui_text(prop, "Clip Max Y", "");
640         RNA_def_property_float_funcs(prop, NULL, NULL, "rna_CurveMapping_clipmaxy_range");
641
642         prop = RNA_def_property(srna, "curves", PROP_COLLECTION, PROP_NONE);
643         RNA_def_property_collection_funcs(prop, "rna_CurveMapping_curves_begin", "rna_iterator_array_next",
644                                           "rna_iterator_array_end", "rna_iterator_array_get",
645                                           "rna_CurveMapping_curves_length", NULL, NULL, NULL);
646         RNA_def_property_struct_type(prop, "CurveMap");
647         RNA_def_property_ui_text(prop, "Curves", "");
648
649         prop = RNA_def_property(srna, "black_level", PROP_FLOAT, PROP_COLOR);
650         RNA_def_property_float_sdna(prop, NULL, "black");
651         RNA_def_property_range(prop, -1000.0f, 1000.0f);
652         RNA_def_property_ui_text(prop, "Black Level", "For RGB curves, the color that black is mapped to");
653         RNA_def_property_float_funcs(prop, NULL, "rna_CurveMapping_black_level_set", NULL);
654
655         prop = RNA_def_property(srna, "white_level", PROP_FLOAT, PROP_COLOR);
656         RNA_def_property_float_sdna(prop, NULL, "white");
657         RNA_def_property_range(prop, -1000.0f, 1000.0f);
658         RNA_def_property_ui_text(prop, "White Level", "For RGB curves, the color that white is mapped to");
659         RNA_def_property_float_funcs(prop, NULL, "rna_CurveMapping_white_level_set", NULL);
660
661         func = RNA_def_function(srna, "update", "curvemapping_changed_all");
662         RNA_def_function_ui_description(func, "Update curve mapping after making changes");
663 }
664
665 static void rna_def_color_ramp_element(BlenderRNA *brna)
666 {
667         StructRNA *srna;
668         PropertyRNA *prop;
669
670         srna = RNA_def_struct(brna, "ColorRampElement", NULL);
671         RNA_def_struct_sdna(srna, "CBData");
672         RNA_def_struct_path_func(srna, "rna_ColorRampElement_path");
673         RNA_def_struct_ui_text(srna, "Color Ramp Element", "Element defining a color at a position in the color ramp");
674         
675         prop = RNA_def_property(srna, "color", PROP_FLOAT, PROP_COLOR);
676         RNA_def_property_float_sdna(prop, NULL, "r");
677         RNA_def_property_array(prop, 4);
678         RNA_def_property_ui_text(prop, "Color", "Set color of selected color stop");
679         RNA_def_property_update(prop, 0, "rna_ColorRamp_update");
680         
681         prop = RNA_def_property(srna, "position", PROP_FLOAT, PROP_NONE);
682         RNA_def_property_float_sdna(prop, NULL, "pos");
683         RNA_def_property_range(prop, 0, 1);
684         RNA_def_property_ui_text(prop, "Position", "Set position of selected color stop");
685         RNA_def_property_update(prop, 0, "rna_ColorRamp_update");
686 }
687
688 static void rna_def_color_ramp_element_api(BlenderRNA *brna, PropertyRNA *cprop)
689 {
690         StructRNA *srna;
691         PropertyRNA *parm;
692         FunctionRNA *func;
693
694         RNA_def_property_srna(cprop, "ColorRampElements");
695         srna = RNA_def_struct(brna, "ColorRampElements", NULL);
696         RNA_def_struct_sdna(srna, "ColorBand");
697         RNA_def_struct_path_func(srna, "rna_ColorRampElement_path");
698         RNA_def_struct_ui_text(srna, "Color Ramp Elements", "Collection of Color Ramp Elements");
699
700         /* TODO, make these functions generic in texture.c */
701         func = RNA_def_function(srna, "new", "rna_ColorRampElement_new");
702         RNA_def_function_ui_description(func, "Add element to ColorRamp");
703         RNA_def_function_flag(func, FUNC_USE_REPORTS);
704         parm = RNA_def_float(func, "position", 0.0f, 0.0f, 1.0f, "Position", "Position to add element", 0.0f, 1.0f);
705         RNA_def_property_flag(parm, PROP_REQUIRED);
706         /* return type */
707         parm = RNA_def_pointer(func, "element", "ColorRampElement", "", "New element");
708         RNA_def_function_return(func, parm);
709
710         func = RNA_def_function(srna, "remove", "rna_ColorRampElement_remove");
711         RNA_def_function_ui_description(func, "Delete element from ColorRamp");
712         RNA_def_function_flag(func, FUNC_USE_REPORTS);
713         parm = RNA_def_pointer(func, "element", "ColorRampElement", "", "Element to remove");
714         RNA_def_property_flag(parm, PROP_REQUIRED | PROP_NEVER_NULL);
715 }
716
717 static void rna_def_color_ramp(BlenderRNA *brna)
718 {
719         StructRNA *srna;
720         PropertyRNA *prop;
721         FunctionRNA *func;
722
723         static EnumPropertyItem prop_interpolation_items[] = {
724                 {1, "EASE", 0, "Ease", ""},
725                 {3, "CARDINAL", 0, "Cardinal", ""},
726                 {0, "LINEAR", 0, "Linear", ""},
727                 {2, "B_SPLINE", 0, "B-Spline", ""},
728                 {4, "CONSTANT", 0, "Constant", ""},
729                 {0, NULL, 0, NULL, NULL}
730         };
731         
732         srna = RNA_def_struct(brna, "ColorRamp", NULL);
733         RNA_def_struct_sdna(srna, "ColorBand");
734         RNA_def_struct_path_func(srna, "rna_ColorRamp_path");
735         RNA_def_struct_ui_text(srna, "Color Ramp", "Color ramp mapping a scalar value to a color");
736         
737         prop = RNA_def_property(srna, "elements", PROP_COLLECTION, PROP_COLOR);
738         RNA_def_property_collection_sdna(prop, NULL, "data", "tot");
739         RNA_def_property_struct_type(prop, "ColorRampElement");
740         RNA_def_property_ui_text(prop, "Elements", "");
741         RNA_def_property_update(prop, 0, "rna_ColorRamp_update");
742         rna_def_color_ramp_element_api(brna, prop);
743
744         prop = RNA_def_property(srna, "interpolation", PROP_ENUM, PROP_NONE);
745         RNA_def_property_enum_sdna(prop, NULL, "ipotype");
746         RNA_def_property_enum_items(prop, prop_interpolation_items);
747         RNA_def_property_ui_text(prop, "Interpolation", "");
748         RNA_def_property_update(prop, 0, "rna_ColorRamp_update");
749
750 #if 0 /* use len(elements) */
751         prop = RNA_def_property(srna, "total", PROP_INT, PROP_NONE);
752         RNA_def_property_int_sdna(prop, NULL, "tot");
753         /* needs a function to do the right thing when adding elements like colorband_add_cb() */
754         RNA_def_property_clear_flag(prop, PROP_EDITABLE);
755         RNA_def_property_range(prop, 0, 31); /* MAXCOLORBAND = 32 */
756         RNA_def_property_ui_text(prop, "Total", "Total number of elements");
757         RNA_def_property_update(prop, 0, "rna_ColorRamp_update");
758 #endif
759         
760         func = RNA_def_function(srna, "evaluate", "rna_ColorRamp_eval");
761         RNA_def_function_ui_description(func, "Evaluate ColorRamp");
762         prop = RNA_def_float(func, "position", 1.0f, 0.0f, 1.0f, "Position", "Evaluate ColorRamp at position", 0.0f, 1.0f);
763         RNA_def_property_flag(prop, PROP_REQUIRED);
764         /* return */
765         prop = RNA_def_float_color(func, "color", 4, NULL, -FLT_MAX, FLT_MAX, "Color", "Color at given position",
766                                    -FLT_MAX, FLT_MAX);
767         RNA_def_property_flag(prop, PROP_THICK_WRAP);
768         RNA_def_function_output(func, prop);
769 }
770
771 static void rna_def_histogram(BlenderRNA *brna)
772 {
773         StructRNA *srna;
774         PropertyRNA *prop;
775         
776         static EnumPropertyItem prop_mode_items[] = {
777                 {HISTO_MODE_LUMA, "LUMA", 0, "Luma", "Luma"},
778                 {HISTO_MODE_RGB, "RGB", 0, "RGB", "Red Green Blue"},
779                 {HISTO_MODE_R, "R", 0, "R", "Red"},
780                 {HISTO_MODE_G, "G", 0, "G", "Green"},
781                 {HISTO_MODE_B, "B", 0, "B", "Blue"},
782                 {HISTO_MODE_ALPHA, "A", 0, "A", "Alpha"},
783                 {0, NULL, 0, NULL, NULL}
784         };
785
786         srna = RNA_def_struct(brna, "Histogram", NULL);
787         RNA_def_struct_ui_text(srna, "Histogram", "Statistical view of the levels of color in an image");
788         
789         prop = RNA_def_property(srna, "mode", PROP_ENUM, PROP_NONE);
790         RNA_def_property_enum_sdna(prop, NULL, "mode");
791         RNA_def_property_enum_items(prop, prop_mode_items);
792         RNA_def_property_ui_text(prop, "Mode", "Channels to display when drawing the histogram");
793
794         prop = RNA_def_property(srna, "show_line", PROP_BOOLEAN, PROP_NONE);
795         RNA_def_property_boolean_sdna(prop, NULL, "flag", HISTO_FLAG_LINE);
796         RNA_def_property_ui_text(prop, "Show Line", "Display lines rather then filled shapes");
797         RNA_def_property_ui_icon(prop, ICON_IPO, 0);
798 }
799
800 static void rna_def_scopes(BlenderRNA *brna)
801 {
802         StructRNA *srna;
803         PropertyRNA *prop;
804
805         static EnumPropertyItem prop_wavefrm_mode_items[] = {
806                 {SCOPES_WAVEFRM_LUMA, "LUMA", ICON_COLOR, "Luma", ""},
807                 {SCOPES_WAVEFRM_RGB, "RGB", ICON_COLOR, "Red Green Blue", ""},
808                 {SCOPES_WAVEFRM_YCC_601, "YCBCR601", ICON_COLOR, "YCbCr (ITU 601)", ""},
809                 {SCOPES_WAVEFRM_YCC_709, "YCBCR709", ICON_COLOR, "YCbCr (ITU 709)", ""},
810                 {SCOPES_WAVEFRM_YCC_JPEG, "YCBCRJPG", ICON_COLOR, "YCbCr (Jpeg)", ""},
811                 {0, NULL, 0, NULL, NULL}
812         };
813
814         srna = RNA_def_struct(brna, "Scopes", NULL);
815         RNA_def_struct_ui_text(srna, "Scopes", "Scopes for statistical view of an image");
816         
817         prop = RNA_def_property(srna, "use_full_resolution", PROP_BOOLEAN, PROP_NONE);
818         RNA_def_property_boolean_sdna(prop, "Scopes", "sample_full", 1);
819         RNA_def_property_ui_text(prop, "Full Sample", "Sample every pixel of the image");
820         RNA_def_property_update(prop, 0, "rna_Scopes_update");
821         
822         prop = RNA_def_property(srna, "accuracy", PROP_FLOAT, PROP_PERCENTAGE);
823         RNA_def_property_float_sdna(prop, "Scopes", "accuracy");
824         RNA_def_property_range(prop, 0.0, 100.0);
825         RNA_def_property_ui_range(prop, 0.0, 100.0, 10, 1);
826         RNA_def_property_ui_text(prop, "Accuracy", "Proportion of original image source pixel lines to sample");
827         RNA_def_property_update(prop, 0, "rna_Scopes_update");
828
829         prop = RNA_def_property(srna, "histogram", PROP_POINTER, PROP_NONE);
830         RNA_def_property_pointer_sdna(prop, "Scopes", "hist");
831         RNA_def_property_struct_type(prop, "Histogram");
832         RNA_def_property_ui_text(prop, "Histogram", "Histogram for viewing image statistics");
833
834         prop = RNA_def_property(srna, "waveform_mode", PROP_ENUM, PROP_NONE);
835         RNA_def_property_enum_sdna(prop, "Scopes", "wavefrm_mode");
836         RNA_def_property_enum_items(prop, prop_wavefrm_mode_items);
837         RNA_def_property_ui_text(prop, "Waveform Mode", "");
838         RNA_def_property_update(prop, 0, "rna_Scopes_update");
839
840         prop = RNA_def_property(srna, "waveform_alpha", PROP_FLOAT, PROP_FACTOR);
841         RNA_def_property_float_sdna(prop, "Scopes", "wavefrm_alpha");
842         RNA_def_property_range(prop, 0, 1);
843         RNA_def_property_ui_text(prop, "Waveform Opacity", "Opacity of the points");
844
845         prop = RNA_def_property(srna, "vectorscope_alpha", PROP_FLOAT, PROP_FACTOR);
846         RNA_def_property_float_sdna(prop, "Scopes", "vecscope_alpha");
847         RNA_def_property_range(prop, 0, 1);
848         RNA_def_property_ui_text(prop, "Vectorscope Opacity", "Opacity of the points");
849 }
850
851 static void rna_def_colormanage(BlenderRNA *brna)
852 {
853         StructRNA *srna;
854         PropertyRNA *prop;
855
856         static EnumPropertyItem display_device_items[] = {
857                 {0, "DEFAULT", 0, "Default", ""},
858                 {0, NULL, 0, NULL, NULL}
859         };
860
861         static EnumPropertyItem view_transform_items[] = {
862                 {0, "NONE", 0, "None", "Do not perform any color transform on display, use old non-color managed technique for display"},
863                 {0, NULL, 0, NULL, NULL}
864         };
865
866         static EnumPropertyItem color_space_items[] = {
867                 {0, "NONE", 0, "None", "Do not perform any color transform on load, treat colors as in scene linear space already"},
868                 {0, NULL, 0, NULL, NULL}
869         };
870
871         /* ** Display Settings  **  */
872         srna = RNA_def_struct(brna, "ColorManagedDisplaySettings", NULL);
873         RNA_def_struct_ui_text(srna, "ColorManagedDisplaySettings", "Color management specific to display device");
874
875         prop = RNA_def_property(srna, "display_device", PROP_ENUM, PROP_NONE);
876         RNA_def_property_enum_items(prop, display_device_items);
877         RNA_def_property_enum_funcs(prop, "rna_ColorManagedDisplaySettings_display_device_get",
878                                           "rna_ColorManagedDisplaySettings_display_device_set",
879                                           "rna_ColorManagedDisplaySettings_display_device_itemf");
880         RNA_def_property_ui_text(prop, "Display Device", "Display device name");
881         RNA_def_property_update(prop, NC_WINDOW, "rna_ColorManagedDisplaySettings_display_device_update");
882
883         /* ** View Settings  **  */
884         srna = RNA_def_struct(brna, "ColorManagedViewSettings", NULL);
885         RNA_def_struct_ui_text(srna, "ColorManagedViewSettings", "Color management settings used for displaying images on the display");
886
887         prop = RNA_def_property(srna, "view_transform", PROP_ENUM, PROP_NONE);
888         RNA_def_property_enum_items(prop, view_transform_items);
889         RNA_def_property_enum_funcs(prop, "rna_ColorManagedViewSettings_view_transform_get",
890                                           "rna_ColorManagedViewSettings_view_transform_set",
891                                           "rna_ColorManagedViewSettings_view_transform_itemf");
892         RNA_def_property_ui_text(prop, "View Transform", "View used ");
893         RNA_def_property_update(prop, NC_WINDOW, "rna_ColorManagement_update");
894
895         prop = RNA_def_property(srna, "exposure", PROP_FLOAT, PROP_FACTOR);
896         RNA_def_property_float_sdna(prop, NULL, "exposure");
897         RNA_def_property_range(prop, -10.0f, 10.0f);
898         RNA_def_property_float_default(prop, 0.0f);
899         RNA_def_property_ui_text(prop, "Exposure", "Exposure (stops) applied before display transform");
900         RNA_def_property_update(prop, NC_WINDOW, "rna_ColorManagement_update");
901
902         prop = RNA_def_property(srna, "gamma", PROP_FLOAT, PROP_FACTOR);
903         RNA_def_property_float_sdna(prop, NULL, "gamma");
904         RNA_def_property_float_default(prop, 1.0f);
905         RNA_def_property_range(prop, 0.0f, 5.0f);
906         RNA_def_property_ui_text(prop, "Gamma", "Amount of gamma modification applied after display transform");
907         RNA_def_property_update(prop, NC_WINDOW, "rna_ColorManagement_update");
908
909         prop = RNA_def_property(srna, "curve_mapping", PROP_POINTER, PROP_NONE);
910         RNA_def_property_pointer_sdna(prop, NULL, "curve_mapping");
911         RNA_def_property_ui_text(prop, "Curve", "Color curve mapping applied before display transform");
912         RNA_def_property_update(prop, NC_WINDOW, "rna_ColorManagement_update");
913
914         prop = RNA_def_property(srna, "use_curve_mapping", PROP_BOOLEAN, PROP_NONE);
915         RNA_def_property_boolean_sdna(prop, NULL, "flag", COLORMANAGE_VIEW_USE_CURVES);
916         RNA_def_property_boolean_funcs(prop, NULL, "rna_ColorManagedViewSettings_use_curves_set");
917         RNA_def_property_ui_text(prop, "Use Curves", "Use RGB curved for pre-display transformation");
918         RNA_def_property_update(prop, NC_WINDOW, "rna_ColorManagement_update");
919
920         /* ** Colorspace **  */
921         srna = RNA_def_struct(brna, "ColorManagedColorspaceSettings", NULL);
922         RNA_def_struct_ui_text(srna, "ColorManagedColorspaceSettings", "Input color space settings");
923
924         prop = RNA_def_property(srna, "name", PROP_ENUM, PROP_NONE);
925         RNA_def_property_enum_items(prop, color_space_items);
926         RNA_def_property_enum_funcs(prop, "rna_ColorManagedColorspaceSettings_colorspace_get",
927                                           "rna_ColorManagedColorspaceSettings_colorspace_set",
928                                           "rna_ColorManagedColorspaceSettings_colorspace_itemf");
929         RNA_def_property_ui_text(prop, "Color Space", "Input color space name");
930         RNA_def_property_update(prop, NC_WINDOW, "rna_ColorManagedColorspaceSettings_reload_update");
931 }
932
933 void RNA_def_color(BlenderRNA *brna)
934 {
935         rna_def_curvemappoint(brna);
936         rna_def_curvemap(brna);
937         rna_def_curvemapping(brna);
938         rna_def_color_ramp_element(brna);
939         rna_def_color_ramp(brna);
940         rna_def_histogram(brna);
941         rna_def_scopes(brna);
942         rna_def_colormanage(brna);
943 }
944
945 #endif