/** * @file * @brief Source file for Example Executable (example app for libopenshot) * @author Jonathan Thomas * * @ref License */ /* LICENSE * * Copyright (c) 2008-2019 OpenShot Studios, LLC * . This file is part of * OpenShot Library (libopenshot), an open-source project dedicated to * delivering high quality video editing and animation solutions to the * world. For more information visit . * * OpenShot Library (libopenshot) is free software: you can redistribute it * and/or modify it under the terms of the GNU Lesser General Public License * as published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * OpenShot Library (libopenshot) 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with OpenShot Library. If not, see . */ #include #include #include // #include // #include "../../include/CVTracker.h" // #include "../../include/CVStabilization.h" // #include "treackerdata.pb.h" #include "../../include/OpenShot.h" #include "../../include/CrashHandler.h" using namespace openshot; // using namespace cv; void trackVideo(openshot::Clip &r9){ // Opencv display window cv::namedWindow("Display Image", cv::WINDOW_NORMAL ); // Create Tracker ClipProcessingJobs clipProcessing("Track", r9); // CVTracker kcfTracker; // kcfTracker.trackClip(r9); // bool trackerInit = false; // int videoLenght = r9.Reader()->info.video_length; // for (long int frame = 0; frame < videoLenght; frame++) // { // int frame_number = frame; // std::shared_ptr f = r9.GetFrame(frame_number); // // Grab Mat image // cv::Mat cvimage = f->GetImageCV(); // if(!trackerInit){ // cv::Rect2d bbox = cv::selectROI("Display Image", cvimage); // kcfTracker.initTracker(bbox, cvimage, frame_number); // cv::rectangle(cvimage, bbox, cv::Scalar( 255, 0, 0 ), 2, 1 ); // trackerInit = true; // } // else{ // trackerInit = kcfTracker.trackFrame(cvimage, frame_number); // // Draw box on image // FrameData fd = kcfTracker.GetTrackedData(frame_number); // // std::cout<< "fd: "<< fd.x1<< " "<< fd.y1 <<" "<info.video_length; for (long int frame = 0; frame < videoLenght; frame++) { int frame_number = frame; std::shared_ptr f = r9.GetFrame(frame_number); // Grab Mat image cv::Mat cvimage = f->GetImageCV(); cv::imshow("Display Tracked result", cvimage); // Press ESC on keyboard to exit char c=(char)cv::waitKey(25); if(c==27) break; } } void displayTrackedData(openshot::Clip &r9){ // Opencv display window cv::namedWindow("Display Image", cv::WINDOW_NORMAL ); // Create Tracker CVTracker kcfTracker; // Load saved data if(!kcfTracker.LoadTrackedData("kcf_tracker.data")){ std::cout<<"Was not possible to load the tracked data\n"; return; } for (long int frame = 1200; frame <= 1600; frame++) { int frame_number = frame; std::shared_ptr f = r9.GetFrame(frame_number); // Grab Mat image cv::Mat cvimage = f->GetImageCV(); FrameData fd = kcfTracker.GetTrackedData(frame_number); cv::Rect2d box(fd.x1, fd.y1, fd.x2-fd.x1, fd.y2-fd.y1); cv::rectangle(cvimage, box, cv::Scalar( 255, 0, 0 ), 2, 1 ); cv::imshow("Display Image", cvimage); // Press ESC on keyboard to exit char c=(char)cv::waitKey(25); if(c==27) break; } } void displayStabilization(openshot::Clip &r9){ // Opencv display window cv::namedWindow("Display Image", cv::WINDOW_NORMAL ); int videoLenght = r9.Reader()->info.video_length; for (long int frame = 0; frame < videoLenght; frame++) { int frame_number = frame; std::shared_ptr f = r9.GetFrame(frame_number); // Grab Mat image cv::Mat cvimage = f->GetImageCV(); cv::imshow("Display Image", cvimage); // Press ESC on keyboard to exit char c=(char)cv::waitKey(25); if(c==27) break; } } int main(int argc, char* argv[]) { bool TRACK_DATA = false; bool LOAD_TRACKED_DATA = false; bool SMOOTH_VIDEO = true; std::string input_filepath = TEST_MEDIA_PATH; input_filepath = "/media/brenno/Data/projects/openshot/libopenshot/src/examples/test.avi"; openshot::Clip r9(input_filepath); r9.Open(); if(TRACK_DATA) trackVideo(r9); if(LOAD_TRACKED_DATA) displayTrackedData(r9); if(SMOOTH_VIDEO){ ClipProcessingJobs clipProcessing("Stabilize", r9); // CVStabilization stabilization; // r9.stabilize_video(); displayStabilization(r9); } // Close timeline r9.Close(); std::cout << "Completed successfully!" << std::endl; return 0; }