23#include "RNA_prototypes.hh"
59 STRNCPY(data->tracking_object, tracking_object->
name);
85 if (tracking_object) {
87 &clip->id, &RNA_MovieTrackingObject, tracking_object);
97 if (
ELEM(node->custom1,
132 if (!should_compute_x && !should_compute_y) {
139 const float2 position = (current_marker_position - reference_marker_position) *
float2(size);
141 if (should_compute_x) {
143 result.allocate_single_value();
144 result.set_float_value(position.x);
147 if (should_compute_y) {
149 result.allocate_single_value();
150 result.set_float_value(position.y);
164 track, current_marker_position, -1);
165 const float2 speed_toward_previous = previous_marker_position - current_marker_position;
170 track, current_marker_position, 1);
171 const float2 speed_toward_next = current_marker_position - next_marker_position;
174 const float4 speed =
float4(speed_toward_previous, speed_toward_next) *
float4(size, size);
177 result.allocate_single_value();
178 result.set_vector_value(speed);
185 result.allocate_single_value();
186 result.set_float_value(0.0f);
190 result.allocate_single_value();
191 result.set_float_value(0.0f);
195 result.allocate_single_value();
196 result.set_vector_value(
float4(0.0f));
205 float2 current_marker_position,
213 return current_marker_position;
273 movie_tracking, node_storage(
bnode()).tracking_object);
274 if (!movie_tracking_object) {
279 node_storage(
bnode()).track_name);
359 ntype.
declare = file_ns::cmp_node_trackpos_declare;
360 ntype.
draw_buttons = file_ns::node_composit_buts_trackpos;
Scene * CTX_data_scene(const bContext *C)
float BKE_movieclip_remap_scene_to_clip_frame(const struct MovieClip *clip, float framenr)
void BKE_movieclip_user_set_frame(struct MovieClipUser *user, int framenr)
void BKE_movieclip_get_size(struct MovieClip *clip, const struct MovieClipUser *user, int *r_width, int *r_height)
#define NODE_STORAGE_FUNCS(StorageT)
struct MovieTrackingObject * BKE_tracking_object_get_named(struct MovieTracking *tracking, const char *name)
struct MovieTrackingMarker * BKE_tracking_marker_get(struct MovieTrackingTrack *track, int framenr)
struct MovieTrackingObject * BKE_tracking_object_get_active(const struct MovieTracking *tracking)
struct MovieTrackingMarker * BKE_tracking_marker_get_exact(struct MovieTrackingTrack *track, int framenr)
struct MovieTrackingTrack * BKE_tracking_object_find_track_with_name(struct MovieTrackingObject *tracking_object, const char *name)
#define STRNCPY(dst, src)
#define DNA_struct_default_get(struct_name)
@ CMP_NODE_TRACK_POSITION_RELATIVE_START
@ CMP_NODE_TRACK_POSITION_ABSOLUTE_FRAME
@ CMP_NODE_TRACK_POSITION_RELATIVE_FRAME
void uiItemPointerR(uiLayout *layout, PointerRNA *ptr, const char *propname, PointerRNA *searchptr, const char *searchpropname, const char *name, int icon)
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)
uiLayout * uiLayoutColumn(uiLayout *layout, bool align)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
@ UI_ITEM_R_SPLIT_EMPTY_NAME
static DBVT_INLINE btScalar size(const btDbvtVolume &a)
void execute_position(MovieTrackingTrack *track, float2 current_marker_position, int2 size)
void execute_speed(MovieTrackingTrack *track, float2 current_marker_position, int2 size)
MovieClip * get_movie_clip()
float2 compute_marker_position_at_frame(MovieTrackingTrack *track, int frame)
float2 compute_reference_marker_position(MovieTrackingTrack *track)
float2 compute_first_marker_position(MovieTrackingTrack *track)
float2 compute_temporally_neighboring_marker_position(MovieTrackingTrack *track, float2 current_marker_position, int time_delta)
MovieTrackingTrack * get_movie_tracking_track()
CMPNodeTrackPositionMode get_mode()
int get_frame_number() const
NodeOperation(Context &context, DNode node)
bool should_compute_output(StringRef identifier)
const bNode & bnode() const
Result & get_result(StringRef identifier)
Context & context() const
local_group_size(16, 16) .push_constant(Type b
void node_type_storage(bNodeType *ntype, const char *storagename, void(*freefunc)(bNode *node), void(*copyfunc)(bNodeTree *dest_ntree, bNode *dest_node, const bNode *src_node))
void node_register_type(bNodeType *ntype)
static void cmp_node_trackpos_declare(NodeDeclarationBuilder &b)
static void node_composit_buts_trackpos(uiLayout *layout, bContext *C, PointerRNA *ptr)
static NodeOperation * get_compositor_operation(Context &context, DNode node)
VecBase< float, 4 > float4
VecBase< float, 2 > float2
void register_node_type_cmp_trackpos()
void cmp_node_type_base(blender::bke::bNodeType *ntype, int type, const char *name, short nclass)
void node_free_standard_storage(bNode *node)
void node_copy_standard_storage(bNodeTree *, bNode *dest_node, const bNode *src_node)
PointerRNA RNA_pointer_create(ID *id, StructRNA *type, void *data)
struct MovieTracking tracking
MovieTrackingTrack * active_track
MovieTrackingMarker * markers
NodeGetCompositorOperationFunction get_compositor_operation
void(* draw_buttons)(uiLayout *, bContext *C, PointerRNA *ptr)
NodeDeclareFunction declare
void(* initfunc_api)(const bContext *C, PointerRNA *ptr)