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