| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2011 Blender Foundation. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup bke | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This file contains declarations of function which are used | 
					
						
							|  |  |  |  * by multiple tracking files but which should not be public. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-01-12 22:05:24 +11:00
										 |  |  | #ifndef __TRACKING_PRIVATE_H__
 | 
					
						
							|  |  |  | #define __TRACKING_PRIVATE_H__
 | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-13 18:31:02 +06:00
										 |  |  | #include "BLI_threads.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 15:07:49 +01:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | struct GHash; | 
					
						
							|  |  |  | struct MovieTracking; | 
					
						
							|  |  |  | struct MovieTrackingMarker; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-02-20 19:41:05 +06:00
										 |  |  | struct libmv_CameraIntrinsicsOptions; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | /*********************** Tracks map *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct TracksMap { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   char object_name[MAX_NAME]; | 
					
						
							|  |  |  |   bool is_camera; | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   int num_tracks; | 
					
						
							|  |  |  |   int customdata_size; | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   char *customdata; | 
					
						
							|  |  |  |   MovieTrackingTrack *tracks; | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   struct GHash *hash; | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   int ptr; | 
					
						
							| 
									
										
										
										
											2014-02-13 18:31:02 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Spin lock is used to sync context during tracking. */ | 
					
						
							|  |  |  |   SpinLock spin_lock; | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | } TracksMap; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | struct TracksMap *tracks_map_new(const char *object_name, | 
					
						
							|  |  |  |                                  bool is_camera, | 
					
						
							|  |  |  |                                  int num_tracks, | 
					
						
							|  |  |  |                                  int customdata_size); | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | int tracks_map_get_size(struct TracksMap *map); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracks_map_get_indexed_element(struct TracksMap *map, | 
					
						
							|  |  |  |                                     int index, | 
					
						
							|  |  |  |                                     struct MovieTrackingTrack **track, | 
					
						
							|  |  |  |                                     void **customdata); | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | void tracks_map_insert(struct TracksMap *map, struct MovieTrackingTrack *track, void *customdata); | 
					
						
							|  |  |  | void tracks_map_free(struct TracksMap *map, void (*customdata_free)(void *customdata)); | 
					
						
							|  |  |  | void tracks_map_merge(struct TracksMap *map, struct MovieTracking *tracking); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*********************** Space transformation functions *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracking_get_search_origin_frame_pixel(int frame_width, | 
					
						
							|  |  |  |                                             int frame_height, | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  |                                             const struct MovieTrackingMarker *marker, | 
					
						
							|  |  |  |                                             float frame_pixel[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracking_get_marker_coords_for_tracking(int frame_width, | 
					
						
							|  |  |  |                                              int frame_height, | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  |                                              const struct MovieTrackingMarker *marker, | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |                                              double search_pixel_x[5], | 
					
						
							|  |  |  |                                              double search_pixel_y[5]); | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracking_set_marker_coords_from_tracking(int frame_width, | 
					
						
							|  |  |  |                                               int frame_height, | 
					
						
							|  |  |  |                                               struct MovieTrackingMarker *marker, | 
					
						
							|  |  |  |                                               const double search_pixel_x[5], | 
					
						
							|  |  |  |                                               const double search_pixel_y[5]); | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*********************** General purpose utility functions *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracking_marker_insert_disabled(struct MovieTrackingTrack *track, | 
					
						
							|  |  |  |                                      const struct MovieTrackingMarker *ref_marker, | 
					
						
							|  |  |  |                                      bool before, | 
					
						
							|  |  |  |                                      bool overwrite); | 
					
						
							| 
									
										
										
										
											2013-12-30 17:03:59 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracking_cameraIntrinscisOptionsFromTracking( | 
					
						
							|  |  |  |     struct MovieTracking *tracking, | 
					
						
							|  |  |  |     int calibration_width, | 
					
						
							|  |  |  |     int calibration_height, | 
					
						
							|  |  |  |     struct libmv_CameraIntrinsicsOptions *camera_intrinsics_options); | 
					
						
							| 
									
										
										
										
											2014-02-20 19:41:05 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracking_trackingCameraFromIntrinscisOptions( | 
					
						
							|  |  |  |     struct MovieTracking *tracking, | 
					
						
							|  |  |  |     const struct libmv_CameraIntrinsicsOptions *camera_intrinsics_options); | 
					
						
							| 
									
										
										
										
											2014-02-20 19:41:05 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-22 20:19:48 +06:00
										 |  |  | struct libmv_TrackRegionOptions; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | void tracking_configure_tracker(const MovieTrackingTrack *track, | 
					
						
							|  |  |  |                                 float *mask, | 
					
						
							| 
									
										
										
										
											2014-06-22 20:19:48 +06:00
										 |  |  |                                 struct libmv_TrackRegionOptions *options); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | struct MovieTrackingMarker *tracking_get_keyframed_marker(struct MovieTrackingTrack *track, | 
					
						
							|  |  |  |                                                           int current_frame, | 
					
						
							|  |  |  |                                                           bool backwards); | 
					
						
							| 
									
										
										
										
											2014-06-22 20:19:48 +06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-05-26 15:21:15 +02:00
										 |  |  | /*********************** Masking *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | float *tracking_track_get_mask_for_region(int frame_width, | 
					
						
							|  |  |  |                                           int frame_height, | 
					
						
							| 
									
										
										
										
											2017-05-26 15:21:15 +02:00
										 |  |  |                                           const float region_min[2], | 
					
						
							|  |  |  |                                           const float region_max[2], | 
					
						
							|  |  |  |                                           MovieTrackingTrack *track); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-22 20:19:48 +06:00
										 |  |  | /*********************** Frame accessr *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct libmv_FrameAccessor; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MAX_ACCESSOR_CLIP 64
 | 
					
						
							|  |  |  | typedef struct TrackingImageAccessor { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   struct MovieCache *cache; | 
					
						
							|  |  |  |   struct MovieClip *clips[MAX_ACCESSOR_CLIP]; | 
					
						
							|  |  |  |   int num_clips; | 
					
						
							|  |  |  |   struct MovieTrackingTrack **tracks; | 
					
						
							|  |  |  |   int num_tracks; | 
					
						
							|  |  |  |   int start_frame; | 
					
						
							|  |  |  |   struct libmv_FrameAccessor *libmv_accessor; | 
					
						
							|  |  |  |   SpinLock cache_lock; | 
					
						
							| 
									
										
										
										
											2014-06-22 20:19:48 +06:00
										 |  |  | } TrackingImageAccessor; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TrackingImageAccessor *tracking_image_accessor_new(MovieClip *clips[MAX_ACCESSOR_CLIP], | 
					
						
							|  |  |  |                                                    int num_clips, | 
					
						
							| 
									
										
										
										
											2017-05-26 15:21:15 +02:00
										 |  |  |                                                    MovieTrackingTrack **tracks, | 
					
						
							|  |  |  |                                                    int num_tracks, | 
					
						
							| 
									
										
										
										
											2014-06-22 20:19:48 +06:00
										 |  |  |                                                    int start_frame); | 
					
						
							|  |  |  | void tracking_image_accessor_destroy(TrackingImageAccessor *accessor); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-02 15:07:49 +01:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | #endif /* __TRACKING_PRIVATE_H__ */
 |