1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
/* SPDX-License-Identifier: GPL-2.0-or-later
* Copyright 2011 Blender Foundation. */
#include "COM_GlareBaseOperation.h"
namespace blender::compositor {
GlareBaseOperation::GlareBaseOperation()
{
this->add_input_socket(DataType::Color);
this->add_output_socket(DataType::Color);
settings_ = nullptr;
flags_.is_fullframe_operation = true;
is_output_rendered_ = false;
}
void GlareBaseOperation::init_execution()
{
SingleThreadedOperation::init_execution();
input_program_ = get_input_socket_reader(0);
}
void GlareBaseOperation::deinit_execution()
{
input_program_ = nullptr;
SingleThreadedOperation::deinit_execution();
}
MemoryBuffer *GlareBaseOperation::create_memory_buffer(rcti *rect2)
{
MemoryBuffer *tile = (MemoryBuffer *)input_program_->initialize_tile_data(rect2);
rcti rect;
rect.xmin = 0;
rect.ymin = 0;
rect.xmax = get_width();
rect.ymax = get_height();
MemoryBuffer *result = new MemoryBuffer(DataType::Color, rect);
float *data = result->get_buffer();
this->generate_glare(data, tile, settings_);
return result;
}
bool GlareBaseOperation::determine_depending_area_of_interest(rcti * /*input*/,
ReadBufferOperation *read_operation,
rcti *output)
{
if (is_cached()) {
return false;
}
rcti new_input;
new_input.xmax = this->get_width();
new_input.xmin = 0;
new_input.ymax = this->get_height();
new_input.ymin = 0;
return NodeOperation::determine_depending_area_of_interest(&new_input, read_operation, output);
}
void GlareBaseOperation::get_area_of_interest(const int input_idx,
const rcti &UNUSED(output_area),
rcti &r_input_area)
{
BLI_assert(input_idx == 0);
UNUSED_VARS_NDEBUG(input_idx);
r_input_area.xmin = 0;
r_input_area.xmax = this->get_width();
r_input_area.ymin = 0;
r_input_area.ymax = this->get_height();
}
void GlareBaseOperation::update_memory_buffer(MemoryBuffer *output,
const rcti &UNUSED(area),
Span<MemoryBuffer *> inputs)
{
if (!is_output_rendered_) {
MemoryBuffer *input = inputs[0];
const bool is_input_inflated = input->is_a_single_elem();
if (is_input_inflated) {
input = input->inflate();
}
this->generate_glare(output->get_buffer(), input, settings_);
is_output_rendered_ = true;
if (is_input_inflated) {
delete input;
}
}
}
} // namespace blender::compositor
|