Blender V4.3
node_composite_stabilize2d.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2011 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
9#include "BLI_assert.h"
11#include "BLI_math_matrix.hh"
14
15#include "UI_interface.hh"
16#include "UI_resources.hh"
17
18#include "DNA_movieclip_types.h"
19#include "DNA_node_types.h"
20
21#include "BKE_context.hh"
22#include "BKE_lib_id.hh"
23#include "BKE_movieclip.h"
24#include "BKE_tracking.h"
25
27#include "COM_node_operation.hh"
28
30
31/* **************** Stabilize 2D ******************** */
32
34
36{
37 b.add_input<decl::Color>("Image")
38 .default_value({0.8f, 0.8f, 0.8f, 1.0f})
39 .compositor_domain_priority(0);
40 b.add_output<decl::Color>("Image");
41}
42
43static void init(const bContext *C, PointerRNA *ptr)
44{
45 bNode *node = (bNode *)ptr->data;
46 Scene *scene = CTX_data_scene(C);
47
48 node->id = (ID *)scene->clip;
49 id_us_plus(node->id);
50
51 /* Default to bi-linear, see node_sampler_type_items in `rna_nodetree.cc`. */
52 node->custom1 = 1;
53}
54
56{
57 bNode *node = (bNode *)ptr->data;
58
59 uiTemplateID(layout, C, ptr, "clip", nullptr, "CLIP_OT_open", nullptr);
60
61 if (!node->id) {
62 return;
63 }
64
65 uiItemR(layout, ptr, "filter_type", UI_ITEM_R_SPLIT_EMPTY_NAME, "", ICON_NONE);
66 uiItemR(layout, ptr, "invert", UI_ITEM_R_SPLIT_EMPTY_NAME, nullptr, ICON_NONE);
67}
68
69using namespace blender::realtime_compositor;
70
72 public:
74
75 void execute() override
76 {
77 Result &input = get_input("Image");
78 Result &output = get_result("Image");
79
80 MovieClip *movie_clip = get_movie_clip();
81 if (input.is_single_value() || !movie_clip) {
82 input.pass_through(output);
83 return;
84 }
85
86 const int width = input.domain().size.x;
87 const int height = input.domain().size.y;
88 const int frame_number = BKE_movieclip_remap_scene_to_clip_frame(movie_clip,
89 context().get_frame_number());
90
91 float2 translation;
92 float scale, rotation;
94 movie_clip, frame_number, width, height, translation, &scale, &rotation);
95
97 translation, math::AngleRadian(rotation), float2(scale));
99 transformation = math::invert(transformation);
100 }
101
102 RealizationOptions realization_options = input.get_realization_options();
103 realization_options.interpolation = get_interpolation();
104
105 transform(context(), input, output, transformation, realization_options);
106 }
107
109 {
110 switch (static_cast<CMPNodeInterpolation>(bnode().custom1)) {
112 return Interpolation::Nearest;
114 return Interpolation::Bilinear;
116 return Interpolation::Bicubic;
117 }
118
120 return Interpolation::Nearest;
121 }
122
127
129 {
130 return (MovieClip *)bnode().id;
131 }
132};
133
135{
136 return new Stabilize2DOperation(context, node);
137}
138
139} // namespace blender::nodes::node_composite_stabilize2d_cc
140
142{
144
145 static blender::bke::bNodeType ntype;
146
147 cmp_node_type_base(&ntype, CMP_NODE_STABILIZE2D, "Stabilize 2D", NODE_CLASS_DISTORT);
148 ntype.declare = file_ns::cmp_node_stabilize2d_declare;
149 ntype.draw_buttons = file_ns::node_composit_buts_stabilize2d;
150 ntype.initfunc_api = file_ns::init;
151 ntype.get_compositor_operation = file_ns::get_compositor_operation;
152
154}
Scene * CTX_data_scene(const bContext *C)
void id_us_plus(ID *id)
Definition lib_id.cc:351
float BKE_movieclip_remap_scene_to_clip_frame(const struct MovieClip *clip, float framenr)
#define NODE_CLASS_DISTORT
Definition BKE_node.hh:412
void BKE_tracking_stabilization_data_get(struct MovieClip *clip, int framenr, int width, int height, float translation[2], float *scale, float *angle)
#define BLI_assert_unreachable()
Definition BLI_assert.h:97
CMPNodeInterpolation
@ CMP_NODE_INTERPOLATION_NEAREST
@ CMP_NODE_INTERPOLATION_BILINEAR
@ CMP_NODE_INTERPOLATION_BICUBIC
@ CMP_NODE_STABILIZE_FLAG_INVERSE
void uiTemplateID(uiLayout *layout, const bContext *C, PointerRNA *ptr, const char *propname, const char *newop, const char *openop, const char *unlinkop, int filter=UI_TEMPLATE_ID_FILTER_ALL, bool live_icon=false, const char *text=nullptr)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
@ UI_ITEM_R_SPLIT_EMPTY_NAME
void init()
NodeOperation(Context &context, DNode node)
Result & get_input(StringRef identifier) const
Definition operation.cc:144
Result & get_result(StringRef identifier)
Definition operation.cc:46
local_group_size(16, 16) .push_constant(Type b
void node_register_type(bNodeType *ntype)
Definition node.cc:1708
CartesianBasis invert(const CartesianBasis &basis)
MatT from_loc_rot_scale(const typename MatT::loc_type &location, const RotationT &rotation, const VecBase< typename MatT::base_type, ScaleDim > &scale)
static void node_composit_buts_stabilize2d(uiLayout *layout, bContext *C, PointerRNA *ptr)
static NodeOperation * get_compositor_operation(Context &context, DNode node)
static void cmp_node_stabilize2d_declare(NodeDeclarationBuilder &b)
void transform(Context &context, Result &input, Result &output, const float3x3 &transformation, RealizationOptions realization_options)
VecBase< float, 2 > float2
void register_node_type_cmp_stabilize2d()
void cmp_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
Definition DNA_ID.h:413
void * data
Definition RNA_types.hh:42
struct ID * id
int16_t custom2
Defines a node type.
Definition BKE_node.hh:218
NodeGetCompositorOperationFunction get_compositor_operation
Definition BKE_node.hh:324
void(* draw_buttons)(uiLayout *, bContext *C, PointerRNA *ptr)
Definition BKE_node.hh:238
NodeDeclareFunction declare
Definition BKE_node.hh:347
void(* initfunc_api)(const bContext *C, PointerRNA *ptr)
Definition BKE_node.hh:280
PointerRNA * ptr
Definition wm_files.cc:4126