Blender V4.3
COM_KuwaharaNode.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2023 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
5#include "DNA_node_types.h"
6#include "DNA_scene_types.h"
7
8#include "COM_KuwaharaNode.h"
9
15
16namespace blender::compositor {
17
19 const CompositorContext & /*context*/) const
20{
21 const bNode *node = this->get_bnode();
22 const NodeKuwaharaData *data = (const NodeKuwaharaData *)node->storage;
23
24 switch (data->variation) {
26 KuwaharaClassicOperation *kuwahara_classic = new KuwaharaClassicOperation();
27 kuwahara_classic->set_high_precision(data->high_precision);
28 converter.add_operation(kuwahara_classic);
29 converter.map_input_socket(get_input_socket(0), kuwahara_classic->get_input_socket(0));
30 converter.map_input_socket(get_input_socket(1), kuwahara_classic->get_input_socket(1));
31
34 converter.add_operation(sat);
36 converter.add_link(sat->get_output_socket(0), kuwahara_classic->get_input_socket(2));
37
40 converter.add_operation(sat_squared);
41 converter.map_input_socket(get_input_socket(0), sat_squared->get_input_socket(0));
42 converter.add_link(sat_squared->get_output_socket(0), kuwahara_classic->get_input_socket(3));
43
44 converter.map_output_socket(get_output_socket(0), kuwahara_classic->get_output_socket(0));
45 break;
46 }
47
49 KuwaharaAnisotropicStructureTensorOperation *structure_tensor_operation =
51 converter.add_operation(structure_tensor_operation);
53 structure_tensor_operation->get_input_socket(0));
54
55 NodeBlurData blur_data;
56 blur_data.sizex = data->uniformity;
57 blur_data.sizey = data->uniformity;
58 blur_data.relative = false;
59 blur_data.filtertype = R_FILTER_GAUSS;
60
61 GaussianXBlurOperation *blur_x_operation = new GaussianXBlurOperation();
62 blur_x_operation->set_data(&blur_data);
63 blur_x_operation->set_size(1.0f);
64
65 converter.add_operation(blur_x_operation);
66 converter.add_link(structure_tensor_operation->get_output_socket(0),
67 blur_x_operation->get_input_socket(0));
68
69 GaussianYBlurOperation *blur_y_operation = new GaussianYBlurOperation();
70 blur_y_operation->set_data(&blur_data);
71 blur_y_operation->set_size(1.0f);
72
73 converter.add_operation(blur_y_operation);
74 converter.add_link(blur_x_operation->get_output_socket(0),
75 blur_y_operation->get_input_socket(0));
76
77 KuwaharaAnisotropicOperation *kuwahara_anisotropic_operation =
79 kuwahara_anisotropic_operation->set_sharpness(data->sharpness);
80 kuwahara_anisotropic_operation->set_eccentricity(data->eccentricity);
81
82 converter.add_operation(kuwahara_anisotropic_operation);
84 kuwahara_anisotropic_operation->get_input_socket(0));
86 kuwahara_anisotropic_operation->get_input_socket(1));
87 converter.add_link(blur_y_operation->get_output_socket(0),
88 kuwahara_anisotropic_operation->get_input_socket(2));
89
91 kuwahara_anisotropic_operation->get_output_socket(0));
92
93 break;
94 }
95 }
96}
97
98} // namespace blender::compositor
@ CMP_NODE_KUWAHARA_CLASSIC
@ CMP_NODE_KUWAHARA_ANISOTROPIC
@ R_FILTER_GAUSS
Overall context of the compositor.
void convert_to_operations(NodeConverter &converter, const CompositorContext &context) const override
convert node to operation
void add_link(NodeOperationOutput *from, NodeOperationInput *to)
void map_output_socket(NodeOutput *node_socket, NodeOperationOutput *operation_socket)
void add_operation(NodeOperation *operation)
void map_input_socket(NodeInput *node_socket, NodeOperationInput *operation_socket)
NodeOperationOutput * get_output_socket(unsigned int index=0)
NodeOperationInput * get_input_socket(unsigned int index)
NodeOutput * get_output_socket(unsigned int index=0) const
Definition COM_Node.cc:85
NodeInput * get_input_socket(unsigned int index) const
Definition COM_Node.cc:90
const bNode * get_bnode() const
get the reference to the SDNA bNode struct
Definition COM_Node.h:65
SummedAreaTableOperation class computes the summed area table.