Fix T64842: crash rendering files with bevel curves
[blender.git] / source / blender / blenkernel / BKE_colortools.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) 2006 Blender Foundation.
17  * All rights reserved.
18  */
19 #ifndef __BKE_COLORTOOLS_H__
20 #define __BKE_COLORTOOLS_H__
21
22 /** \file
23  * \ingroup bke
24  */
25
26 struct ColorManagedColorspaceSettings;
27 struct ColorManagedDisplaySettings;
28 struct ColorManagedViewSettings;
29 struct CurveMap;
30 struct CurveMapPoint;
31 struct CurveMapping;
32 struct Histogram;
33 struct ImBuf;
34 struct Scopes;
35 struct rctf;
36
37 void curvemapping_set_defaults(
38     struct CurveMapping *cumap, int tot, float minx, float miny, float maxx, float maxy);
39 struct CurveMapping *curvemapping_add(int tot, float minx, float miny, float maxx, float maxy);
40 void curvemapping_free_data(struct CurveMapping *cumap);
41 void curvemapping_free(struct CurveMapping *cumap);
42 void curvemapping_copy_data(struct CurveMapping *target, const struct CurveMapping *cumap);
43 struct CurveMapping *curvemapping_copy(const struct CurveMapping *cumap);
44 void curvemapping_set_black_white_ex(const float black[3], const float white[3], float r_bwmul[3]);
45 void curvemapping_set_black_white(struct CurveMapping *cumap,
46                                   const float black[3],
47                                   const float white[3]);
48
49 enum {
50   CURVEMAP_SLOPE_NEGATIVE = 0,
51   CURVEMAP_SLOPE_POSITIVE = 1,
52   CURVEMAP_SLOPE_POS_NEG = 2,
53 };
54
55 void curvemap_reset(struct CurveMap *cuma, const struct rctf *clipr, int preset, int slope);
56 void curvemap_remove(struct CurveMap *cuma, const short flag);
57 bool curvemap_remove_point(struct CurveMap *cuma, struct CurveMapPoint *cmp);
58 struct CurveMapPoint *curvemap_insert(struct CurveMap *cuma, float x, float y);
59 void curvemap_handle_set(struct CurveMap *cuma, int type);
60
61 void curvemapping_changed(struct CurveMapping *cumap, const bool rem_doubles);
62 void curvemapping_changed_all(struct CurveMapping *cumap);
63
64 /* call before _all_ evaluation functions */
65 void curvemapping_initialize(struct CurveMapping *cumap);
66
67 /* keep these (const CurveMap) - to help with thread safety */
68 /* single curve, no table check */
69 float curvemap_evaluateF(const struct CurveMap *cuma, float value);
70 /* single curve, with table check */
71 float curvemapping_evaluateF(const struct CurveMapping *cumap, int cur, float value);
72 void curvemapping_evaluate3F(const struct CurveMapping *cumap,
73                              float vecout[3],
74                              const float vecin[3]);
75 void curvemapping_evaluateRGBF(const struct CurveMapping *cumap,
76                                float vecout[3],
77                                const float vecin[3]);
78 void curvemapping_evaluate_premulRGB(const struct CurveMapping *cumap,
79                                      unsigned char vecout_byte[3],
80                                      const unsigned char vecin_byte[3]);
81 void curvemapping_evaluate_premulRGBF_ex(const struct CurveMapping *cumap,
82                                          float vecout[3],
83                                          const float vecin[3],
84                                          const float black[3],
85                                          const float bwmul[3]);
86 void curvemapping_evaluate_premulRGBF(const struct CurveMapping *cumap,
87                                       float vecout[3],
88                                       const float vecin[3]);
89 int curvemapping_RGBA_does_something(const struct CurveMapping *cumap);
90 void curvemapping_table_RGBA(const struct CurveMapping *cumap, float **array, int *size);
91
92 /* non-const, these modify the curve */
93 void curvemapping_premultiply(struct CurveMapping *cumap, int restore);
94
95 void BKE_histogram_update_sample_line(struct Histogram *hist,
96                                       struct ImBuf *ibuf,
97                                       const struct ColorManagedViewSettings *view_settings,
98                                       const struct ColorManagedDisplaySettings *display_settings);
99 void scopes_update(struct Scopes *scopes,
100                    struct ImBuf *ibuf,
101                    const struct ColorManagedViewSettings *view_settings,
102                    const struct ColorManagedDisplaySettings *display_settings);
103 void scopes_free(struct Scopes *scopes);
104 void scopes_new(struct Scopes *scopes);
105
106 void BKE_color_managed_display_settings_init(struct ColorManagedDisplaySettings *settings);
107 void BKE_color_managed_display_settings_copy(struct ColorManagedDisplaySettings *new_settings,
108                                              const struct ColorManagedDisplaySettings *settings);
109
110 /* Initialize view settings to be best suitable for render type of viewing.
111  * This will use default view transform from the OCIO configuration if none
112  * is specified. */
113 void BKE_color_managed_view_settings_init_render(
114     struct ColorManagedViewSettings *settings,
115     const struct ColorManagedDisplaySettings *display_settings,
116     const char *view_transform);
117
118 /* Initialize view settings which are best suitable for viewing non-render
119  * images. For example,s movie clips while tracking. */
120 void BKE_color_managed_view_settings_init_default(
121     struct ColorManagedViewSettings *settings,
122     const struct ColorManagedDisplaySettings *display_settings);
123
124 void BKE_color_managed_view_settings_copy(struct ColorManagedViewSettings *new_settings,
125                                           const struct ColorManagedViewSettings *settings);
126 void BKE_color_managed_view_settings_free(struct ColorManagedViewSettings *settings);
127
128 void BKE_color_managed_colorspace_settings_init(
129     struct ColorManagedColorspaceSettings *colorspace_settings);
130 void BKE_color_managed_colorspace_settings_copy(
131     struct ColorManagedColorspaceSettings *colorspace_settings,
132     const struct ColorManagedColorspaceSettings *settings);
133 bool BKE_color_managed_colorspace_settings_equals(
134     const struct ColorManagedColorspaceSettings *settings1,
135     const struct ColorManagedColorspaceSettings *settings2);
136 #endif