Blender V4.3
COM_ColorCurveOperation.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2011 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
6
7#include "BKE_colortools.hh"
8
9namespace blender::compositor {
10
27
29 const rcti &area,
31{
33 float bwmul[3];
34 for (BuffersIterator<float> it = output->iterate_with(inputs, area); !it.is_end(); ++it) {
35 /* Local versions of `cumap->black` and `cumap->white`. */
36 const float *black = it.in(2);
37 const float *white = it.in(3);
38 /* Get a local `bwmul` value, it's not threadsafe using `cumap->bwmul` and others. */
39 BKE_curvemapping_set_black_white_ex(black, white, bwmul);
40
41 const float fac = *it.in(0);
42 const float *image = it.in(1);
43 if (fac >= 1.0f) {
44 BKE_curvemapping_evaluate_premulRGBF_ex(cumap, it.out, image, black, bwmul);
45 }
46 else if (fac <= 0.0f) {
47 copy_v3_v3(it.out, image);
48 }
49 else {
50 float col[4];
51 BKE_curvemapping_evaluate_premulRGBF_ex(cumap, col, image, black, bwmul);
52 interp_v3_v3v3(it.out, image, col, fac);
53 }
54 it.out[3] = image[3];
55 }
56}
57
58/* Constant level curve mapping. */
59
76
78 const rcti &area,
80{
82 for (BuffersIterator<float> it = output->iterate_with(inputs, area); !it.is_end(); ++it) {
83 const float fac = *it.in(0);
84 const float *image = it.in(1);
85 if (fac >= 1.0f) {
86 BKE_curvemapping_evaluate_premulRGBF(cumap, it.out, image);
87 }
88 else if (fac <= 0.0f) {
89 copy_v3_v3(it.out, image);
90 }
91 else {
92 float col[4];
94 interp_v3_v3v3(it.out, image, col, fac);
95 }
96 it.out[3] = image[3];
97 }
98}
99
100} // namespace blender::compositor
void BKE_curvemapping_evaluate_premulRGBF(const CurveMapping *cumap, float vecout[3], const float vecin[3])
void BKE_curvemapping_premultiply(CurveMapping *cumap, bool restore)
void BKE_curvemapping_evaluate_premulRGBF_ex(const CurveMapping *cumap, float vecout[3], const float vecin[3], const float black[3], const float bwmul[3])
void BKE_curvemapping_set_black_white(CurveMapping *cumap, const float black[3], const float white[3])
void BKE_curvemapping_set_black_white_ex(const float black[3], const float white[3], float r_bwmul[3])
MINLINE void copy_v3_v3(float r[3], const float a[3])
void interp_v3_v3v3(float r[3], const float a[3], const float b[3], float t)
Definition math_vector.c:36
void update_memory_buffer_partial(MemoryBuffer *output, const rcti &area, Span< MemoryBuffer * > inputs) override
void update_memory_buffer_partial(MemoryBuffer *output, const rcti &area, Span< MemoryBuffer * > inputs) override
a MemoryBuffer contains access to the data
void add_output_socket(DataType datatype)
void add_input_socket(DataType datatype, ResizeMode resize_mode=ResizeMode::Center)
void set_canvas_input_index(unsigned int index)
set the index of the input socket that will determine the canvas of this operation
uint col
typename BuffersIteratorBuilder< T >::Iterator BuffersIterator