early-access version 2853
This commit is contained in:
12
externals/vcpkg/ports/opencv3/0001-disable-downloading.patch
vendored
Executable file
12
externals/vcpkg/ports/opencv3/0001-disable-downloading.patch
vendored
Executable file
@@ -0,0 +1,12 @@
|
||||
--- a/cmake/OpenCVDownload.cmake
|
||||
+++ b/cmake/OpenCVDownload.cmake
|
||||
@@ -157,6 +157,9 @@ function(ocv_download)
|
||||
# Download
|
||||
if(NOT EXISTS "${CACHE_CANDIDATE}")
|
||||
ocv_download_log("#cmake_download \"${CACHE_CANDIDATE}\" \"${DL_URL}\"")
|
||||
+ string(REPLACE "${OPENCV_DOWNLOAD_PATH}/" "opencv-cache/" CACHE_SUBPATH "${CACHE_CANDIDATE}")
|
||||
+ message(FATAL_ERROR " Downloads are not permitted during configure. Please pre-download the file \"${CACHE_CANDIDATE}\":\n \n vcpkg_download_distfile(OCV_DOWNLOAD\n URLS \"${DL_URL}\"\n FILENAME \"${CACHE_SUBPATH}\"\n SHA512 0\n )")
|
||||
+
|
||||
foreach(try ${OPENCV_DOWNLOAD_TRIES_LIST})
|
||||
ocv_download_log("#try ${try}")
|
||||
file(DOWNLOAD "${DL_URL}" "${CACHE_CANDIDATE}"
|
||||
59
externals/vcpkg/ports/opencv3/0002-install-options.patch
vendored
Executable file
59
externals/vcpkg/ports/opencv3/0002-install-options.patch
vendored
Executable file
@@ -0,0 +1,59 @@
|
||||
--- a/CMakeLists.txt
|
||||
+++ b/CMakeLists.txt
|
||||
@@ -607,7 +607,7 @@ endif()
|
||||
ocv_cmake_hook(POST_CMAKE_BUILD_OPTIONS)
|
||||
|
||||
# --- Python Support ---
|
||||
-if(NOT IOS)
|
||||
+if(WITH_PYTHON)
|
||||
include(cmake/OpenCVDetectPython.cmake)
|
||||
endif()
|
||||
|
||||
--- a/cmake/OpenCVCompilerOptions.cmake
|
||||
+++ b/cmake/OpenCVCompilerOptions.cmake
|
||||
@@ -284,7 +284,6 @@ if(MSVC)
|
||||
#endif()
|
||||
|
||||
if(BUILD_WITH_DEBUG_INFO)
|
||||
- set(OPENCV_EXTRA_FLAGS_RELEASE "${OPENCV_EXTRA_FLAGS_RELEASE} /Zi")
|
||||
set(OPENCV_EXTRA_EXE_LINKER_FLAGS_RELEASE "${OPENCV_EXTRA_EXE_LINKER_FLAGS_RELEASE} /debug")
|
||||
set(OPENCV_EXTRA_SHARED_LINKER_FLAGS_RELEASE "${OPENCV_EXTRA_SHARED_LINKER_FLAGS_RELEASE} /debug")
|
||||
set(OPENCV_EXTRA_MODULE_LINKER_FLAGS_RELEASE "${OPENCV_EXTRA_MODULE_LINKER_FLAGS_RELEASE} /debug")
|
||||
--- a/cmake/OpenCVGenConfig.cmake
|
||||
+++ b/cmake/OpenCVGenConfig.cmake
|
||||
@@ -109,11 +109,11 @@ function(ocv_gen_config TMP_DIR NESTED_PATH ROOT_NAME)
|
||||
endif()
|
||||
endfunction()
|
||||
|
||||
-if((CMAKE_HOST_SYSTEM_NAME MATCHES "Linux" OR UNIX) AND NOT ANDROID)
|
||||
+if(TRUE)
|
||||
ocv_gen_config("${CMAKE_BINARY_DIR}/unix-install" "" "")
|
||||
endif()
|
||||
|
||||
-if(ANDROID)
|
||||
+if(FALSE)
|
||||
ocv_gen_config("${CMAKE_BINARY_DIR}/unix-install" "abi-${ANDROID_NDK_ABI_NAME}" "OpenCVConfig.root-ANDROID.cmake.in")
|
||||
install(FILES "${OpenCV_SOURCE_DIR}/platforms/android/android.toolchain.cmake" DESTINATION "${OPENCV_CONFIG_INSTALL_PATH}" COMPONENT dev)
|
||||
endif()
|
||||
@@ -121,7 +121,7 @@ endif()
|
||||
# --------------------------------------------------------------------------------------------
|
||||
# Part 3/3: ${BIN_DIR}/win-install/OpenCVConfig.cmake -> For use within binary installers/packages
|
||||
# --------------------------------------------------------------------------------------------
|
||||
-if(WIN32)
|
||||
+if(FALSE)
|
||||
if(CMAKE_HOST_SYSTEM_NAME MATCHES Windows AND NOT OPENCV_SKIP_CMAKE_ROOT_CONFIG)
|
||||
ocv_gen_config("${CMAKE_BINARY_DIR}/win-install"
|
||||
"${OPENCV_INSTALL_BINARIES_PREFIX}${OPENCV_INSTALL_BINARIES_SUFFIX}"
|
||||
diff --git a/data/CMakeLists.txt b/data/CMakeLists.txt
|
||||
index 1f0d720..0bb1ff7 100644
|
||||
--- a/data/CMakeLists.txt
|
||||
+++ b/data/CMakeLists.txt
|
||||
@@ -1,8 +1,6 @@
|
||||
file(GLOB HAAR_CASCADES haarcascades/*.xml)
|
||||
file(GLOB LBP_CASCADES lbpcascades/*.xml)
|
||||
|
||||
-install(FILES ${HAAR_CASCADES} DESTINATION ${OPENCV_OTHER_INSTALL_PATH}/haarcascades COMPONENT libs)
|
||||
-install(FILES ${LBP_CASCADES} DESTINATION ${OPENCV_OTHER_INSTALL_PATH}/lbpcascades COMPONENT libs)
|
||||
|
||||
if(INSTALL_TESTS AND OPENCV_TEST_DATA_PATH)
|
||||
install(DIRECTORY "${OPENCV_TEST_DATA_PATH}/" DESTINATION "${OPENCV_TEST_DATA_INSTALL_PATH}" COMPONENT "tests")
|
||||
83
externals/vcpkg/ports/opencv3/0003-force-package-requirements.patch
vendored
Executable file
83
externals/vcpkg/ports/opencv3/0003-force-package-requirements.patch
vendored
Executable file
@@ -0,0 +1,83 @@
|
||||
--- a/cmake/OpenCVFindLibsGrfmt.cmake
|
||||
+++ b/cmake/OpenCVFindLibsGrfmt.cmake
|
||||
@@ -11,7 +11,7 @@ else()
|
||||
set(_zlib_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES ${CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||
set(CMAKE_FIND_LIBRARY_SUFFIXES .so)
|
||||
endif()
|
||||
- find_package(ZLIB "${MIN_VER_ZLIB}")
|
||||
+ find_package(ZLIB "${MIN_VER_ZLIB}" REQUIRED)
|
||||
if(ANDROID)
|
||||
set(CMAKE_FIND_LIBRARY_SUFFIXES ${_zlib_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES})
|
||||
unset(_zlib_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES)
|
||||
@@ -41,7 +41,7 @@ if(WITH_JPEG)
|
||||
ocv_clear_vars(JPEG_FOUND)
|
||||
else()
|
||||
ocv_clear_internal_cache_vars(JPEG_LIBRARY JPEG_INCLUDE_DIR)
|
||||
- include(FindJPEG)
|
||||
+ find_package(JPEG REQUIRED)
|
||||
endif()
|
||||
|
||||
if(NOT JPEG_FOUND)
|
||||
@@ -87,7 +87,7 @@ if(WITH_TIFF)
|
||||
ocv_clear_vars(TIFF_FOUND)
|
||||
else()
|
||||
ocv_clear_internal_cache_vars(TIFF_LIBRARY TIFF_INCLUDE_DIR)
|
||||
- include(FindTIFF)
|
||||
+ find_package(TIFF REQUIRED)
|
||||
if(TIFF_FOUND)
|
||||
ocv_parse_header("${TIFF_INCLUDE_DIR}/tiff.h" TIFF_VERSION_LINES TIFF_VERSION_CLASSIC TIFF_VERSION_BIG TIFF_VERSION TIFF_BIGTIFF_VERSION)
|
||||
endif()
|
||||
@@ -131,7 +131,7 @@ if(WITH_WEBP)
|
||||
ocv_clear_vars(WEBP_FOUND WEBP_LIBRARY WEBP_LIBRARIES WEBP_INCLUDE_DIR)
|
||||
else()
|
||||
ocv_clear_internal_cache_vars(WEBP_LIBRARY WEBP_INCLUDE_DIR)
|
||||
- include(cmake/OpenCVFindWebP.cmake)
|
||||
+ find_package(WEBP NAMES WebP REQUIRED)
|
||||
if(WEBP_FOUND)
|
||||
set(HAVE_WEBP 1)
|
||||
endif()
|
||||
@@ -172,7 +172,7 @@ if(WITH_JASPER)
|
||||
if(BUILD_JASPER)
|
||||
ocv_clear_vars(JASPER_FOUND)
|
||||
else()
|
||||
- include(FindJasper)
|
||||
+ find_package(Jasper REQUIRED)
|
||||
endif()
|
||||
|
||||
if(NOT JASPER_FOUND)
|
||||
@@ -197,7 +197,7 @@ if(WITH_PNG)
|
||||
ocv_clear_vars(PNG_FOUND)
|
||||
else()
|
||||
ocv_clear_internal_cache_vars(PNG_LIBRARY PNG_INCLUDE_DIR)
|
||||
- include(FindPNG)
|
||||
+ find_package(PNG REQUIRED)
|
||||
if(PNG_FOUND)
|
||||
include(CheckIncludeFile)
|
||||
check_include_file("${PNG_PNG_INCLUDE_DIR}/libpng/png.h" HAVE_LIBPNG_PNG_H)
|
||||
@@ -229,7 +229,7 @@ if(WITH_OPENEXR)
|
||||
ocv_clear_vars(HAVE_OPENEXR)
|
||||
if(NOT BUILD_OPENEXR)
|
||||
ocv_clear_internal_cache_vars(OPENEXR_INCLUDE_PATHS OPENEXR_LIBRARIES OPENEXR_ILMIMF_LIBRARY OPENEXR_VERSION)
|
||||
- include("${OpenCV_SOURCE_DIR}/cmake/OpenCVFindOpenEXR.cmake")
|
||||
+ find_package(OpenEXR REQUIRED)
|
||||
endif()
|
||||
|
||||
if(OPENEXR_FOUND)
|
||||
@@ -247,7 +247,7 @@ endif()
|
||||
|
||||
# --- GDAL (optional) ---
|
||||
if(WITH_GDAL)
|
||||
- find_package(GDAL QUIET)
|
||||
+ find_package(GDAL REQUIRED)
|
||||
|
||||
if(NOT GDAL_FOUND)
|
||||
set(HAVE_GDAL NO)
|
||||
@@ -259,7 +259,7 @@ if(WITH_GDAL)
|
||||
endif()
|
||||
|
||||
if(WITH_GDCM)
|
||||
- find_package(GDCM QUIET)
|
||||
+ find_package(GDCM REQUIRED)
|
||||
if(NOT GDCM_FOUND)
|
||||
set(HAVE_GDCM NO)
|
||||
ocv_clear_vars(GDCM_VERSION GDCM_LIBRARIES)
|
||||
11
externals/vcpkg/ports/opencv3/0004-fix-eigen.patch
vendored
Executable file
11
externals/vcpkg/ports/opencv3/0004-fix-eigen.patch
vendored
Executable file
@@ -0,0 +1,11 @@
|
||||
--- a/cmake/OpenCVFindLibsPerf.cmake
|
||||
+++ b/cmake/OpenCVFindLibsPerf.cmake
|
||||
@@ -55,7 +55,7 @@ if(WITH_EIGEN AND NOT HAVE_EIGEN)
|
||||
OR NOT (CMAKE_VERSION VERSION_LESS "3.0.0") # Eigen3Targets.cmake required CMake 3.0.0+
|
||||
) AND NOT OPENCV_SKIP_EIGEN_FIND_PACKAGE_CONFIG
|
||||
)
|
||||
- find_package(Eigen3 CONFIG QUIET) # Ceres 2.0.0 CMake scripts doesn't work with CMake's FindEigen3.cmake module (due to missing EIGEN3_VERSION_STRING)
|
||||
+ find_package(Eigen3 CONFIG REQUIRED) # Ceres 2.0.0 CMake scripts doesn't work with CMake's FindEigen3.cmake module (due to missing EIGEN3_VERSION_STRING)
|
||||
endif()
|
||||
if(NOT Eigen3_FOUND)
|
||||
find_package(Eigen3 QUIET)
|
||||
466
externals/vcpkg/ports/opencv3/0005-fix-vtk9.patch
vendored
Executable file
466
externals/vcpkg/ports/opencv3/0005-fix-vtk9.patch
vendored
Executable file
@@ -0,0 +1,466 @@
|
||||
--- a/cmake/OpenCVDetectVTK.cmake
|
||||
+++ b/cmake/OpenCVDetectVTK.cmake
|
||||
@@ -1,12 +1,30 @@
|
||||
+# VTK 9.0
|
||||
+if(NOT VTK_FOUND)
|
||||
+ find_package(VTK 9 QUIET NAMES vtk COMPONENTS
|
||||
+ FiltersExtraction
|
||||
+ FiltersSources
|
||||
+ FiltersTexture
|
||||
+ IOExport
|
||||
+ IOGeometry
|
||||
+ IOPLY
|
||||
+ InteractionStyle
|
||||
+ RenderingCore
|
||||
+ RenderingLOD
|
||||
+ RenderingOpenGL2
|
||||
+ NO_MODULE)
|
||||
+endif()
|
||||
+
|
||||
# VTK 6.x components
|
||||
-find_package(VTK QUIET COMPONENTS vtkInteractionStyle vtkRenderingLOD vtkIOPLY vtkFiltersTexture vtkRenderingFreeType vtkIOExport NO_MODULE)
|
||||
-IF(VTK_FOUND)
|
||||
- IF(VTK_RENDERING_BACKEND) #in vtk 7, the rendering backend is exported as a var.
|
||||
+if(NOT VTK_FOUND)
|
||||
+ find_package(VTK QUIET COMPONENTS vtkInteractionStyle vtkRenderingLOD vtkIOPLY vtkFiltersTexture vtkRenderingFreeType vtkIOExport NO_MODULE)
|
||||
+ IF(VTK_FOUND)
|
||||
+ IF(VTK_RENDERING_BACKEND) #in vtk 7, the rendering backend is exported as a var.
|
||||
find_package(VTK QUIET COMPONENTS vtkRendering${VTK_RENDERING_BACKEND} vtkInteractionStyle vtkRenderingLOD vtkIOPLY vtkFiltersTexture vtkRenderingFreeType vtkIOExport vtkIOGeometry NO_MODULE)
|
||||
- ELSE(VTK_RENDERING_BACKEND)
|
||||
+ ELSE(VTK_RENDERING_BACKEND)
|
||||
find_package(VTK QUIET COMPONENTS vtkRenderingOpenGL vtkInteractionStyle vtkRenderingLOD vtkIOPLY vtkFiltersTexture vtkRenderingFreeType vtkIOExport NO_MODULE)
|
||||
- ENDIF(VTK_RENDERING_BACKEND)
|
||||
-ENDIF(VTK_FOUND)
|
||||
+ ENDIF(VTK_RENDERING_BACKEND)
|
||||
+ ENDIF(VTK_FOUND)
|
||||
+endif()
|
||||
|
||||
# VTK 5.x components
|
||||
if(NOT VTK_FOUND)
|
||||
diff --git a/modules/viz/CMakeLists.txt b/modules/viz/CMakeLists.txt
|
||||
index 256b464..92698c3 100644
|
||||
--- a/modules/viz/CMakeLists.txt
|
||||
+++ b/modules/viz/CMakeLists.txt
|
||||
@@ -3,7 +3,6 @@ if(NOT HAVE_VTK)
|
||||
endif()
|
||||
|
||||
set(the_description "Viz")
|
||||
-include(${VTK_USE_FILE})
|
||||
|
||||
if(NOT BUILD_SHARED_LIBS)
|
||||
# We observed conflict between builtin 3rdparty libraries and
|
||||
@@ -27,7 +26,14 @@ endif()
|
||||
ocv_warnings_disable(CMAKE_CXX_FLAGS -Winconsistent-missing-override -Wsuggest-override)
|
||||
|
||||
ocv_define_module(viz opencv_core WRAP python)
|
||||
-ocv_target_link_libraries(${the_module} PRIVATE ${VTK_LIBRARIES})
|
||||
+
|
||||
+if (VTK_VERSION VERSION_LESS "8.90.0")
|
||||
+ include(${VTK_USE_FILE})
|
||||
+ ocv_target_link_libraries(${the_module} PRIVATE ${VTK_LIBRARIES})
|
||||
+else ()
|
||||
+ ocv_target_link_libraries(${the_module} PRIVATE ${VTK_LIBRARIES})
|
||||
+ vtk_module_autoinit(TARGETS ${the_module} MODULES ${VTK_LIBRARIES})
|
||||
+endif()
|
||||
|
||||
if(APPLE AND BUILD_opencv_viz)
|
||||
ocv_target_link_libraries(${the_module} PRIVATE "-framework Cocoa")
|
||||
diff --git a/modules/viz/src/precomp.hpp b/modules/viz/src/precomp.hpp
|
||||
index f92fdb6..4c4bf7c 100644
|
||||
--- a/modules/viz/src/precomp.hpp
|
||||
+++ b/modules/viz/src/precomp.hpp
|
||||
@@ -133,7 +133,8 @@
|
||||
#include <vtkColorTransferFunction.h>
|
||||
#include <vtkStreamingDemandDrivenPipeline.h>
|
||||
#include <vtkLight.h>
|
||||
-#include "vtkCallbackCommand.h"
|
||||
+#include <vtkCallbackCommand.h>
|
||||
+#include <vtkVersion.h>
|
||||
|
||||
#if !defined(_WIN32) || defined(__CYGWIN__)
|
||||
# include <unistd.h> /* unlink */
|
||||
@@ -149,6 +150,11 @@
|
||||
#include "vtk/vtkTrajectorySource.h"
|
||||
#include "vtk/vtkImageMatSource.h"
|
||||
|
||||
+#if VTK_MAJOR_VERSION >= 9
|
||||
+typedef vtkIdType const * CellIterT;
|
||||
+#else
|
||||
+typedef vtkIdType * CellIterT;
|
||||
+#endif
|
||||
|
||||
#include <opencv2/core.hpp>
|
||||
#include <opencv2/viz.hpp>
|
||||
diff --git a/modules/viz/src/types.cpp b/modules/viz/src/types.cpp
|
||||
index 65571a1..e9a470c 100644
|
||||
--- a/modules/viz/src/types.cpp
|
||||
+++ b/modules/viz/src/types.cpp
|
||||
@@ -97,10 +97,12 @@ cv::viz::Mesh cv::viz::Mesh::load(const String& file, int type)
|
||||
// Now handle the polygons
|
||||
vtkSmartPointer<vtkCellArray> polygons = polydata->GetPolys();
|
||||
mesh.polygons.create(1, polygons->GetSize(), CV_32SC1);
|
||||
+ mesh.polygons = 0;
|
||||
int* poly_ptr = mesh.polygons.ptr<int>();
|
||||
|
||||
polygons->InitTraversal();
|
||||
- vtkIdType nr_cell_points, *cell_points;
|
||||
+ vtkIdType nr_cell_points;
|
||||
+ CellIterT cell_points;
|
||||
while (polygons->GetNextCell(nr_cell_points, cell_points))
|
||||
{
|
||||
*poly_ptr++ = nr_cell_points;
|
||||
--- a/modules/viz/src/vizimpl.cpp
|
||||
+++ b/modules/viz/src/vizimpl.cpp
|
||||
@@ -55,8 +55,17 @@ cv::viz::Viz3d::VizImpl::VizImpl(const String &name) : spin_once_state_(false),
|
||||
|
||||
// Create render window
|
||||
window_ = vtkSmartPointer<vtkRenderWindow>::New();
|
||||
- cv::Vec2i window_size = cv::Vec2i(window_->GetScreenSize()) / 2;
|
||||
- window_->SetSize(window_size.val);
|
||||
+ int * sz = window_->GetScreenSize();
|
||||
+ if (sz)
|
||||
+ {
|
||||
+ cv::Vec2i window_size = cv::Vec2i(sz) / 2;
|
||||
+ window_->SetSize(window_size.val);
|
||||
+ }
|
||||
+ else
|
||||
+ {
|
||||
+ int new_sz[2] = { 640, 480 };
|
||||
+ window_->SetSize(new_sz);
|
||||
+ }
|
||||
window_->AddRenderer(renderer_);
|
||||
|
||||
// Create the interactor style
|
||||
--- a/modules/viz/src/vtk/vtkOBJWriter.cpp
|
||||
+++ b/modules/viz/src/vtk/vtkOBJWriter.cpp
|
||||
@@ -72,7 +72,7 @@ void cv::viz::vtkOBJWriter::WriteData()
|
||||
}
|
||||
|
||||
vtkDebugMacro(<<"Opening vtk file for writing...");
|
||||
- ostream *outfilep = new ofstream(this->FileName, ios::out);
|
||||
+ std::ostream *outfilep = new std::ofstream(this->FileName, ios::out);
|
||||
if (outfilep->fail())
|
||||
{
|
||||
vtkErrorMacro(<< "Unable to open file: "<< this->FileName);
|
||||
@@ -127,7 +127,8 @@ void cv::viz::vtkOBJWriter::WriteData()
|
||||
// write out verts if any
|
||||
if (input->GetNumberOfVerts() > 0)
|
||||
{
|
||||
- vtkIdType npts = 0, *index = 0;
|
||||
+ vtkIdType npts = 0;
|
||||
+ CellIterT index = 0;
|
||||
vtkCellArray *cells = input->GetVerts();
|
||||
for (cells->InitTraversal(); cells->GetNextCell(npts, index); )
|
||||
{
|
||||
@@ -141,7 +142,8 @@ void cv::viz::vtkOBJWriter::WriteData()
|
||||
// write out lines if any
|
||||
if (input->GetNumberOfLines() > 0)
|
||||
{
|
||||
- vtkIdType npts = 0, *index = 0;
|
||||
+ vtkIdType npts = 0;
|
||||
+ CellIterT index = 0;
|
||||
vtkCellArray *cells = input->GetLines();
|
||||
for (cells->InitTraversal(); cells->GetNextCell(npts, index); )
|
||||
{
|
||||
@@ -162,7 +164,8 @@ void cv::viz::vtkOBJWriter::WriteData()
|
||||
// write out polys if any
|
||||
if (input->GetNumberOfPolys() > 0)
|
||||
{
|
||||
- vtkIdType npts = 0, *index = 0;
|
||||
+ vtkIdType npts = 0;
|
||||
+ CellIterT index = 0;
|
||||
vtkCellArray *cells = input->GetPolys();
|
||||
for (cells->InitTraversal(); cells->GetNextCell(npts, index); )
|
||||
{
|
||||
@@ -191,7 +194,8 @@ void cv::viz::vtkOBJWriter::WriteData()
|
||||
// write out tstrips if any
|
||||
if (input->GetNumberOfStrips() > 0)
|
||||
{
|
||||
- vtkIdType npts = 0, *index = 0;
|
||||
+ vtkIdType npts = 0;
|
||||
+ CellIterT index = 0;
|
||||
vtkCellArray *cells = input->GetStrips();
|
||||
for (cells->InitTraversal(); cells->GetNextCell(npts, index); )
|
||||
{
|
||||
--- a/modules/viz/src/vtk/vtkXYZReader.cpp
|
||||
+++ b/modules/viz/src/vtk/vtkXYZReader.cpp
|
||||
@@ -77,7 +77,7 @@ int cv::viz::vtkXYZReader::RequestData(vtkInformation*, vtkInformationVector**,
|
||||
}
|
||||
|
||||
// Open the input file.
|
||||
- ifstream fin(this->FileName);
|
||||
+ std::ifstream fin(this->FileName);
|
||||
if(!fin)
|
||||
{
|
||||
vtkErrorMacro("Error opening file " << this->FileName);
|
||||
--- a/modules/viz/src/vtk/vtkXYZWriter.cpp
|
||||
+++ b/modules/viz/src/vtk/vtkXYZWriter.cpp
|
||||
@@ -69,7 +69,7 @@ void cv::viz::vtkXYZWriter::WriteData()
|
||||
}
|
||||
|
||||
vtkDebugMacro(<<"Opening vtk file for writing...");
|
||||
- ostream *outfilep = new ofstream(this->FileName, ios::out);
|
||||
+ std::ostream *outfilep = new std::ofstream(this->FileName, ios::out);
|
||||
if (outfilep->fail())
|
||||
{
|
||||
vtkErrorMacro(<< "Unable to open file: "<< this->FileName);
|
||||
--- a/modules/viz/test/test_tutorial2.cpp
|
||||
+++ b/modules/viz/test/test_tutorial2.cpp
|
||||
@@ -28,7 +28,7 @@ static void tutorial2()
|
||||
/// Rodrigues vector
|
||||
Vec3d rot_vec = Vec3d::all(0);
|
||||
double translation_phase = 0.0, translation = 0.0;
|
||||
- while(!myWindow.wasStopped())
|
||||
+ for(unsigned num = 0; num < 50; ++num)
|
||||
{
|
||||
/* Rotation using rodrigues */
|
||||
/// Rotate around (1,1,1)
|
||||
@@ -45,7 +45,7 @@ static void tutorial2()
|
||||
|
||||
myWindow.setWidgetPose("Cube Widget", pose);
|
||||
|
||||
- myWindow.spinOnce(1, true);
|
||||
+ myWindow.spinOnce(100, true);
|
||||
}
|
||||
}
|
||||
|
||||
--- a/modules/viz/test/test_tutorial3.cpp
|
||||
+++ b/modules/viz/test/test_tutorial3.cpp
|
||||
@@ -48,7 +48,7 @@ static void tutorial3(bool camera_pov)
|
||||
myWindow.setViewerPose(camera_pose);
|
||||
|
||||
/// Start event loop.
|
||||
- myWindow.spin();
|
||||
+ myWindow.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, tutorial3_global_view)
|
||||
--- a/modules/viz/test/test_viz3d.cpp
|
||||
+++ b/modules/viz/test/test_viz3d.cpp
|
||||
@@ -59,7 +59,7 @@ TEST(Viz_viz3d, DISABLED_develop)
|
||||
//cv::Mat cloud = cv::viz::readCloud(get_dragon_ply_file_path());
|
||||
//---->>>>> </to_test_in_future>
|
||||
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
}} // namespace
|
||||
--- a/modules/viz/test/tests_simple.cpp
|
||||
+++ b/modules/viz/test/tests_simple.cpp
|
||||
@@ -56,7 +56,7 @@ TEST(Viz, show_cloud_bluberry)
|
||||
viz.showWidget("dragon", WCloud(dragon_cloud, Color::bluberry()), pose);
|
||||
|
||||
viz.showWidget("text2d", WText("Bluberry cloud", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_cloud_random_color)
|
||||
@@ -73,7 +73,7 @@ TEST(Viz, show_cloud_random_color)
|
||||
viz.showWidget("coosys", WCoordinateSystem());
|
||||
viz.showWidget("dragon", WCloud(dragon_cloud, colors), pose);
|
||||
viz.showWidget("text2d", WText("Random color cloud", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_cloud_masked)
|
||||
@@ -91,7 +91,7 @@ TEST(Viz, show_cloud_masked)
|
||||
viz.showWidget("coosys", WCoordinateSystem());
|
||||
viz.showWidget("dragon", WCloud(dragon_cloud), pose);
|
||||
viz.showWidget("text2d", WText("Nan masked cloud", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_cloud_collection)
|
||||
@@ -109,7 +109,7 @@ TEST(Viz, show_cloud_collection)
|
||||
viz.showWidget("coosys", WCoordinateSystem());
|
||||
viz.showWidget("ccol", ccol);
|
||||
viz.showWidget("text2d", WText("Cloud collection", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_painted_clouds)
|
||||
@@ -124,7 +124,7 @@ TEST(Viz, show_painted_clouds)
|
||||
viz.showWidget("cloud3", WPaintedCloud(cloud, Vec3d(0.0, 0.0, -1.0), Vec3d(0.0, 0.0, 1.0), Color::blue(), Color::red()));
|
||||
viz.showWidget("arrow", WArrow(Vec3d(0.0, 1.0, -1.0), Vec3d(0.0, 1.0, 1.0), 0.009, Color::raspberry()));
|
||||
viz.showWidget("text2d", WText("Painted clouds", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_mesh)
|
||||
@@ -137,7 +137,7 @@ TEST(Viz, show_mesh)
|
||||
viz.showWidget("coosys", WCoordinateSystem());
|
||||
viz.showWidget("mesh", WMesh(mesh), pose);
|
||||
viz.showWidget("text2d", WText("Just mesh", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_mesh_random_colors)
|
||||
@@ -152,7 +152,7 @@ TEST(Viz, show_mesh_random_colors)
|
||||
viz.showWidget("mesh", WMesh(mesh), pose);
|
||||
viz.setRenderingProperty("mesh", SHADING, SHADING_PHONG);
|
||||
viz.showWidget("text2d", WText("Random color mesh", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_widget_merger)
|
||||
@@ -173,7 +173,7 @@ TEST(Viz, show_widget_merger)
|
||||
viz.showWidget("coo", WCoordinateSystem());
|
||||
viz.showWidget("merger", merger);
|
||||
viz.showWidget("text2d", WText("Widget merger", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_textured_mesh)
|
||||
@@ -210,7 +210,7 @@ TEST(Viz, show_textured_mesh)
|
||||
viz.showWidget("mesh", WMesh(mesh));
|
||||
viz.setRenderingProperty("mesh", SHADING, SHADING_PHONG);
|
||||
viz.showWidget("text2d", WText("Textured mesh", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_polyline)
|
||||
@@ -229,7 +229,7 @@ TEST(Viz, show_polyline)
|
||||
viz.showWidget("polyline", WPolyLine(polyline, colors));
|
||||
viz.showWidget("coosys", WCoordinateSystem());
|
||||
viz.showWidget("text2d", WText("Polyline", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_sampled_normals)
|
||||
@@ -244,7 +244,7 @@ TEST(Viz, show_sampled_normals)
|
||||
viz.showWidget("normals", WCloudNormals(mesh.cloud, mesh.normals, 30, 0.1f, Color::green()), pose);
|
||||
viz.setRenderingProperty("normals", LINE_WIDTH, 2.0);
|
||||
viz.showWidget("text2d", WText("Cloud or mesh normals", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_cloud_shaded_by_normals)
|
||||
@@ -260,7 +260,7 @@ TEST(Viz, show_cloud_shaded_by_normals)
|
||||
Viz3d viz("show_cloud_shaded_by_normals");
|
||||
viz.showWidget("cloud", cloud, pose);
|
||||
viz.showWidget("text2d", WText("Cloud shaded by normals", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_trajectories)
|
||||
@@ -287,15 +287,15 @@ TEST(Viz, show_trajectories)
|
||||
viz.showWidget("text2d", WText("Different kinds of supported trajectories", Point(20, 20), 20, Color::green()));
|
||||
|
||||
int i = 0;
|
||||
- while(!viz.wasStopped())
|
||||
+ for(unsigned num = 0; num < 50; ++num)
|
||||
{
|
||||
double a = --i % 360;
|
||||
Vec3d pose(sin(a * CV_PI/180), 0.7, cos(a * CV_PI/180));
|
||||
viz.setViewerPose(makeCameraPose(pose * 7.5, Vec3d(0.0, 0.5, 0.0), Vec3d(0.0, 0.1, 0.0)));
|
||||
- viz.spinOnce(20, true);
|
||||
+ viz.spinOnce(100, true);
|
||||
}
|
||||
viz.resetCamera();
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_trajectory_reposition)
|
||||
@@ -306,7 +306,7 @@ TEST(Viz, show_trajectory_reposition)
|
||||
viz.showWidget("coos", WCoordinateSystem());
|
||||
viz.showWidget("sub3", WTrajectory(Mat(path).rowRange(0, (int)path.size()/3), WTrajectory::BOTH, 0.2, Color::brown()), path.front().inv());
|
||||
viz.showWidget("text2d", WText("Trajectory resposition to origin", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_camera_positions)
|
||||
@@ -330,7 +330,7 @@ TEST(Viz, show_camera_positions)
|
||||
viz.showWidget("pos3", WCameraPosition(0.75), poses[1]);
|
||||
viz.showWidget("pos4", WCameraPosition(K, gray, 3, Color::indigo()), poses[1]);
|
||||
viz.showWidget("text2d", WText("Camera positions with images", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_overlay_image)
|
||||
@@ -353,16 +353,16 @@ TEST(Viz, show_overlay_image)
|
||||
viz.showWidget("text2d", WText("Overlay images", Point(20, 20), 20, Color::green()));
|
||||
|
||||
int i = 0;
|
||||
- while(!viz.wasStopped())
|
||||
+ for(unsigned num = 0; num < 50; ++num)
|
||||
{
|
||||
double a = ++i % 360;
|
||||
Vec3d pose(sin(a * CV_PI/180), 0.7, cos(a * CV_PI/180));
|
||||
viz.setViewerPose(makeCameraPose(pose * 3, Vec3d(0.0, 0.5, 0.0), Vec3d(0.0, 0.1, 0.0)));
|
||||
viz.getWidget("img1").cast<WImageOverlay>().setImage(lena * pow(sin(i*10*CV_PI/180) * 0.5 + 0.5, 1.0));
|
||||
- viz.spinOnce(1, true);
|
||||
+ viz.spinOnce(100, true);
|
||||
}
|
||||
viz.showWidget("text2d", WText("Overlay images (stopped)", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
|
||||
@@ -376,7 +376,7 @@ TEST(Viz, show_image_method)
|
||||
viz.showImage(lena, lena.size());
|
||||
viz.spinOnce(1500, true);
|
||||
|
||||
- cv::viz::imshow("show_image_method", make_gray(lena)).spin();
|
||||
+ cv::viz::imshow("show_image_method", make_gray(lena)).spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_image_3d)
|
||||
@@ -398,13 +398,13 @@ TEST(Viz, show_image_3d)
|
||||
viz.showWidget("text2d", WText("Images in 3D", Point(20, 20), 20, Color::green()));
|
||||
|
||||
int i = 0;
|
||||
- while(!viz.wasStopped())
|
||||
+ for(unsigned num = 0; num < 50; ++num)
|
||||
{
|
||||
viz.getWidget("img0").cast<WImage3D>().setImage(lena * pow(sin(i++*7.5*CV_PI/180) * 0.5 + 0.5, 1.0));
|
||||
- viz.spinOnce(1, true);
|
||||
+ viz.spinOnce(100, true);
|
||||
}
|
||||
viz.showWidget("text2d", WText("Images in 3D (stopped)", Point(20, 20), 20, Color::green()));
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_simple_widgets)
|
||||
@@ -431,10 +431,10 @@ TEST(Viz, show_simple_widgets)
|
||||
|
||||
viz.showWidget("grid1", WGrid(Vec2i(7,7), Vec2d::all(0.75), Color::gray()), Affine3d().translate(Vec3d(0.0, 0.0, -1.0)));
|
||||
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
viz.getWidget("text2d").cast<WText>().setText("Different simple widgets (updated)");
|
||||
viz.getWidget("text3d").cast<WText3D>().setText("Updated text 3D");
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
TEST(Viz, show_follower)
|
||||
@@ -446,9 +446,9 @@ TEST(Viz, show_follower)
|
||||
viz.showWidget("t3d_2", WText3D("Simple 3D follower", Point3d(-0.5, -0.5, 0.5), 0.125, true, Color::green()));
|
||||
viz.showWidget("text2d", WText("Follower: text always facing camera", Point(20, 20), 20, Color::green()));
|
||||
viz.setBackgroundMeshLab();
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
viz.getWidget("t3d_2").cast<WText3D>().setText("Updated follower 3D");
|
||||
- viz.spin();
|
||||
+ viz.spinOnce(500, true);
|
||||
}
|
||||
|
||||
}} // namespace
|
||||
11
externals/vcpkg/ports/opencv3/0006-fix-uwp.patch
vendored
Executable file
11
externals/vcpkg/ports/opencv3/0006-fix-uwp.patch
vendored
Executable file
@@ -0,0 +1,11 @@
|
||||
--- a/cmake/OpenCVModule.cmake
|
||||
+++ b/cmake/OpenCVModule.cmake
|
||||
@@ -1188,7 +1188,7 @@ function(ocv_add_perf_tests)
|
||||
set_target_properties(${the_target} PROPERTIES FOLDER "tests performance")
|
||||
endif()
|
||||
|
||||
- if(WINRT)
|
||||
+ if(WINRT AND BUILD_TESTS)
|
||||
# removing APPCONTAINER from tests to run from console
|
||||
# look for detailed description inside of ocv_create_module macro above
|
||||
add_custom_command(TARGET "opencv_perf_${name}"
|
||||
28
externals/vcpkg/ports/opencv3/0007-fix-hdf5.patch
vendored
Executable file
28
externals/vcpkg/ports/opencv3/0007-fix-hdf5.patch
vendored
Executable file
@@ -0,0 +1,28 @@
|
||||
--- a/modules/hdf/CMakeLists.txt
|
||||
+++ b/modules/hdf/CMakeLists.txt
|
||||
@@ -1,25 +1,8 @@
|
||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_CURRENT_SOURCE_DIR})
|
||||
|
||||
-if(WIN32)
|
||||
- # windows cmake internal lookups are broken for now
|
||||
- # will lookup for headers and shared libs given HDF_DIR env
|
||||
- find_path(HDF5_INCLUDE_DIRS hdf5.h HINTS "$ENV{HDF5_DIR}\\..\\include")
|
||||
- find_library(HDF5_C_LIBRARY NAMES hdf5 HINTS "$ENV{HDF5_DIR}\\..\\lib")
|
||||
- if(HDF5_INCLUDE_DIRS AND HDF5_C_LIBRARY)
|
||||
- set(HDF5_FOUND "YES")
|
||||
- set(HDF5_LIBRARIES ${HDF5_C_LIBRARY})
|
||||
- mark_as_advanced(HDF5_LIBRARIES)
|
||||
- mark_as_advanced(HDF5_C_LIBRARY)
|
||||
- mark_as_advanced(HDF5_INCLUDE_DIRS)
|
||||
- add_definitions(-DH5_BUILT_AS_DYNAMIC_LIB -D_HDF5USEDLL_)
|
||||
- else()
|
||||
- set(HDF5_FOUND "NO")
|
||||
- endif()
|
||||
-else()
|
||||
if(NOT CMAKE_CROSSCOMPILING) # iOS build should not reuse OSX package
|
||||
find_package(HDF5)
|
||||
endif()
|
||||
-endif()
|
||||
|
||||
if(NOT HDF5_FOUND)
|
||||
ocv_module_disable(hdf) # no return
|
||||
22
externals/vcpkg/ports/opencv3/0008-devendor-quirc.patch
vendored
Executable file
22
externals/vcpkg/ports/opencv3/0008-devendor-quirc.patch
vendored
Executable file
@@ -0,0 +1,22 @@
|
||||
--- a/CMakeLists.txt
|
||||
+++ b/CMakeLists.txt
|
||||
@@ -778,7 +778,7 @@ if(WITH_OPENVX)
|
||||
endif()
|
||||
|
||||
if(WITH_QUIRC)
|
||||
- add_subdirectory(3rdparty/quirc)
|
||||
+ find_package(quirc CONFIG REQUIRED)
|
||||
set(HAVE_QUIRC TRUE)
|
||||
endif()
|
||||
# ----------------------------------------------------------------------------
|
||||
--- a/modules/objdetect/CMakeLists.txt
|
||||
+++ b/modules/objdetect/CMakeLists.txt
|
||||
@@ -2,7 +2,5 @@ set(the_description "Object Detection")
|
||||
ocv_define_module(objdetect opencv_core opencv_imgproc opencv_calib3d WRAP java python js)
|
||||
|
||||
if(HAVE_QUIRC)
|
||||
- get_property(QUIRC_INCLUDE GLOBAL PROPERTY QUIRC_INCLUDE_DIR)
|
||||
- ocv_include_directories(${QUIRC_INCLUDE})
|
||||
- ocv_target_link_libraries(${the_module} quirc)
|
||||
+ ocv_target_link_libraries(${the_module} quirc::quirc)
|
||||
endif()
|
||||
26
externals/vcpkg/ports/opencv3/0009-fix-protobuf.patch
vendored
Executable file
26
externals/vcpkg/ports/opencv3/0009-fix-protobuf.patch
vendored
Executable file
@@ -0,0 +1,26 @@
|
||||
--- a/cmake/OpenCVFindProtobuf.cmake
|
||||
+++ b/cmake/OpenCVFindProtobuf.cmake
|
||||
@@ -31,7 +31,7 @@ if(BUILD_PROTOBUF)
|
||||
set(HAVE_PROTOBUF TRUE)
|
||||
else()
|
||||
unset(Protobuf_VERSION CACHE)
|
||||
- find_package(Protobuf QUIET)
|
||||
+ find_package(Protobuf CONFIG REQUIRED)
|
||||
|
||||
# Backwards compatibility
|
||||
# Define camel case versions of input variables
|
||||
@@ -76,6 +76,7 @@ if(HAVE_PROTOBUF)
|
||||
if(NOT BUILD_PROTOBUF)
|
||||
if(TARGET "${Protobuf_LIBRARIES}")
|
||||
get_target_property(__location "${Protobuf_LIBRARIES}" IMPORTED_LOCATION_RELEASE)
|
||||
+ get_target_property(__location_debug "${Protobuf_LIBRARIES}" IMPORTED_LOCATION_DEBUG)
|
||||
if(NOT __location)
|
||||
get_target_property(__location "${Protobuf_LIBRARIES}" IMPORTED_LOCATION)
|
||||
endif()
|
||||
@@ -87,5 +88,5 @@ if(HAVE_PROTOBUF)
|
||||
endif()
|
||||
list(APPEND CUSTOM_STATUS_protobuf " Protobuf:"
|
||||
BUILD_PROTOBUF THEN "build (${Protobuf_VERSION})"
|
||||
- ELSE "${__location} (${Protobuf_VERSION})")
|
||||
+ ELSE "optimized ${__location} debug ${__location_debug} ; version (${Protobuf_VERSION})")
|
||||
endif()
|
||||
13
externals/vcpkg/ports/opencv3/0010-fix-uwp-tiff-imgcodecs.patch
vendored
Executable file
13
externals/vcpkg/ports/opencv3/0010-fix-uwp-tiff-imgcodecs.patch
vendored
Executable file
@@ -0,0 +1,13 @@
|
||||
--- a/modules/imgcodecs/CMakeLists.txt
|
||||
+++ b/modules/imgcodecs/CMakeLists.txt
|
||||
@@ -9,6 +9,10 @@ ocv_add_module(imgcodecs opencv_imgproc WRAP java objc python)
|
||||
|
||||
ocv_clear_vars(GRFMT_LIBS)
|
||||
|
||||
+if(MSVC)
|
||||
+ set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /wd4996")
|
||||
+endif()
|
||||
+
|
||||
if(HAVE_WINRT_CX AND NOT WINRT)
|
||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /ZW")
|
||||
endif()
|
||||
18
externals/vcpkg/ports/opencv3/0011-remove-python2.patch
vendored
Executable file
18
externals/vcpkg/ports/opencv3/0011-remove-python2.patch
vendored
Executable file
@@ -0,0 +1,18 @@
|
||||
--- a/cmake/OpenCVDetectPython.cmake
|
||||
+++ b/cmake/OpenCVDetectPython.cmake
|
||||
@@ -268,15 +268,6 @@ if(OPENCV_PYTHON_SKIP_DETECTION)
|
||||
return()
|
||||
endif()
|
||||
|
||||
-find_python("" "${MIN_VER_PYTHON2}" PYTHON2_LIBRARY PYTHON2_INCLUDE_DIR
|
||||
- PYTHON2INTERP_FOUND PYTHON2_EXECUTABLE PYTHON2_VERSION_STRING
|
||||
- PYTHON2_VERSION_MAJOR PYTHON2_VERSION_MINOR PYTHON2LIBS_FOUND
|
||||
- PYTHON2LIBS_VERSION_STRING PYTHON2_LIBRARIES PYTHON2_LIBRARY
|
||||
- PYTHON2_DEBUG_LIBRARIES PYTHON2_LIBRARY_DEBUG PYTHON2_INCLUDE_PATH
|
||||
- PYTHON2_INCLUDE_DIR PYTHON2_INCLUDE_DIR2 PYTHON2_PACKAGES_PATH
|
||||
- PYTHON2_NUMPY_INCLUDE_DIRS PYTHON2_NUMPY_VERSION)
|
||||
-
|
||||
-option(OPENCV_PYTHON3_VERSION "Python3 version" "")
|
||||
find_python("${OPENCV_PYTHON3_VERSION}" "${MIN_VER_PYTHON3}" PYTHON3_LIBRARY PYTHON3_INCLUDE_DIR
|
||||
PYTHON3INTERP_FOUND PYTHON3_EXECUTABLE PYTHON3_VERSION_STRING
|
||||
PYTHON3_VERSION_MAJOR PYTHON3_VERSION_MINOR PYTHON3LIBS_FOUND
|
||||
14
externals/vcpkg/ports/opencv3/0012-fix-zlib.patch
vendored
Executable file
14
externals/vcpkg/ports/opencv3/0012-fix-zlib.patch
vendored
Executable file
@@ -0,0 +1,14 @@
|
||||
diff --git a/cmake/OpenCVFindLibsGrfmt.cmake b/cmake/OpenCVFindLibsGrfmt.cmake
|
||||
index 6dbeca9..08e2f4a 100644
|
||||
--- a/cmake/OpenCVFindLibsGrfmt.cmake
|
||||
+++ b/cmake/OpenCVFindLibsGrfmt.cmake
|
||||
@@ -5,6 +5,9 @@
|
||||
# --- zlib (required) ---
|
||||
if(BUILD_ZLIB)
|
||||
ocv_clear_vars(ZLIB_FOUND)
|
||||
+elseif(1)
|
||||
+ ocv_clear_internal_cache_vars(ZLIB_LIBRARY ZLIB_INCLUDE_DIR)
|
||||
+ find_package(ZLIB "${MIN_VER_ZLIB}" REQUIRED)
|
||||
else()
|
||||
ocv_clear_internal_cache_vars(ZLIB_LIBRARY ZLIB_INCLUDE_DIR)
|
||||
if(ANDROID)
|
||||
500
externals/vcpkg/ports/opencv3/portfile.cmake
vendored
Executable file
500
externals/vcpkg/ports/opencv3/portfile.cmake
vendored
Executable file
@@ -0,0 +1,500 @@
|
||||
if (EXISTS "${CURRENT_INSTALLED_DIR}/share/opencv2")
|
||||
message(FATAL_ERROR "OpenCV 2 is installed, please uninstall and try again:\n vcpkg remove opencv2")
|
||||
endif()
|
||||
|
||||
if (EXISTS "${CURRENT_INSTALLED_DIR}/share/opencv4")
|
||||
message(FATAL_ERROR "OpenCV 4 is installed, please uninstall and try again:\n vcpkg remove opencv4")
|
||||
endif()
|
||||
|
||||
file(READ "${CMAKE_CURRENT_LIST_DIR}/vcpkg.json" _contents)
|
||||
string(JSON OPENCV_VERSION GET "${_contents}" version)
|
||||
|
||||
set(USE_QT_VERSION "5")
|
||||
|
||||
vcpkg_from_github(
|
||||
OUT_SOURCE_PATH SOURCE_PATH
|
||||
REPO opencv/opencv
|
||||
REF ${OPENCV_VERSION}
|
||||
SHA512 2fa9243625309a1c12c916737c94f0e2f9566f0828469b148cc1683dd1b8db8d1d58f90a36cfcaa72052964a718929451f04cda5361d8b546a63da69217d040a
|
||||
HEAD_REF master
|
||||
PATCHES
|
||||
0001-disable-downloading.patch
|
||||
0002-install-options.patch
|
||||
0003-force-package-requirements.patch
|
||||
0004-fix-eigen.patch
|
||||
0005-fix-vtk9.patch
|
||||
0006-fix-uwp.patch
|
||||
0008-devendor-quirc.patch
|
||||
0009-fix-protobuf.patch
|
||||
0010-fix-uwp-tiff-imgcodecs.patch
|
||||
0011-remove-python2.patch
|
||||
0012-fix-zlib.patch
|
||||
)
|
||||
|
||||
if(VCPKG_TARGET_ARCHITECTURE STREQUAL "arm64")
|
||||
set(TARGET_IS_AARCH64 1)
|
||||
elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL "arm")
|
||||
set(TARGET_IS_ARM 1)
|
||||
elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL "x64")
|
||||
set(TARGET_IS_X86_64 1)
|
||||
else()
|
||||
set(TARGET_IS_X86 1)
|
||||
endif()
|
||||
|
||||
file(REMOVE "${SOURCE_PATH}/cmake/FindCUDNN.cmake")
|
||||
|
||||
string(COMPARE EQUAL "${VCPKG_CRT_LINKAGE}" "static" BUILD_WITH_STATIC_CRT)
|
||||
|
||||
vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS
|
||||
FEATURES
|
||||
"contrib" WITH_CONTRIB
|
||||
"cuda" WITH_CUBLAS
|
||||
"cuda" WITH_CUDA
|
||||
"dnn" BUILD_opencv_dnn
|
||||
"eigen" WITH_EIGEN
|
||||
"ffmpeg" WITH_FFMPEG
|
||||
"flann" BUILD_opencv_flann
|
||||
"gdcm" WITH_GDCM
|
||||
"gstreamer" WITH_GSTREAMER
|
||||
"halide" WITH_HALIDE
|
||||
"jasper" WITH_JASPER
|
||||
"jpeg" WITH_JPEG
|
||||
"lapack" WITH_LAPACK
|
||||
"nonfree" OPENCV_ENABLE_NONFREE
|
||||
"openexr" WITH_OPENEXR
|
||||
"opengl" WITH_OPENGL
|
||||
"png" WITH_PNG
|
||||
"quirc" WITH_QUIRC
|
||||
"sfm" BUILD_opencv_sfm
|
||||
"tiff" WITH_TIFF
|
||||
"vtk" WITH_VTK
|
||||
"webp" WITH_WEBP
|
||||
"world" BUILD_opencv_world
|
||||
"dc1394" WITH_1394
|
||||
)
|
||||
|
||||
# Cannot use vcpkg_check_features() for "dnn", "gtk", "ipp", ovis", "python", "qt", "tbb"
|
||||
set(BUILD_opencv_dnn OFF)
|
||||
if("dnn" IN_LIST FEATURES)
|
||||
if(NOT VCPKG_TARGET_IS_ANDROID)
|
||||
set(BUILD_opencv_dnn ON)
|
||||
else()
|
||||
message(WARNING "The dnn module cannot be enabled on Android")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
set(WITH_GTK OFF)
|
||||
if("gtk" IN_LIST FEATURES)
|
||||
if(VCPKG_TARGET_IS_LINUX)
|
||||
set(WITH_GTK ON)
|
||||
else()
|
||||
message(WARNING "The gtk module cannot be enabled outside Linux")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
set(WITH_QT OFF)
|
||||
if("qt" IN_LIST FEATURES)
|
||||
set(WITH_QT ${USE_QT_VERSION})
|
||||
endif()
|
||||
|
||||
set(WITH_IPP OFF)
|
||||
if("ipp" IN_LIST FEATURES)
|
||||
set(WITH_IPP ON)
|
||||
endif()
|
||||
|
||||
set(BUILD_opencv_ovis OFF)
|
||||
if("ovis" IN_LIST FEATURES)
|
||||
set(BUILD_opencv_ovis ON)
|
||||
endif()
|
||||
|
||||
set(WITH_TBB OFF)
|
||||
if("tbb" IN_LIST FEATURES)
|
||||
set(WITH_TBB ON)
|
||||
endif()
|
||||
|
||||
set(WITH_PYTHON OFF)
|
||||
if("python" IN_LIST FEATURES)
|
||||
x_vcpkg_get_python_packages(PYTHON_VERSION "3" PACKAGES numpy OUT_PYTHON_VAR "PYTHON3")
|
||||
set(ENV{PYTHON} "${PYTHON3}")
|
||||
set(WITH_PYTHON ON)
|
||||
endif()
|
||||
|
||||
if("dnn" IN_LIST FEATURES)
|
||||
vcpkg_download_distfile(TINYDNN_ARCHIVE
|
||||
URLS "https://github.com/tiny-dnn/tiny-dnn/archive/v1.0.0a3.tar.gz"
|
||||
FILENAME "opencv-cache/tiny_dnn/adb1c512e09ca2c7a6faef36f9c53e59-v1.0.0a3.tar.gz"
|
||||
SHA512 5f2c1a161771efa67e85b1fea395953b7744e29f61187ac5a6c54c912fb195b3aef9a5827135c3668bd0eeea5ae04a33cc433e1f6683e2b7955010a2632d168b
|
||||
)
|
||||
endif()
|
||||
|
||||
# Build image quality module when building with 'contrib' feature and not UWP.
|
||||
set(BUILD_opencv_quality OFF)
|
||||
if("contrib" IN_LIST FEATURES)
|
||||
if (VCPKG_TARGET_IS_UWP)
|
||||
set(BUILD_opencv_quality OFF)
|
||||
message(WARNING "The image quality module (quality) does not build for UWP, the module has been disabled.")
|
||||
# The hdf module is silently disabled by OpenCVs buildsystem if HDF5 is not detected.
|
||||
message(WARNING "The hierarchical data format module (hdf) depends on HDF5 which doesn't support UWP, the module has been disabled.")
|
||||
else()
|
||||
set(BUILD_opencv_quality CMAKE_DEPENDS_IN_PROJECT_ONLY)
|
||||
endif()
|
||||
|
||||
vcpkg_from_github(
|
||||
OUT_SOURCE_PATH CONTRIB_SOURCE_PATH
|
||||
REPO opencv/opencv_contrib
|
||||
REF ${OPENCV_VERSION}
|
||||
SHA512 31bd55617d3a54fa020d4255e463c90caf41e10136c82a05c24ee19890f0cdc4fc049136874841dc84037dedb0562471ea0345ab1dcd5ad8a5b0218f24ae9a35
|
||||
HEAD_REF master
|
||||
PATCHES
|
||||
0007-fix-hdf5.patch
|
||||
)
|
||||
set(BUILD_WITH_CONTRIB_FLAG "-DOPENCV_EXTRA_MODULES_PATH=${CONTRIB_SOURCE_PATH}/modules")
|
||||
|
||||
vcpkg_download_distfile(OCV_DOWNLOAD
|
||||
URLS "https://raw.githubusercontent.com/opencv/opencv_3rdparty/8afa57abc8229d611c4937165d20e2a2d9fc5a12/face_landmark_model.dat"
|
||||
FILENAME "opencv-cache/data/7505c44ca4eb54b4ab1e4777cb96ac05-face_landmark_model.dat"
|
||||
SHA512 c16e60a6c4bb4de3ab39b876ae3c3f320ea56f69c93e9303bd2dff8760841dcd71be4161fff8bc71e8fe4fe8747fa8465d49d6bd8f5ebcdaea161f4bc2da7c93
|
||||
)
|
||||
|
||||
function(download_opencv_3rdparty ID COMMIT HASH)
|
||||
if(NOT EXISTS "${DOWNLOADS}/opencv-cache/${ID}/${COMMIT}.stamp")
|
||||
vcpkg_download_distfile(OCV_DOWNLOAD
|
||||
URLS "https://github.com/opencv/opencv_3rdparty/archive/${COMMIT}.zip"
|
||||
FILENAME "opencv_3rdparty-${COMMIT}.zip"
|
||||
SHA512 ${HASH}
|
||||
)
|
||||
vcpkg_extract_source_archive(extracted_ocv ARCHIVE "${OCV_DOWNLOAD}")
|
||||
file(MAKE_DIRECTORY "${DOWNLOADS}/opencv-cache/${ID}")
|
||||
file(GLOB XFEATURES2D_I "${extracted_ocv}/*")
|
||||
foreach(FILE ${XFEATURES2D_I})
|
||||
file(COPY ${FILE} DESTINATION "${DOWNLOADS}/opencv-cache/${ID}")
|
||||
get_filename_component(XFEATURES2D_I_NAME "${FILE}" NAME)
|
||||
file(MD5 "${FILE}" FILE_HASH)
|
||||
file(RENAME "${DOWNLOADS}/opencv-cache/${ID}/${XFEATURES2D_I_NAME}" "${DOWNLOADS}/opencv-cache/${ID}/${FILE_HASH}-${XFEATURES2D_I_NAME}")
|
||||
endforeach()
|
||||
file(WRITE "${DOWNLOADS}/opencv-cache/${ID}/${COMMIT}.stamp")
|
||||
endif()
|
||||
endfunction()
|
||||
|
||||
# Used for opencv's xfeature2d module
|
||||
download_opencv_3rdparty(
|
||||
xfeatures2d/boostdesc
|
||||
34e4206aef44d50e6bbcd0ab06354b52e7466d26
|
||||
2ccdc8fb59da55eabc73309a80a4d3b1e73e2341027cdcdd2d714e0f519e60f243f38f79b13ed3de32f595aa23e4f86418eed42e741f32a81b1e6e0879190601
|
||||
)
|
||||
|
||||
# Used for opencv's xfeature2d module
|
||||
download_opencv_3rdparty(
|
||||
xfeatures2d/vgg
|
||||
fccf7cd6a4b12079f73bbfb21745f9babcd4eb1d
|
||||
7051f5d6ccb938d296b919dd6d5dcddc5afb527aed456639c9984276a8f64565c084d96a72499a7756f127f8d2b1ce9ab70e4cbb3f89c4e16f82296c2a15daed
|
||||
)
|
||||
endif()
|
||||
|
||||
if(WITH_IPP)
|
||||
if(VCPKG_TARGET_IS_OSX)
|
||||
if(VCPKG_TARGET_ARCHITECTURE STREQUAL "x64")
|
||||
vcpkg_download_distfile(OCV_DOWNLOAD
|
||||
URLS "https://raw.githubusercontent.com/opencv/opencv_3rdparty/a56b6ac6f030c312b2dce17430eef13aed9af274/ippicv/ippicv_2020_mac_intel64_20191018_general.tgz"
|
||||
FILENAME "opencv-cache/ippicv/1c3d675c2a2395d094d523024896e01b-ippicv_2020_mac_intel64_20191018_general.tgz"
|
||||
SHA512 454dfaaa245e3a3b2f1ffb1aa8e27e280b03685009d66e147482b14e5796fdf2d332cac0f9b0822caedd5760fda4ee0ce2961889597456bbc18202f10bf727cd
|
||||
)
|
||||
else()
|
||||
message(WARNING "This target architecture is not supported IPPICV")
|
||||
set(WITH_IPP OFF)
|
||||
endif()
|
||||
elseif(VCPKG_TARGET_IS_LINUX)
|
||||
if(VCPKG_TARGET_ARCHITECTURE STREQUAL "x64")
|
||||
vcpkg_download_distfile(OCV_DOWNLOAD
|
||||
URLS "https://raw.githubusercontent.com/opencv/opencv_3rdparty/a56b6ac6f030c312b2dce17430eef13aed9af274/ippicv/ippicv_2020_lnx_intel64_20191018_general.tgz"
|
||||
FILENAME "opencv-cache/ippicv/7421de0095c7a39162ae13a6098782f9-ippicv_2020_lnx_intel64_20191018_general.tgz"
|
||||
SHA512 de6d80695cd6deef359376476edc4ff85fdddcf94972b936e0017f8a48aaa5d18f55c4253ae37deb83bff2f71410f68408063c88b5f3bf4df3c416aa93ceca87
|
||||
)
|
||||
elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL "x86")
|
||||
vcpkg_download_distfile(OCV_DOWNLOAD
|
||||
URLS "https://raw.githubusercontent.com/opencv/opencv_3rdparty/a56b6ac6f030c312b2dce17430eef13aed9af274/ippicv/ippicv_2020_lnx_ia32_20191018_general.tgz"
|
||||
FILENAME "opencv-cache/ippicv/ad189a940fb60eb71f291321322fe3e8-ippicv_2020_lnx_ia32_20191018_general.tgz"
|
||||
SHA512 5ca9dafc3a634e2a5f83f6a498611c990ef16d54358e9b44574b01694e9d64b118d46d6e2011506e40d37e5a9865f576f790e37ff96b7c8b503507633631a296
|
||||
)
|
||||
else()
|
||||
message(WARNING "This target architecture is not supported IPPICV")
|
||||
set(WITH_IPP OFF)
|
||||
endif()
|
||||
elseif(VCPKG_TARGET_IS_WINDOWS)
|
||||
if(VCPKG_TARGET_ARCHITECTURE STREQUAL "x64")
|
||||
vcpkg_download_distfile(OCV_DOWNLOAD
|
||||
URLS "https://raw.githubusercontent.com/opencv/opencv_3rdparty/a56b6ac6f030c312b2dce17430eef13aed9af274/ippicv/ippicv_2020_win_intel64_20191018_general.zip"
|
||||
FILENAME "opencv-cache/ippicv/879741a7946b814455eee6c6ffde2984-ippicv_2020_win_intel64_20191018_general.zip"
|
||||
SHA512 50c4af4b7fe2161d652264230389dad2330e8c95b734d04fb7565bffdab855c06d43085e480da554c56b04f8538087d49503538d5943221ee2a772ee7be4c93c
|
||||
)
|
||||
elseif(VCPKG_TARGET_ARCHITECTURE STREQUAL "x86")
|
||||
vcpkg_download_distfile(OCV_DOWNLOAD
|
||||
URLS "https://raw.githubusercontent.com/opencv/opencv_3rdparty/a56b6ac6f030c312b2dce17430eef13aed9af274/ippicv/ippicv_2020_win_ia32_20191018_general.zip"
|
||||
FILENAME "opencv-cache/ippicv/cd39bdf0c2e1cac9a61101dad7a2413e-ippicv_2020_win_ia32_20191018_general.zip"
|
||||
SHA512 058d00775d9f16955c7a557d554b8c2976ab9dbad4ba3fdb9823c0f768809edbd835e4397f01dc090a9bc80d81de834375e7006614d2a898f42e8004de0e04bf
|
||||
)
|
||||
else()
|
||||
message(WARNING "This target architecture is not supported IPPICV")
|
||||
set(WITH_IPP OFF)
|
||||
endif()
|
||||
else()
|
||||
message(WARNING "This target architecture is not supported IPPICV")
|
||||
set(WITH_IPP OFF)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
set(WITH_MSMF ON)
|
||||
if(NOT VCPKG_TARGET_IS_WINDOWS OR VCPKG_TARGET_IS_UWP)
|
||||
set(WITH_MSMF OFF)
|
||||
endif()
|
||||
|
||||
if (VCPKG_LIBRARY_LINKAGE STREQUAL static)
|
||||
if (WITH_TBB)
|
||||
message(WARNING "TBB is currently unsupported in this build configuration, turning it off")
|
||||
set(WITH_TBB OFF)
|
||||
endif()
|
||||
|
||||
if (VCPKG_TARGET_IS_WINDOWS AND BUILD_opencv_ovis)
|
||||
message(WARNING "OVIS is currently unsupported in this build configuration, turning it off")
|
||||
set(BUILD_opencv_ovis OFF)
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if("ffmpeg" IN_LIST FEATURES)
|
||||
if(VCPKG_TARGET_IS_UWP)
|
||||
set(VCPKG_C_FLAGS "/sdl- ${VCPKG_C_FLAGS}")
|
||||
set(VCPKG_CXX_FLAGS "/sdl- ${VCPKG_CXX_FLAGS}")
|
||||
endif()
|
||||
endif()
|
||||
|
||||
if("qt" IN_LIST FEATURES)
|
||||
list(APPEND ADDITIONAL_BUILD_FLAGS "-DCMAKE_AUTOMOC=ON")
|
||||
endif()
|
||||
|
||||
set(BUILD_opencv_line_descriptor ON)
|
||||
set(BUILD_opencv_saliency ON)
|
||||
set(BUILD_opencv_bgsegm ON)
|
||||
if(VCPKG_TARGET_ARCHITECTURE MATCHES "arm")
|
||||
set(BUILD_opencv_line_descriptor OFF)
|
||||
set(BUILD_opencv_saliency OFF)
|
||||
set(BUILD_opencv_bgsegm OFF)
|
||||
endif()
|
||||
|
||||
vcpkg_cmake_configure(
|
||||
SOURCE_PATH "${SOURCE_PATH}"
|
||||
OPTIONS
|
||||
###### opencv cpu recognition is broken, always using host and not target: here we bypass that
|
||||
-DOPENCV_SKIP_SYSTEM_PROCESSOR_DETECTION=TRUE
|
||||
-DAARCH64=${TARGET_IS_AARCH64}
|
||||
-DX86_64=${TARGET_IS_X86_64}
|
||||
-DX86=${TARGET_IS_X86}
|
||||
-DARM=${TARGET_IS_ARM}
|
||||
###### ocv_options
|
||||
-DOpenCV_INSTALL_BINARIES_PREFIX=
|
||||
-DOPENCV_BIN_INSTALL_PATH=bin
|
||||
-DOPENCV_INCLUDE_INSTALL_PATH=include
|
||||
-DOPENCV_LIB_INSTALL_PATH=lib
|
||||
-DOPENCV_3P_LIB_INSTALL_PATH=lib
|
||||
-DOPENCV_CONFIG_INSTALL_PATH=share/opencv
|
||||
-DINSTALL_TO_MANGLED_PATHS=OFF
|
||||
-DOPENCV_FFMPEG_USE_FIND_PACKAGE=FFMPEG
|
||||
-DOPENCV_FFMPEG_SKIP_BUILD_CHECK=TRUE
|
||||
-DCMAKE_DEBUG_POSTFIX=d
|
||||
-DOPENCV_DLLVERSION=
|
||||
-DOPENCV_DEBUG_POSTFIX=d
|
||||
-DOPENCV_GENERATE_SETUPVARS=OFF
|
||||
# Do not build docs/examples
|
||||
-DBUILD_DOCS=OFF
|
||||
-DBUILD_EXAMPLES=OFF
|
||||
###### Disable build 3rd party libs
|
||||
-DBUILD_JASPER=OFF
|
||||
-DBUILD_JPEG=OFF
|
||||
-DBUILD_OPENEXR=OFF
|
||||
-DBUILD_PNG=OFF
|
||||
-DBUILD_TIFF=OFF
|
||||
-DBUILD_WEBP=OFF
|
||||
-DBUILD_ZLIB=OFF
|
||||
-DBUILD_TBB=OFF
|
||||
-DBUILD_IPP_IW=OFF
|
||||
-DBUILD_ITT=OFF
|
||||
###### Disable build 3rd party components
|
||||
-DBUILD_PROTOBUF=OFF
|
||||
###### OpenCV Build components
|
||||
-DBUILD_opencv_apps=OFF
|
||||
-DBUILD_opencv_bgsegm=${BUILD_opencv_bgsegm}
|
||||
-DBUILD_opencv_line_descriptor=${BUILD_opencv_line_descriptor}
|
||||
-DBUILD_opencv_saliency=${BUILD_opencv_saliency}
|
||||
-DBUILD_ANDROID_PROJECT=OFF
|
||||
-DBUILD_ANDROID_EXAMPLES=OFF
|
||||
-DBUILD_PACKAGE=OFF
|
||||
-DBUILD_PERF_TESTS=OFF
|
||||
-DBUILD_TESTS=OFF
|
||||
-DBUILD_WITH_DEBUG_INFO=ON
|
||||
-DBUILD_WITH_STATIC_CRT=${BUILD_WITH_STATIC_CRT}
|
||||
-DBUILD_JAVA=OFF
|
||||
-DCURRENT_INSTALLED_DIR=${CURRENT_INSTALLED_DIR}
|
||||
###### PROTOBUF
|
||||
-DPROTOBUF_UPDATE_FILES=${BUILD_opencv_flann}
|
||||
-DUPDATE_PROTO_FILES=${BUILD_opencv_flann}
|
||||
###### PYLINT/FLAKE8
|
||||
-DENABLE_PYLINT=OFF
|
||||
-DENABLE_FLAKE8=OFF
|
||||
# CMAKE
|
||||
-DCMAKE_DISABLE_FIND_PACKAGE_Git=ON
|
||||
-DCMAKE_DISABLE_FIND_PACKAGE_JNI=ON
|
||||
# ENABLE
|
||||
-DENABLE_CXX11=ON
|
||||
###### OPENCV vars
|
||||
"-DOPENCV_DOWNLOAD_PATH=${DOWNLOADS}/opencv-cache"
|
||||
${BUILD_WITH_CONTRIB_FLAG}
|
||||
-DOPENCV_OTHER_INSTALL_PATH=share/opencv
|
||||
###### customized properties
|
||||
## Options from vcpkg_check_features()
|
||||
${FEATURE_OPTIONS}
|
||||
-DCMAKE_DISABLE_FIND_PACKAGE_Halide=ON
|
||||
-DHALIDE_ROOT_DIR=${CURRENT_INSTALLED_DIR}
|
||||
-DWITH_GTK=${WITH_GTK}
|
||||
-DWITH_QT=${WITH_QT}
|
||||
-DWITH_IPP=${WITH_IPP}
|
||||
-DWITH_MATLAB=OFF
|
||||
-DWITH_MSMF=${WITH_MSMF}
|
||||
-DWITH_OPENMP=OFF
|
||||
-DWITH_PROTOBUF=${BUILD_opencv_flann}
|
||||
-DWITH_PYTHON=${WITH_PYTHON}
|
||||
-DWITH_OPENCLAMDBLAS=OFF
|
||||
-DWITH_TBB=${WITH_TBB}
|
||||
-DWITH_OPENJPEG=OFF
|
||||
-DWITH_CPUFEATURES=OFF
|
||||
###### BUILD_options (mainly modules which require additional libraries)
|
||||
-DBUILD_opencv_ovis=${BUILD_opencv_ovis}
|
||||
-DBUILD_opencv_dnn=${BUILD_opencv_dnn}
|
||||
###### The following modules are disabled for UWP
|
||||
-DBUILD_opencv_quality=${BUILD_opencv_quality}
|
||||
###### Additional build flags
|
||||
${ADDITIONAL_BUILD_FLAGS}
|
||||
)
|
||||
|
||||
vcpkg_cmake_install()
|
||||
vcpkg_cmake_config_fixup(PACKAGE_NAME opencv CONFIG_PATH "share/opencv")
|
||||
vcpkg_copy_pdbs()
|
||||
|
||||
if (NOT VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug")
|
||||
# Update debug paths for libs in Android builds (e.g. sdk/native/staticlibs/armeabi-v7a)
|
||||
vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/share/opencv/OpenCVModules-debug.cmake"
|
||||
"\${_IMPORT_PREFIX}/sdk"
|
||||
"\${_IMPORT_PREFIX}/debug/sdk"
|
||||
)
|
||||
endif()
|
||||
|
||||
if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
|
||||
file(READ "${CURRENT_PACKAGES_DIR}/share/opencv/OpenCVModules.cmake" OPENCV_MODULES)
|
||||
set(DEPS_STRING "include(CMakeFindDependencyMacro)
|
||||
if(${BUILD_opencv_flann})
|
||||
find_dependency(Protobuf CONFIG REQUIRED)
|
||||
if(TARGET protobuf::libprotobuf)
|
||||
add_library (libprotobuf INTERFACE IMPORTED)
|
||||
set_target_properties(libprotobuf PROPERTIES
|
||||
INTERFACE_LINK_LIBRARIES protobuf::libprotobuf
|
||||
)
|
||||
else()
|
||||
add_library (libprotobuf UNKNOWN IMPORTED)
|
||||
set_target_properties(libprotobuf PROPERTIES
|
||||
IMPORTED_LOCATION \"${Protobuf_LIBRARY}\"
|
||||
INTERFACE_INCLUDE_DIRECTORIES \"${Protobuf_INCLUDE_DIR}\"
|
||||
INTERFACE_SYSTEM_INCLUDE_DIRECTORIES \"${Protobuf_INCLUDE_DIR}\"
|
||||
)
|
||||
endif()
|
||||
endif()
|
||||
find_dependency(Threads)")
|
||||
if("tiff" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(TIFF)")
|
||||
endif()
|
||||
if("cuda" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(CUDA)")
|
||||
endif()
|
||||
if(BUILD_opencv_quality)
|
||||
string(APPEND DEPS_STRING "
|
||||
# C language is required for try_compile tests in FindHDF5
|
||||
enable_language(C)
|
||||
find_dependency(HDF5)
|
||||
find_dependency(Tesseract)")
|
||||
endif()
|
||||
if(WITH_TBB)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(TBB)")
|
||||
endif()
|
||||
if("vtk" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(VTK)")
|
||||
endif()
|
||||
if("sfm" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(gflags CONFIG)\nfind_dependency(Ceres CONFIG)")
|
||||
endif()
|
||||
if("eigen" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(Eigen3 CONFIG)")
|
||||
endif()
|
||||
if("lapack" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(LAPACK)")
|
||||
endif()
|
||||
if("openexr" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(OpenEXR CONFIG)")
|
||||
endif()
|
||||
if(WITH_OPENMP)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(OpenMP)")
|
||||
endif()
|
||||
if(BUILD_opencv_ovis)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(Ogre)\nfind_dependency(Freetype)")
|
||||
endif()
|
||||
if("quirc" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(quirc)")
|
||||
endif()
|
||||
if("qt" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "
|
||||
set(CMAKE_AUTOMOC ON)
|
||||
set(CMAKE_AUTORCC ON)
|
||||
set(CMAKE_AUTOUIC ON)
|
||||
find_dependency(Qt${USE_QT_VERSION} COMPONENTS Core Gui Widgets Test Concurrent)")
|
||||
if("opengl" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "
|
||||
find_dependency(Qt${USE_QT_VERSION} COMPONENTS OpenGL)")
|
||||
endif()
|
||||
endif()
|
||||
if("ade" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(ade)")
|
||||
endif()
|
||||
if("gdcm" IN_LIST FEATURES)
|
||||
string(APPEND DEPS_STRING "\nfind_dependency(GDCM)")
|
||||
endif()
|
||||
|
||||
string(REPLACE "set(CMAKE_IMPORT_FILE_VERSION 1)"
|
||||
"set(CMAKE_IMPORT_FILE_VERSION 1)\n${DEPS_STRING}" OPENCV_MODULES "${OPENCV_MODULES}")
|
||||
|
||||
if(WITH_OPENMP)
|
||||
string(REPLACE "set_target_properties(opencv_core PROPERTIES
|
||||
INTERFACE_LINK_LIBRARIES \""
|
||||
"set_target_properties(opencv_core PROPERTIES
|
||||
INTERFACE_LINK_LIBRARIES \"\$<LINK_ONLY:OpenMP::OpenMP_CXX>;" OPENCV_MODULES "${OPENCV_MODULES}")
|
||||
endif()
|
||||
|
||||
if(BUILD_opencv_ovis)
|
||||
string(REPLACE "OgreGLSupportStatic"
|
||||
"OgreGLSupport" OPENCV_MODULES "${OPENCV_MODULES}")
|
||||
endif()
|
||||
|
||||
file(WRITE "${CURRENT_PACKAGES_DIR}/share/opencv/OpenCVModules.cmake" "${OPENCV_MODULES}")
|
||||
|
||||
|
||||
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/bin" "${CURRENT_PACKAGES_DIR}/debug/bin")
|
||||
endif()
|
||||
|
||||
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/share")
|
||||
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/include")
|
||||
file(REMOVE "${CURRENT_PACKAGES_DIR}/LICENSE")
|
||||
file(REMOVE "${CURRENT_PACKAGES_DIR}/debug/LICENSE")
|
||||
|
||||
if(VCPKG_TARGET_IS_ANDROID)
|
||||
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/README.android")
|
||||
file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/README.android")
|
||||
endif()
|
||||
|
||||
vcpkg_fixup_pkgconfig()
|
||||
|
||||
file(INSTALL "${SOURCE_PATH}/LICENSE" DESTINATION "${CURRENT_PACKAGES_DIR}/share/${PORT}" RENAME copyright)
|
||||
278
externals/vcpkg/ports/opencv3/vcpkg.json
vendored
Executable file
278
externals/vcpkg/ports/opencv3/vcpkg.json
vendored
Executable file
@@ -0,0 +1,278 @@
|
||||
{
|
||||
"name": "opencv3",
|
||||
"version": "3.4.16",
|
||||
"port-version": 9,
|
||||
"description": "Open Source Computer Vision Library",
|
||||
"homepage": "https://github.com/opencv/opencv",
|
||||
"license": "BSD-3-Clause",
|
||||
"dependencies": [
|
||||
{
|
||||
"name": "vcpkg-cmake",
|
||||
"host": true
|
||||
},
|
||||
{
|
||||
"name": "vcpkg-cmake-config",
|
||||
"host": true
|
||||
},
|
||||
{
|
||||
"name": "vcpkg-get-python-packages",
|
||||
"host": true
|
||||
},
|
||||
"zlib"
|
||||
],
|
||||
"default-features": [
|
||||
"default-features"
|
||||
],
|
||||
"features": {
|
||||
"contrib": {
|
||||
"description": "opencv_contrib module",
|
||||
"dependencies": [
|
||||
{
|
||||
"name": "hdf5",
|
||||
"platform": "!uwp & !(windows & (arm | arm64))"
|
||||
},
|
||||
{
|
||||
"name": "opencv3",
|
||||
"features": [
|
||||
"dnn"
|
||||
]
|
||||
},
|
||||
{
|
||||
"name": "tesseract",
|
||||
"platform": "!uwp & !(windows & (arm | arm64))"
|
||||
}
|
||||
]
|
||||
},
|
||||
"cuda": {
|
||||
"description": "CUDA support for opencv",
|
||||
"dependencies": [
|
||||
"cuda",
|
||||
"cudnn",
|
||||
{
|
||||
"name": "opencv3",
|
||||
"features": [
|
||||
"contrib"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"dc1394": {
|
||||
"description": "Dc1394 support for opencv",
|
||||
"dependencies": [
|
||||
"libdc1394"
|
||||
]
|
||||
},
|
||||
"default-features": {
|
||||
"description": "Platform-dependent default features",
|
||||
"dependencies": [
|
||||
{
|
||||
"name": "opencv3",
|
||||
"default-features": false,
|
||||
"features": [
|
||||
"dnn",
|
||||
"jpeg",
|
||||
"png",
|
||||
"quirc",
|
||||
"tiff",
|
||||
"webp"
|
||||
]
|
||||
},
|
||||
{
|
||||
"name": "opencv3",
|
||||
"default-features": false,
|
||||
"features": [
|
||||
"gtk"
|
||||
],
|
||||
"platform": "linux"
|
||||
}
|
||||
]
|
||||
},
|
||||
"dnn": {
|
||||
"description": "Enable dnn module",
|
||||
"dependencies": [
|
||||
{
|
||||
"name": "opencv3",
|
||||
"features": [
|
||||
"flann"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"eigen": {
|
||||
"description": "Eigen support for opencv",
|
||||
"dependencies": [
|
||||
"eigen3"
|
||||
]
|
||||
},
|
||||
"ffmpeg": {
|
||||
"description": "ffmpeg support for opencv",
|
||||
"dependencies": [
|
||||
{
|
||||
"name": "ffmpeg",
|
||||
"default-features": false,
|
||||
"features": [
|
||||
"avcodec",
|
||||
"avformat",
|
||||
"swresample",
|
||||
"swscale"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"flann": {
|
||||
"description": "opencv_flann module",
|
||||
"dependencies": [
|
||||
"protobuf"
|
||||
]
|
||||
},
|
||||
"gdcm": {
|
||||
"description": "GDCM support for opencv",
|
||||
"dependencies": [
|
||||
"gdcm"
|
||||
]
|
||||
},
|
||||
"gstreamer": {
|
||||
"description": "gstreamer support for opencv",
|
||||
"dependencies": [
|
||||
"gstreamer"
|
||||
]
|
||||
},
|
||||
"gtk": {
|
||||
"description": "GTK support for opencv",
|
||||
"dependencies": [
|
||||
"gtk"
|
||||
]
|
||||
},
|
||||
"halide": {
|
||||
"description": "Halide support for opencv",
|
||||
"dependencies": [
|
||||
"halide",
|
||||
{
|
||||
"name": "opencv3",
|
||||
"default-features": false
|
||||
},
|
||||
{
|
||||
"name": "opencv3",
|
||||
"features": [
|
||||
"dnn"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"ipp": {
|
||||
"description": "Enable Intel Integrated Performance Primitives"
|
||||
},
|
||||
"jasper": {
|
||||
"description": "JPEG 2000 support for opencv",
|
||||
"dependencies": [
|
||||
"jasper"
|
||||
]
|
||||
},
|
||||
"jpeg": {
|
||||
"description": "JPEG support for opencv",
|
||||
"dependencies": [
|
||||
"libjpeg-turbo"
|
||||
]
|
||||
},
|
||||
"lapack": {
|
||||
"description": "LAPACK support for opencv",
|
||||
"dependencies": [
|
||||
"blas",
|
||||
"lapack"
|
||||
]
|
||||
},
|
||||
"nonfree": {
|
||||
"description": "allow nonfree and unredistributable libraries"
|
||||
},
|
||||
"openexr": {
|
||||
"description": "OpenEXR support for opencv",
|
||||
"dependencies": [
|
||||
"openexr"
|
||||
]
|
||||
},
|
||||
"opengl": {
|
||||
"description": "opengl support for opencv",
|
||||
"dependencies": [
|
||||
"opengl"
|
||||
]
|
||||
},
|
||||
"ovis": {
|
||||
"description": "opencv_ovis module",
|
||||
"dependencies": [
|
||||
"ogre",
|
||||
{
|
||||
"name": "opencv3",
|
||||
"features": [
|
||||
"contrib"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"png": {
|
||||
"description": "PNG support for opencv",
|
||||
"dependencies": [
|
||||
"libpng"
|
||||
]
|
||||
},
|
||||
"python": {
|
||||
"description": "Python wrapper support for opencv"
|
||||
},
|
||||
"qt": {
|
||||
"description": "Qt GUI support for opencv",
|
||||
"dependencies": [
|
||||
{
|
||||
"name": "qt5-base",
|
||||
"default-features": false
|
||||
}
|
||||
]
|
||||
},
|
||||
"quirc": {
|
||||
"description": "Enable QR code module",
|
||||
"dependencies": [
|
||||
"quirc"
|
||||
]
|
||||
},
|
||||
"sfm": {
|
||||
"description": "opencv_sfm module",
|
||||
"dependencies": [
|
||||
"ceres",
|
||||
"eigen3",
|
||||
"gflags",
|
||||
"glog",
|
||||
{
|
||||
"name": "opencv3",
|
||||
"features": [
|
||||
"contrib"
|
||||
]
|
||||
}
|
||||
]
|
||||
},
|
||||
"tbb": {
|
||||
"description": "Enable Intel Threading Building Blocks",
|
||||
"dependencies": [
|
||||
"tbb"
|
||||
]
|
||||
},
|
||||
"tiff": {
|
||||
"description": "TIFF support for opencv",
|
||||
"dependencies": [
|
||||
"tiff"
|
||||
]
|
||||
},
|
||||
"vtk": {
|
||||
"description": "vtk support for opencv",
|
||||
"dependencies": [
|
||||
"vtk"
|
||||
]
|
||||
},
|
||||
"webp": {
|
||||
"description": "WebP support for opencv",
|
||||
"dependencies": [
|
||||
"libwebp"
|
||||
]
|
||||
},
|
||||
"world": {
|
||||
"description": "Compile to a single package support for opencv"
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user