diff options
author | Sergey Sharybin <sergey.vfx@gmail.com> | 2014-01-28 16:01:03 +0400 |
---|---|---|
committer | Sergey Sharybin <sergey.vfx@gmail.com> | 2014-01-28 16:02:22 +0400 |
commit | be6643b5ec01c8f64a1065762c38ce8803b717c0 (patch) | |
tree | ec8ffa055277aba2b1fecc636efde0a84140fc35 /source/blender/blenkernel/intern/tracking.c | |
parent | c2da706a36ca355509d9dc2abcffc1edc6c49fff (diff) |
Followup to the previous commit
Need to take weight into account when drawing per-frame track
reprojection curve and when computing per-track average error.
Diffstat (limited to 'source/blender/blenkernel/intern/tracking.c')
-rw-r--r-- | source/blender/blenkernel/intern/tracking.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/source/blender/blenkernel/intern/tracking.c b/source/blender/blenkernel/intern/tracking.c index e01909322eb..ab314d8b148 100644 --- a/source/blender/blenkernel/intern/tracking.c +++ b/source/blender/blenkernel/intern/tracking.c @@ -864,6 +864,23 @@ float *BKE_tracking_track_get_mask(int frame_width, int frame_height, return mask; } +float BKE_tracking_track_get_weight_for_marker(MovieClip *clip, MovieTrackingTrack *track, MovieTrackingMarker *marker) +{ + FCurve *weight_fcurve; + float weight = track->weight; + + weight_fcurve = id_data_find_fcurve(&clip->id, track, &RNA_MovieTrackingTrack, + "weight", 0, NULL); + + if (weight_fcurve) { + int scene_framenr = + BKE_movieclip_remap_clip_to_scene_frame(clip, marker->framenr); + weight = evaluate_fcurve(weight_fcurve, scene_framenr); + } + + return weight; +} + /* area - which part of marker should be selected. see TRACK_AREA_* constants */ void BKE_tracking_track_select(ListBase *tracksbase, MovieTrackingTrack *track, int area, bool extend) { |