Blender
V3.3
|
#include <COM_ScreenLensDistortionOperation.h>
Public Member Functions | |
ScreenLensDistortionOperation () | |
void | init_data () override |
void | execute_pixel (float output[4], int x, int y, void *data) override |
void | init_execution () override |
void * | initialize_tile_data (rcti *rect) override |
void | deinit_execution () override |
void | set_fit (bool fit) |
void | set_jitter (bool jitter) |
void | set_distortion (float distortion) |
void | set_dispersion (float dispersion) |
bool | determine_depending_area_of_interest (rcti *input, ReadBufferOperation *read_operation, rcti *output) override |
void | determine_canvas (const rcti &preferred_area, rcti &r_area) override |
void | get_area_of_interest (int input_idx, const rcti &output_area, rcti &r_input_area) override |
Get input operation area being read by this operation on rendering given output area. More... | |
void | update_memory_buffer_partial (MemoryBuffer *output, const rcti &area, Span< MemoryBuffer * > inputs) override |
![]() | |
virtual | ~NodeOperation () |
void | set_name (const std::string name) |
const std::string | get_name () const |
void | set_id (const int id) |
const int | get_id () const |
float | get_constant_value_default (float default_value) |
const float * | get_constant_elem_default (const float *default_elem) |
const NodeOperationFlags | get_flags () const |
std::optional< NodeOperationHash > | generate_hash () |
unsigned int | get_number_of_input_sockets () const |
unsigned int | get_number_of_output_sockets () const |
NodeOperationOutput * | get_output_socket (unsigned int index=0) |
NodeOperationInput * | get_input_socket (unsigned int index) |
NodeOperation * | get_input_operation (int index) |
virtual bool | is_output_operation (bool) const |
is_output_operation determines whether this operation is an output of the ExecutionSystem during rendering or editing. More... | |
void | set_execution_model (const eExecutionModel model) |
void | set_bnodetree (const bNodeTree *tree) |
void | set_execution_system (ExecutionSystem *system) |
virtual void | execute_region (rcti *, unsigned int) |
when a chunk is executed by a CPUDevice, this method is called More... | |
virtual void | execute_opencl_region (OpenCLDevice *, rcti *, unsigned int, MemoryBuffer **, MemoryBuffer *) |
when a chunk is executed by an OpenCLDevice, this method is called More... | |
virtual void | execute_opencl (OpenCLDevice *, MemoryBuffer *, cl_mem, MemoryBuffer **, std::list< cl_mem > *, std::list< cl_kernel > *) |
custom handle to add new tasks to the OpenCL command queue in order to execute a chunk on an GPUDevice. More... | |
void | set_canvas (const rcti &canvas_area) |
const rcti & | get_canvas () const |
void | unset_canvas () |
virtual bool | is_active_viewer_output () const |
is this operation the active viewer output user can select an ViewerNode to be active (the result of this node will be drawn on the backdrop). More... | |
void | set_canvas_input_index (unsigned int index) |
set the index of the input socket that will determine the canvas of this operation More... | |
void | set_determined_canvas_modifier (std::function< void(rcti &canvas)> fn) |
virtual eCompositorPriority | get_render_priority () const |
get the render priority of this node. More... | |
bool | is_braked () const |
void | update_draw () |
unsigned int | get_width () const |
unsigned int | get_height () const |
void | read_sampled (float result[4], float x, float y, PixelSampler sampler) |
void | read_filtered (float result[4], float x, float y, float dx[2], float dy[2]) |
void | read (float result[4], int x, int y, void *chunk_data) |
virtual void | deinitialize_tile_data (rcti *, void *) |
virtual MemoryBuffer * | get_input_memory_buffer (MemoryBuffer **) |
virtual std::unique_ptr< MetaData > | get_meta_data () |
void | render (MemoryBuffer *output_buf, Span< rcti > areas, Span< MemoryBuffer * > inputs_bufs) |
virtual void | update_memory_buffer (MemoryBuffer *UNUSED(output), const rcti &UNUSED(area), Span< MemoryBuffer * > UNUSED(inputs)) |
void | get_area_of_interest (NodeOperation *input_op, const rcti &output_area, rcti &r_input_area) |
Definition at line 13 of file COM_ScreenLensDistortionOperation.h.
blender::compositor::ScreenLensDistortionOperation::ScreenLensDistortionOperation | ( | ) |
Definition at line 14 of file COM_ScreenLensDistortionOperation.cc.
References blender::compositor::NodeOperation::add_input_socket(), blender::compositor::NodeOperation::add_output_socket(), blender::compositor::Color, blender::compositor::NodeOperationFlags::complex, blender::compositor::NodeOperation::flags_, and blender::compositor::Value.
|
overridevirtual |
Deinitialize the execution
Reimplemented from blender::compositor::NodeOperation.
Definition at line 216 of file COM_ScreenLensDistortionOperation.cc.
References BLI_rng_free(), and blender::compositor::NodeOperation::deinit_mutex().
|
overridevirtual |
Reimplemented from blender::compositor::NodeOperation.
Definition at line 369 of file COM_ScreenLensDistortionOperation.cc.
References BLI_rcti_translate(), blender::compositor::NodeOperation::determine_canvas(), blender::compositor::NodeOperation::execution_model_, blender::compositor::FullFrame, blender::compositor::NodeOperation::set_determined_canvas_modifier(), rcti::xmin, and rcti::ymin.
|
overridevirtual |
Reimplemented from blender::compositor::NodeOperation.
Definition at line 238 of file COM_ScreenLensDistortionOperation.cc.
References BLI_rcti_init_minmax(), blender::compositor::NodeOperation::determine_depending_area_of_interest(), blender::compositor::NodeOperation::get_height(), blender::compositor::NodeOperation::get_input_operation(), blender::compositor::NodeOperation::get_width(), input, output, rcti::xmax, rcti::xmin, rcti::ymax, and rcti::ymin.
|
overridevirtual |
The inner loop of this operation.
Reimplemented from blender::compositor::NodeOperation.
Definition at line 178 of file COM_ScreenLensDistortionOperation.cc.
References buffer, count, data, float(), len_squared_v2(), output, sum(), x, xy, y, and zero_v4().
|
overridevirtual |
Get input operation area being read by this operation on rendering given output area.
Implementation don't need to ensure r_input_area is within input operation bounds. The caller must clamp it. TODO: See if it's possible to use parameter overloading (input_id for example).
input_idx | Input operation index for which we want to calculate the area being read. |
output_area | Area being rendered by this operation. |
r_input_area | Returned input operation area that needs to be read in order to render given output area. |
Reimplemented from blender::compositor::NodeOperation.
Definition at line 386 of file COM_ScreenLensDistortionOperation.cc.
References BLI_rcti_init_minmax(), blender::compositor::COM_CONSTANT_INPUT_AREA_OF_INTEREST, blender::compositor::NodeOperation::get_input_operation(), image(), input, output, rcti::xmax, rcti::xmin, rcti::ymax, and rcti::ymin.
|
overridevirtual |
Initializes operation data needed after operations are linked and resolutions determined. For rendering heap memory data use init_execution().
Reimplemented from blender::compositor::NodeOperation.
Definition at line 41 of file COM_ScreenLensDistortionOperation.cc.
References blender::compositor::NodeOperation::execution_model_, float(), blender::compositor::FullFrame, blender::compositor::NodeOperation::get_flags(), blender::compositor::NodeOperation::get_height(), blender::compositor::NodeOperation::get_input_operation(), blender::compositor::NodeOperation::get_width(), blender::compositor::NodeOperationFlags::is_constant_operation, and blender::compositor::Tiled.
|
overridevirtual |
Initialize the execution
Reimplemented from blender::compositor::NodeOperation.
Definition at line 70 of file COM_ScreenLensDistortionOperation.cc.
References BLI_rng_new(), blender::compositor::NodeOperation::get_input_socket_reader(), blender::compositor::NodeOperation::init_mutex(), PIL_check_seconds_timer_i(), POINTER_AS_INT, and UINT_MAX.
|
overridevirtual |
Reimplemented from blender::compositor::NodeOperation.
Definition at line 80 of file COM_ScreenLensDistortionOperation.cc.
References buffer, blender::compositor::NodeOperation::get_input_socket_reader(), blender::compositor::NodeOperation::initialize_tile_data(), blender::compositor::NodeOperation::lock_mutex(), blender::compositor::Nearest, blender::compositor::NodeOperation::read_sampled(), result, and blender::compositor::NodeOperation::unlock_mutex().
Set constant dispersion value
Definition at line 35 of file COM_ScreenLensDistortionOperation.cc.
Referenced by blender::compositor::LensDistortionNode::convert_to_operations().
Set constant distortion value
Definition at line 29 of file COM_ScreenLensDistortionOperation.cc.
Referenced by blender::compositor::LensDistortionNode::convert_to_operations().
Definition at line 56 of file COM_ScreenLensDistortionOperation.h.
Referenced by blender::compositor::LensDistortionNode::convert_to_operations().
Definition at line 60 of file COM_ScreenLensDistortionOperation.h.
Referenced by blender::compositor::LensDistortionNode::convert_to_operations().
|
overridevirtual |
Executes operation updating a memory buffer area. Multi-threaded calls.
Implements blender::compositor::MultiThreadedOperation.
Definition at line 482 of file COM_ScreenLensDistortionOperation.cc.
References blender::compositor::area(), count, float(), inputs, len_squared_v2(), output, sum(), xy, and zero_v4().