Skip to content

Latest commit

 

History

History
42 lines (33 loc) · 2.79 KB

README.md

File metadata and controls

42 lines (33 loc) · 2.79 KB

Mp4ToPDF

A command line executable written in C++ that extracts 'unique' frames from a Mp4 video, exporting them as a PDF file.

Building / Compilation

Although it should work (with small changes) in other OS, compilation as here described was only tested on Windows 10.
Mp4ToPDF can be compiled with CUDA enabled or CPU only OpenCV. CUDA is recommended.
What I did and advise:

Building OpenCV With CUDA

  1. Make sure to have Microsoft Visual Studio 2019, CUDA, CMake and FFmpeg (used by OpenCV to read mp4 files) installed and correctly in Windows PATH.
  2. Git clone the OpenCV repository (chose wisely, this will end up as a huge folder).
  3. Git clone the OpenCV-Contrib repository.
  4. Create a folder inside the clonned OpenCV folder. I opted for naming it 'building_gpu'.
  5. Open a terminal (CMD) and cd to this folder.
  6. Run CMake with -D WITH_CUDA=ON and -D OPENCV_EXTRA_MODULES_PATH=[path to OpenCV-Contribe modules]. In my case it was: cmake -D WITH_CUDA=ON -D OPENCV_EXTRA_MODULES_PATH=D:/InPath/opencv_contrib/modules .. .
  7. Inside the choosed folder, open OpenCV.sln in Visual Studio.
  8. Proceed to compile in Visual Studio. This may take a while, be sure to pick Debug or Release (or both).
  9. Add [your building path]\install\x64\vc16\bin, [your building path]\bin\Debug and / or [your building path]\bin\Release to Windows Path.
  10. Done!

OpenCV Without CUDA

  1. Make sure to have Microsoft Visual Studio 2019, CMake and FFmpeg (used by OpenCV to read mp4 files) installed and correctly in Windows PATH.
  2. You should be able to use pre-compiled OpenCV binaries.

Building Mp4ToPDF

  1. After cloning this repository, edit CMakeLists.txt at set(OpenCV_DIR and find_package(OpenCV to reflect your installation PATH.
    • In order to compile without CUDA, comment the line add_compile_definitions(GPU_SSIM).
  2. Open the folder in Visual Studio as a CMake project.
  3. Compile it!

Troubleshooting

  • If it does not compile, you probably have not correctly setup CUDA or OpenCV. Make sure to compile OpenCV with CUDA support WITH_CUDA=ON.
  • CUDA is hardware dependent, check CUDA documentation for help.
  • In order to compile Mp4ToPDF without CUDA, comment the line add_compile_definitions(GPU_SSIM) in CMakeLists.txt.

Usage

When compiling Mp4ToPDF, Mp4ToPDF.exe will be created.
This file can them be used through CMD as:
Mp4ToPDF.exe inputfile.mp4 24 where the second argument is the frame skip argument. 24 means checking every 24th frame.