2021-04-20 23:07:23 -03:00
|
|
|
/**
|
|
|
|
|
* @file
|
|
|
|
|
* @brief Source file for ClipProcessingJobs class
|
|
|
|
|
* @author Jonathan Thomas <jonathan@openshot.org>
|
|
|
|
|
* @author Brenno Caldato <brenno.caldato@outlook.com>
|
|
|
|
|
*
|
|
|
|
|
* @ref License
|
|
|
|
|
*/
|
|
|
|
|
|
2021-10-16 01:26:26 -04:00
|
|
|
// Copyright (c) 2008-2019 OpenShot Studios, LLC
|
|
|
|
|
//
|
|
|
|
|
// SPDX-License-Identifier: LGPL-3.0-or-later
|
2021-04-20 23:07:23 -03:00
|
|
|
|
2020-10-20 01:04:59 -03:00
|
|
|
#include "ClipProcessingJobs.h"
|
2020-07-08 11:49:46 -03:00
|
|
|
|
2021-05-04 07:33:47 -04:00
|
|
|
namespace openshot {
|
|
|
|
|
|
2020-07-09 20:26:01 -03:00
|
|
|
// Constructor responsible to choose processing type and apply to clip
|
2021-05-04 07:33:47 -04:00
|
|
|
ClipProcessingJobs::ClipProcessingJobs(std::string processingType, std::string processInfoJson) :
|
2020-07-16 21:10:02 -03:00
|
|
|
processingType(processingType), processInfoJson(processInfoJson){
|
|
|
|
|
}
|
2020-07-08 11:49:46 -03:00
|
|
|
|
2020-11-01 20:02:46 -03:00
|
|
|
void ClipProcessingJobs::processClip(Clip& clip, std::string json){
|
|
|
|
|
processInfoJson = json;
|
2020-07-08 11:49:46 -03:00
|
|
|
|
2020-07-16 21:10:02 -03:00
|
|
|
// Process clip and save processed data
|
|
|
|
|
if(processingType == "Stabilizer"){
|
|
|
|
|
t = std::thread(&ClipProcessingJobs::stabilizeClip, this, std::ref(clip), std::ref(this->processingController));
|
|
|
|
|
}
|
|
|
|
|
if(processingType == "Tracker"){
|
|
|
|
|
t = std::thread(&ClipProcessingJobs::trackClip, this, std::ref(clip), std::ref(this->processingController));
|
|
|
|
|
}
|
2022-06-21 11:30:30 -05:00
|
|
|
if(processingType == "ObjectDetection"){
|
2020-07-26 16:19:55 -03:00
|
|
|
t = std::thread(&ClipProcessingJobs::detectObjectsClip, this, std::ref(clip), std::ref(this->processingController));
|
|
|
|
|
}
|
2020-07-08 11:49:46 -03:00
|
|
|
}
|
|
|
|
|
|
2021-05-04 07:33:47 -04:00
|
|
|
// Apply object tracking to clip
|
2020-07-16 21:10:02 -03:00
|
|
|
void ClipProcessingJobs::trackClip(Clip& clip, ProcessingController& controller){
|
2020-07-08 11:49:46 -03:00
|
|
|
|
2020-07-09 20:26:01 -03:00
|
|
|
// Create CVTracker object
|
2020-07-16 21:10:02 -03:00
|
|
|
CVTracker tracker(processInfoJson, controller);
|
2020-07-09 20:26:01 -03:00
|
|
|
// Start tracking
|
2020-07-16 21:10:02 -03:00
|
|
|
tracker.trackClip(clip);
|
|
|
|
|
|
|
|
|
|
// Thread controller. If effect processing is done, save data
|
|
|
|
|
// Else, kill thread
|
|
|
|
|
if(controller.ShouldStop()){
|
|
|
|
|
controller.SetFinished(true);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
// Save stabilization data
|
|
|
|
|
tracker.SaveTrackedData();
|
|
|
|
|
// tells to UI that the processing finished
|
|
|
|
|
controller.SetFinished(true);
|
|
|
|
|
}
|
2020-07-08 11:49:46 -03:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-28 21:01:57 -03:00
|
|
|
// Apply object detection to clip
|
2020-07-26 16:19:55 -03:00
|
|
|
void ClipProcessingJobs::detectObjectsClip(Clip& clip, ProcessingController& controller){
|
2020-07-28 21:01:57 -03:00
|
|
|
// create CVObjectDetection object
|
2021-05-04 07:33:47 -04:00
|
|
|
CVObjectDetection objDetector(processInfoJson, controller);
|
2020-07-28 21:01:57 -03:00
|
|
|
// Start object detection process
|
2020-07-26 16:19:55 -03:00
|
|
|
objDetector.detectObjectsClip(clip);
|
|
|
|
|
|
|
|
|
|
// Thread controller. If effect processing is done, save data
|
|
|
|
|
// Else, kill thread
|
|
|
|
|
if(controller.ShouldStop()){
|
|
|
|
|
controller.SetFinished(true);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else{
|
2020-07-28 21:01:57 -03:00
|
|
|
// Save object detection data
|
2020-07-30 21:39:20 -03:00
|
|
|
objDetector.SaveObjDetectedData();
|
2020-07-26 16:19:55 -03:00
|
|
|
// tells to UI that the processing finished
|
|
|
|
|
controller.SetFinished(true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void ClipProcessingJobs::stabilizeClip(Clip& clip, ProcessingController& controller){
|
|
|
|
|
// create CVStabilization object
|
2021-05-04 07:33:47 -04:00
|
|
|
CVStabilization stabilizer(processInfoJson, controller);
|
2020-07-09 20:26:01 -03:00
|
|
|
// Start stabilization process
|
2020-07-16 21:10:02 -03:00
|
|
|
stabilizer.stabilizeClip(clip);
|
2020-07-08 11:49:46 -03:00
|
|
|
|
2020-07-16 21:10:02 -03:00
|
|
|
// Thread controller. If effect processing is done, save data
|
|
|
|
|
// Else, kill thread
|
|
|
|
|
if(controller.ShouldStop()){
|
|
|
|
|
controller.SetFinished(true);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
// Save stabilization data
|
|
|
|
|
stabilizer.SaveStabilizedData();
|
|
|
|
|
// tells to UI that the processing finished
|
|
|
|
|
controller.SetFinished(true);
|
|
|
|
|
}
|
2020-07-15 10:29:08 -03:00
|
|
|
}
|
2020-07-08 11:49:46 -03:00
|
|
|
|
2021-05-04 07:33:47 -04:00
|
|
|
// Get processing progress while iterating on the clip
|
2020-07-15 10:29:08 -03:00
|
|
|
int ClipProcessingJobs::GetProgress(){
|
2020-07-16 21:10:02 -03:00
|
|
|
|
|
|
|
|
return (int)processingController.GetProgress();
|
2020-07-15 10:29:08 -03:00
|
|
|
}
|
|
|
|
|
|
2021-05-04 07:33:47 -04:00
|
|
|
// Check if processing finished
|
2020-07-16 21:10:02 -03:00
|
|
|
bool ClipProcessingJobs::IsDone(){
|
|
|
|
|
|
|
|
|
|
if(processingController.GetFinished()){
|
|
|
|
|
t.join();
|
|
|
|
|
}
|
|
|
|
|
return processingController.GetFinished();
|
|
|
|
|
}
|
2020-07-15 10:29:08 -03:00
|
|
|
|
2020-11-01 20:02:46 -03:00
|
|
|
// stop preprocessing before finishing it
|
2020-07-15 10:29:08 -03:00
|
|
|
void ClipProcessingJobs::CancelProcessing(){
|
2020-07-16 21:10:02 -03:00
|
|
|
processingController.CancelProcessing();
|
2020-11-01 20:02:46 -03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// check if there is an error with the config
|
|
|
|
|
bool ClipProcessingJobs::GetError(){
|
|
|
|
|
return processingController.GetError();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// get the error message
|
|
|
|
|
std::string ClipProcessingJobs::GetErrorMessage(){
|
|
|
|
|
return processingController.GetErrorMessage();
|
2021-05-04 07:33:47 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace openshot
|