Blender V5.0
node_composite_brightness.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2006 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
8
9#include <limits>
10
11#include "BLI_math_color.h"
13
15
16#include "NOD_multi_function.hh"
17
18#include "UI_resources.hh"
19
20#include "GPU_material.hh"
21
23
24/* **************** Brightness and Contrast ******************** */
25
27
29{
30 b.use_custom_socket_order();
31 b.allow_any_socket_order();
32 b.is_function_node();
33 b.add_input<decl::Color>("Image").default_value({1.0f, 1.0f, 1.0f, 1.0f}).hide_value();
34 b.add_output<decl::Color>("Image").align_with_previous();
35
36 b.add_input<decl::Float>("Brightness", "Bright").min(-100.0f).max(100.0f);
37 b.add_input<decl::Float>("Contrast").min(-100.0f).max(100.0f);
38}
39
40using namespace blender::compositor;
41
42static int node_gpu_material(GPUMaterial *material,
43 bNode *node,
44 bNodeExecData * /*execdata*/,
47{
48 return GPU_stack_link(material, node, "node_composite_bright_contrast", inputs, outputs);
49}
50
51/* The algorithm is by Werner D. Streidt, extracted of OpenCV `demhist.c`:
52 * http://visca.com/ffactory/archives/5-99/msg00021.html */
54 const float brightness,
55 const float contrast)
56{
57 float scaled_brightness = brightness / 100.0f;
58 float delta = contrast / 200.0f;
59
60 float multiplier, offset;
61 if (contrast > 0.0f) {
62 multiplier = 1.0f - delta * 2.0f;
63 multiplier = 1.0f / math::max(multiplier, std::numeric_limits<float>::epsilon());
64 offset = multiplier * (scaled_brightness - delta);
65 }
66 else {
67 delta *= -1.0f;
68 multiplier = math::max(1.0f - delta * 2.0f, 0.0f);
69 offset = multiplier * scaled_brightness + delta;
70 }
71
72 return float4(color.xyz() * multiplier + offset, color.w);
73}
74
76{
77 static auto function = mf::build::SI3_SO<float4, float, float, float4>(
78 "Brightness And Contrast",
79 [](const float4 &color, const float brightness, const float contrast) -> float4 {
80 return brightness_and_contrast(color, brightness, contrast);
81 },
82 mf::build::exec_presets::SomeSpanOrSingle<0>());
83 builder.set_matching_fn(function);
84}
85
86} // namespace blender::nodes::node_composite_brightness_cc
87
89{
91
92 static blender::bke::bNodeType ntype;
93
94 cmp_node_type_base(&ntype, "CompositorNodeBrightContrast", CMP_NODE_BRIGHTCONTRAST);
95 ntype.ui_name = "Brightness/Contrast";
96 ntype.ui_description = "Adjust brightness and contrast";
97 ntype.enum_name_legacy = "BRIGHTCONTRAST";
99 ntype.declare = file_ns::cmp_node_brightcontrast_declare;
100 ntype.gpu_fn = file_ns::node_gpu_material;
101 ntype.build_multi_function = file_ns::node_build_multi_function;
102
104}
#define NODE_CLASS_OP_COLOR
Definition BKE_node.hh:449
#define CMP_NODE_BRIGHTCONTRAST
bool GPU_stack_link(GPUMaterial *mat, const bNode *node, const char *name, GPUNodeStack *in, GPUNodeStack *out,...)
#define NOD_REGISTER_NODE(REGISTER_FUNC)
void set_matching_fn(const mf::MultiFunction *fn)
void node_register_type(bNodeType &ntype)
Definition node.cc:2416
T max(const T &a, const T &b)
static void node_build_multi_function(blender::nodes::NodeMultiFunctionBuilder &builder)
static void cmp_node_brightcontrast_declare(NodeDeclarationBuilder &b)
static int node_gpu_material(GPUMaterial *material, bNode *node, bNodeExecData *, GPUNodeStack *inputs, GPUNodeStack *outputs)
static float4 brightness_and_contrast(const float4 &color, const float brightness, const float contrast)
VecBase< float, 4 > float4
static void register_node_type_cmp_brightcontrast()
void cmp_node_type_base(blender::bke::bNodeType *ntype, std::string idname, const std::optional< int16_t > legacy_type)
static blender::bke::bNodeSocketTemplate outputs[]
static blender::bke::bNodeSocketTemplate inputs[]
#define min(a, b)
Definition sort.cc:36
Defines a node type.
Definition BKE_node.hh:238
std::string ui_description
Definition BKE_node.hh:244
NodeGPUExecFunction gpu_fn
Definition BKE_node.hh:342
NodeMultiFunctionBuildFunction build_multi_function
Definition BKE_node.hh:351
const char * enum_name_legacy
Definition BKE_node.hh:247
NodeDeclareFunction declare
Definition BKE_node.hh:362