/* * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * * Copyright 2013, Blender Foundation. */ #pragma once #include #include "COM_MultiThreadedOperation.h" #include "DNA_movieclip_types.h" #include "DNA_tracking_types.h" #include "BLI_listbase.h" #include "BLI_string.h" namespace blender::compositor { #define PLANE_DISTORT_MAX_SAMPLES 64 class PlaneDistortBaseOperation : public MultiThreadedOperation { protected: struct MotionSample { float frame_space_corners[4][2]; /* Corners coordinates in pixel space. */ float perspective_matrix[3][3]; }; MotionSample samples_[PLANE_DISTORT_MAX_SAMPLES]; int motion_blur_samples_; float motion_blur_shutter_; public: PlaneDistortBaseOperation(); void set_motion_blur_samples(int samples) { BLI_assert(samples <= PLANE_DISTORT_MAX_SAMPLES); motion_blur_samples_ = samples; } void set_motion_blur_shutter(float shutter) { motion_blur_shutter_ = shutter; } virtual void calculate_corners(const float corners[4][2], bool normalized, int sample); private: friend class PlaneTrackCommon; }; class PlaneDistortWarpImageOperation : public PlaneDistortBaseOperation { protected: SocketReader *pixel_reader_; public: PlaneDistortWarpImageOperation(); void calculate_corners(const float corners[4][2], bool normalized, int sample) override; void init_execution() override; void deinit_execution() override; void execute_pixel_sampled(float output[4], float x, float y, PixelSampler sampler) override; bool determine_depending_area_of_interest(rcti *input, ReadBufferOperation *read_operation, rcti *output) override; void get_area_of_interest(int input_idx, const rcti &output_area, rcti &r_input_area) override; void update_memory_buffer_partial(MemoryBuffer *output, const rcti &area, Span inputs) override; }; class PlaneDistortMaskOperation : public PlaneDistortBaseOperation { protected: int osa_; float jitter_[32][2]; public: PlaneDistortMaskOperation(); void init_execution() override; void execute_pixel_sampled(float output[4], float x, float y, PixelSampler sampler) override; void update_memory_buffer_partial(MemoryBuffer *output, const rcti &area, Span inputs) override; private: int get_jitter_samples_inside_count(int x, int y, MotionSample &sample_data); }; } // namespace blender::compositor