aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStefano Sinigardi <stesinigardi@hotmail.com>2020-12-11 23:16:29 +0100
committerGitHub <noreply@github.com>2020-12-11 14:16:29 -0800
commite054fe2b20469c894b88be4ac466776f9f653954 (patch)
treec38d367b5974c69f7d824b96f8dcdf594dd32041
parentc2329ab26a6e9e06da101d8541c393c102ba6c8c (diff)
downloadvcpkg-e054fe2b20469c894b88be4ac466776f9f653954.tar.gz
vcpkg-e054fe2b20469c894b88be4ac466776f9f653954.zip
[OpenCV] fix compatibility with VTK9 (#12785)
-rw-r--r--ports/ceres/portfile.cmake6
-rw-r--r--ports/ceres/vcpkg.json2
-rw-r--r--ports/opencv2/CONTROL6
-rw-r--r--ports/opencv2/portfile.cmake12
-rw-r--r--ports/opencv3/0005-fix-vtk9.patch484
-rw-r--r--ports/opencv3/CONTROL2
-rw-r--r--ports/opencv3/portfile.cmake97
-rw-r--r--ports/opencv4/0006-fix-vtk9.patch41
-rw-r--r--ports/opencv4/0007-fix-vtk9-contrib.patch470
-rw-r--r--ports/opencv4/CONTROL2
-rw-r--r--ports/opencv4/portfile.cmake19
-rw-r--r--ports/tesseract/CONTROL4
-rw-r--r--ports/tesseract/portfile.cmake10
-rw-r--r--ports/vtk/module-name-mangling.patch18
-rw-r--r--ports/vtk/portfile.cmake23
-rw-r--r--scripts/test_ports/vcpkg-ci-opencv/CONTROL6
-rw-r--r--scripts/test_ports/vcpkg-ci-opencv/portfile.cmake1
17 files changed, 1124 insertions, 79 deletions
diff --git a/ports/ceres/portfile.cmake b/ports/ceres/portfile.cmake
index fd8d0ec40..e58130623 100644
--- a/ports/ceres/portfile.cmake
+++ b/ports/ceres/portfile.cmake
@@ -54,6 +54,12 @@ if(VCPKG_TARGET_IS_WINDOWS)
else()
vcpkg_fixup_cmake_targets(CONFIG_PATH lib${LIB_SUFFIX}/cmake/Ceres)
endif()
+file(READ ${CURRENT_PACKAGES_DIR}/share/ceres/CeresConfig.cmake CERES_CONFIG)
+string(REPLACE "set_target_properties(ceres PROPERTIES INTERFACE_LINK_LIBRARIES Ceres::ceres)"
+ "set_target_properties(ceres PROPERTIES INTERFACE_LINK_LIBRARIES Ceres::ceres)
+ set(CMAKE_CXX_STANDARD 14)
+ set(CMAKE_CXX_STANDARD_REQUIRED ON)" CERES_CONFIG "${CERES_CONFIG}")
+file(WRITE ${CURRENT_PACKAGES_DIR}/share/ceres/CeresConfig.cmake "${CERES_CONFIG}")
vcpkg_copy_pdbs()
diff --git a/ports/ceres/vcpkg.json b/ports/ceres/vcpkg.json
index 7a7177833..d89a0179f 100644
--- a/ports/ceres/vcpkg.json
+++ b/ports/ceres/vcpkg.json
@@ -1,7 +1,7 @@
{
"name": "ceres",
"version-string": "2.0.0",
- "port-version": 1,
+ "port-version": 2,
"description": "non-linear optimization package",
"homepage": "https://github.com/ceres-solver/ceres-solver",
"dependencies": [
diff --git a/ports/opencv2/CONTROL b/ports/opencv2/CONTROL
index 621cb34bd..1e9f57cdb 100644
--- a/ports/opencv2/CONTROL
+++ b/ports/opencv2/CONTROL
@@ -1,6 +1,6 @@
Source: opencv2
Version: 2.4.13.7
-Port-Version: 3
+Port-Version: 4
Build-Depends: zlib
Description: computer vision library, version 2
Default-Features: eigen, jpeg, opengl, png, tiff
@@ -45,9 +45,5 @@ Feature: tiff
Build-Depends: tiff
Description: TIFF support for opencv
-Feature: vtk
-Build-Depends: vtk
-Description: vtk support for opencv
-
Feature: world
Description: Compile to a single package support for opencv
diff --git a/ports/opencv2/portfile.cmake b/ports/opencv2/portfile.cmake
index 8e1fca5fb..6cd8b48a7 100644
--- a/ports/opencv2/portfile.cmake
+++ b/ports/opencv2/portfile.cmake
@@ -45,23 +45,11 @@ vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS
"world" BUILD_opencv_world
)
-set(WITH_VTK OFF)
-if("vtk" IN_LIST FEATURES)
- set(WITH_VTK ON)
-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_VTK)
- message(WARNING "VTK is currently unsupported in this build configuration, turning it off")
- set(WITH_VTK OFF)
- endif()
-endif()
-
if("ffmpeg" IN_LIST FEATURES)
if(VCPKG_TARGET_IS_UWP)
set(VCPKG_C_FLAGS "/sdl- ${VCPKG_C_FLAGS}")
diff --git a/ports/opencv3/0005-fix-vtk9.patch b/ports/opencv3/0005-fix-vtk9.patch
new file mode 100644
index 000000000..137302ee3
--- /dev/null
+++ b/ports/opencv3/0005-fix-vtk9.patch
@@ -0,0 +1,484 @@
+diff --git a/cmake/OpenCVDetectVTK.cmake b/cmake/OpenCVDetectVTK.cmake
+index 1495688..4c83504 100644
+--- 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;
+diff --git a/modules/viz/src/vizimpl.cpp b/modules/viz/src/vizimpl.cpp
+index 23cba75..89f1249 100644
+--- 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
+diff --git a/modules/viz/src/vtk/vtkOBJWriter.cpp b/modules/viz/src/vtk/vtkOBJWriter.cpp
+index 296b6eb..2e5764f 100644
+--- 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); )
+ {
+diff --git a/modules/viz/src/vtk/vtkXYZReader.cpp b/modules/viz/src/vtk/vtkXYZReader.cpp
+index 57726ea..3b9265f 100644
+--- 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);
+diff --git a/modules/viz/src/vtk/vtkXYZWriter.cpp b/modules/viz/src/vtk/vtkXYZWriter.cpp
+index cf95e3c..56a26b3 100644
+--- 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);
+diff --git a/modules/viz/test/test_tutorial2.cpp b/modules/viz/test/test_tutorial2.cpp
+index 6b2972f..a4b5b99 100644
+--- 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);
+ }
+ }
+
+diff --git a/modules/viz/test/test_tutorial3.cpp b/modules/viz/test/test_tutorial3.cpp
+index 232130f..32e33b1 100644
+--- 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)
+diff --git a/modules/viz/test/test_viz3d.cpp b/modules/viz/test/test_viz3d.cpp
+index cdf8a00..4ab05c3 100644
+--- 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
+diff --git a/modules/viz/test/tests_simple.cpp b/modules/viz/test/tests_simple.cpp
+index 12d696d..5584483 100644
+--- 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
diff --git a/ports/opencv3/CONTROL b/ports/opencv3/CONTROL
index f6c2f926b..e48c5dc1d 100644
--- a/ports/opencv3/CONTROL
+++ b/ports/opencv3/CONTROL
@@ -1,6 +1,6 @@
Source: opencv3
Version: 3.4.10
-Port-Version: 2
+Port-Version: 4
Build-Depends: zlib
Homepage: https://github.com/opencv/opencv
Description: computer vision library
diff --git a/ports/opencv3/portfile.cmake b/ports/opencv3/portfile.cmake
index 98f3b32ed..e194e0e9a 100644
--- a/ports/opencv3/portfile.cmake
+++ b/ports/opencv3/portfile.cmake
@@ -18,6 +18,7 @@ vcpkg_from_github(
0001-disable-downloading.patch
0002-install-options.patch
0003-force-package-requirements.patch
+ 0005-fix-vtk9.patch
0009-fix-uwp.patch
)
@@ -44,11 +45,12 @@ vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS
"qt" WITH_QT
"sfm" BUILD_opencv_sfm
"tiff" WITH_TIFF
+ "vtk" WITH_VTK
"webp" WITH_WEBP
"world" BUILD_opencv_world
)
-# Cannot use vcpkg_check_features() for "dnn", "ipp", ovis", "tbb", and "vtk".
+# Cannot use vcpkg_check_features() for "dnn", "ipp", ovis", "tbb"
# As the respective value of their variables can be unset conditionally.
set(BUILD_opencv_dnn OFF)
if("dnn" IN_LIST FEATURES)
@@ -74,11 +76,6 @@ if("tbb" IN_LIST FEATURES)
set(WITH_TBB ON)
endif()
-set(WITH_VTK OFF)
-if("vtk" IN_LIST FEATURES)
- set(WITH_VTK 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"
@@ -214,11 +211,6 @@ if (VCPKG_LIBRARY_LINKAGE STREQUAL static)
set(WITH_TBB OFF)
endif()
- if (WITH_VTK)
- message(WARNING "VTK is currently unsupported in this build configuration, turning it off")
- set(WITH_VTK 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)
@@ -258,6 +250,7 @@ vcpkg_configure_cmake(
-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
@@ -320,7 +313,6 @@ vcpkg_configure_cmake(
-DWITH_PROTOBUF=${BUILD_opencv_flann}
-DWITH_OPENCLAMDBLAS=OFF
-DWITH_TBB=${WITH_TBB}
- -DWITH_VTK=${WITH_VTK}
-DWITH_OPENJPEG=OFF
###### WITH PROPERTIES explicitly disabled, they have problems with libraries if already installed by user and that are "involuntarily" found during install
-DWITH_LAPACK=OFF
@@ -339,17 +331,16 @@ vcpkg_copy_pdbs()
if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
file(READ ${CURRENT_PACKAGES_DIR}/share/opencv/OpenCVModules.cmake OPENCV_MODULES)
- string(REPLACE "set(CMAKE_IMPORT_FILE_VERSION 1)"
- "set(CMAKE_IMPORT_FILE_VERSION 1)
-find_package(Protobuf REQUIRED)
-if(Protobuf_FOUND)
+ set(DEPS_STRING "include(CMakeFindDependencyMacro)
+find_dependency(protobuf CONFIG)
+if(protobuf_FOUND)
if(TARGET protobuf::libprotobuf)
- add_library(libprotobuf INTERFACE IMPORTED)
+ add_library (libprotobuf INTERFACE IMPORTED)
set_target_properties(libprotobuf PROPERTIES
INTERFACE_LINK_LIBRARIES protobuf::libprotobuf
)
else()
- add_library(libprotobuf UNKNOWN IMPORTED)
+ add_library (libprotobuf UNKNOWN IMPORTED)
set_target_properties(libprotobuf PROPERTIES
IMPORTED_LOCATION \"${Protobuf_LIBRARY}\"
INTERFACE_INCLUDE_DIRECTORIES \"${Protobuf_INCLUDE_DIR}\"
@@ -357,25 +348,64 @@ if(Protobuf_FOUND)
)
endif()
endif()
-find_package(CUDA QUIET)
-find_package(Threads QUIET)
-find_package(TIFF QUIET)
-find_package(HDF5 QUIET)
-find_package(Freetype QUIET)
-find_package(Ogre QUIET)
-find_package(gflags QUIET)
-find_package(Ceres QUIET)
-find_package(ade QUIET)
-find_package(VTK QUIET)
-find_package(OpenMP QUIET)
-find_package(Tesseract QUIET)
-find_package(OpenEXR QUIET)
+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("openexr" IN_LIST FEATURES)
+ string(APPEND DEPS_STRING "\nfind_dependency(OpenEXR CONFIG)")
+ endif()
+ if(WITH_OPENMP)
+ string(APPEND DEPS_STRING "\nfind_dependency(OpenMP CONFIG)")
+ endif()
+ if(BUILD_opencv_ovis)
+ string(APPEND DEPS_STRING "\nfind_dependency(Ogre)\nfind_dependency(Freetype)")
+ endif()
+ if("qt" IN_LIST FEATURES)
+ string(APPEND DEPS_STRING "
set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTORCC ON)
set(CMAKE_AUTOUIC ON)
+find_dependency(Qt5 COMPONENTS OpenGL Concurrent Test)")
+ 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()
-find_package(Qt5 COMPONENTS OpenGL Concurrent Test QUIET)
-find_package(GDCM QUIET)" OPENCV_MODULES "${OPENCV_MODULES}")
+ 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"
@@ -384,6 +414,7 @@ find_package(GDCM QUIET)" OPENCV_MODULES "${OPENCV_MODULES}")
file(WRITE ${CURRENT_PACKAGES_DIR}/share/opencv/OpenCVModules.cmake "${OPENCV_MODULES}")
+
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/bin ${CURRENT_PACKAGES_DIR}/debug/bin)
endif()
diff --git a/ports/opencv4/0006-fix-vtk9.patch b/ports/opencv4/0006-fix-vtk9.patch
new file mode 100644
index 000000000..7942b0aa4
--- /dev/null
+++ b/ports/opencv4/0006-fix-vtk9.patch
@@ -0,0 +1,41 @@
+diff --git a/cmake/OpenCVDetectVTK.cmake b/cmake/OpenCVDetectVTK.cmake
+index 0f2b958..4c83504 100644
+--- 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/ports/opencv4/0007-fix-vtk9-contrib.patch b/ports/opencv4/0007-fix-vtk9-contrib.patch
new file mode 100644
index 000000000..1db18f1c6
--- /dev/null
+++ b/ports/opencv4/0007-fix-vtk9-contrib.patch
@@ -0,0 +1,470 @@
+diff --git a/modules/viz/CMakeLists.txt b/modules/viz/CMakeLists.txt
+index 89a9c3e098..3426e1dd26 100644
+--- a/modules/viz/CMakeLists.txt
++++ b/modules/viz/CMakeLists.txt
+@@ -3,7 +3,9 @@ if(NOT HAVE_VTK)
+ endif()
+
+ set(the_description "Viz")
+-include(${VTK_USE_FILE})
++if(VTK_VERSION VERSION_LESS 8.90)
++ include(${VTK_USE_FILE})
++endif()
+
+ if(NOT BUILD_SHARED_LIBS)
+ # We observed conflict between builtin 3rdparty libraries and
+diff --git a/modules/viz/src/precomp.hpp b/modules/viz/src/precomp.hpp
+index f92fdb6ac2..4c4bf7c599 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 65571a192e..0e14477891 100644
+--- a/modules/viz/src/types.cpp
++++ b/modules/viz/src/types.cpp
+@@ -100,7 +100,8 @@ cv::viz::Mesh cv::viz::Mesh::load(const String& file, int type)
+ 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;
+diff --git a/modules/viz/src/vizimpl.cpp b/modules/viz/src/vizimpl.cpp
+index 2c291c0569..2c7ce997a4 100644
+--- 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
+diff --git a/modules/viz/src/vtk/vtkOBJWriter.cpp b/modules/viz/src/vtk/vtkOBJWriter.cpp
+index 296b6eb065..2e5764fc27 100644
+--- 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); )
+ {
+diff --git a/modules/viz/src/vtk/vtkXYZReader.cpp b/modules/viz/src/vtk/vtkXYZReader.cpp
+index 57726eae9b..3b9265fed6 100644
+--- 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);
+diff --git a/modules/viz/src/vtk/vtkXYZWriter.cpp b/modules/viz/src/vtk/vtkXYZWriter.cpp
+index cf95e3c6a0..56a26b38a0 100644
+--- 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);
+
+diff --git a/modules/viz/test/test_tutorial2.cpp b/modules/viz/test/test_tutorial2.cpp
+index 6b2972f0af..a4b5b99582 100644
+--- 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);
+ }
+ }
+
+diff --git a/modules/viz/test/test_tutorial3.cpp b/modules/viz/test/test_tutorial3.cpp
+index 232130f0a6..32e33b1902 100644
+--- 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)
+diff --git a/modules/viz/test/test_viz3d.cpp b/modules/viz/test/test_viz3d.cpp
+index cdf8a00ad7..4ab05c3e0a 100644
+--- 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
+diff --git a/modules/viz/test/tests_simple.cpp b/modules/viz/test/tests_simple.cpp
+index 12d696dfba..5584483f4f 100644
+--- 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
+
+diff --git a/modules/viz/CMakeLists.txt b/modules/viz/CMakeLists.txt
+index 3426e1dd26..cd225960ce 100644
+--- a/modules/viz/CMakeLists.txt
++++ b/modules/viz/CMakeLists.txt
+@@ -3,9 +3,6 @@ if(NOT HAVE_VTK)
+ endif()
+
+ set(the_description "Viz")
+-if(VTK_VERSION VERSION_LESS 8.90)
+- include(${VTK_USE_FILE})
+-endif()
+
+ if(NOT BUILD_SHARED_LIBS)
+ # We observed conflict between builtin 3rdparty libraries and
+@@ -37,7 +34,14 @@ ocv_add_accuracy_tests()
+ ocv_add_perf_tests()
+ ocv_add_samples(opencv_imgproc opencv_calib3d opencv_features2d opencv_flann)
+
+-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/types.cpp b/modules/viz/src/types.cpp
+index 0e14477891..e9a470cf83 100644
+--- a/modules/viz/src/types.cpp
++++ b/modules/viz/src/types.cpp
+@@ -97,6 +97,7 @@ 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();
diff --git a/ports/opencv4/CONTROL b/ports/opencv4/CONTROL
index 0c928ab7b..1a6882900 100644
--- a/ports/opencv4/CONTROL
+++ b/ports/opencv4/CONTROL
@@ -88,7 +88,7 @@ Build-Depends: tiff
Description: TIFF support for opencv
Feature: vtk
-Build-Depends: vtk
+Build-Depends: opencv4[contrib], vtk
Description: vtk support for opencv
Feature: webp
diff --git a/ports/opencv4/portfile.cmake b/ports/opencv4/portfile.cmake
index 4c7d900c6..23c9184e7 100644
--- a/ports/opencv4/portfile.cmake
+++ b/ports/opencv4/portfile.cmake
@@ -19,6 +19,7 @@ vcpkg_from_github(
0002-install-options.patch
0003-force-package-requirements.patch
0004-fix-policy-CMP0057.patch
+ 0006-fix-vtk9.patch
0006-jpeg2000_getref.patch
0009-fix-uwp.patch
0010-fix-interface_link_libraries.patch # Remove this patch when the next update
@@ -48,11 +49,12 @@ vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS
"qt" WITH_QT
"sfm" BUILD_opencv_sfm
"tiff" WITH_TIFF
+ "vtk" WITH_VTK
"webp" WITH_WEBP
"world" BUILD_opencv_world
)
-# Cannot use vcpkg_check_features() for "dnn", ipp", "openmp", "ovis", "tbb", and "vtk".
+# Cannot use vcpkg_check_features() for "dnn", ipp", "openmp", "ovis", "tbb"
# As the respective value of their variables can be unset conditionally.
set(BUILD_opencv_dnn OFF)
if("dnn" IN_LIST FEATURES)
@@ -87,11 +89,6 @@ if("tbb" IN_LIST FEATURES)
set(WITH_TBB ON)
endif()
-set(WITH_VTK OFF)
-if("vtk" IN_LIST FEATURES)
- set(WITH_VTK 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"
@@ -128,6 +125,7 @@ if("contrib" IN_LIST FEATURES)
HEAD_REF master
PATCHES
0005-add-missing-stdexcept-include.patch
+ 0007-fix-vtk9-contrib.patch
)
set(BUILD_WITH_CONTRIB_FLAG "-DOPENCV_EXTRA_MODULES_PATH=${CONTRIB_SOURCE_PATH}/modules")
@@ -256,11 +254,6 @@ if (VCPKG_LIBRARY_LINKAGE STREQUAL static)
set(WITH_TBB OFF)
endif()
- if (WITH_VTK)
- message(WARNING "VTK is currently unsupported in this build configuration, turning it off")
- set(WITH_VTK 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)
@@ -291,6 +284,7 @@ vcpkg_configure_cmake(
-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
@@ -351,7 +345,6 @@ vcpkg_configure_cmake(
-DWITH_OPENMP=${WITH_OPENMP}
-DWITH_PROTOBUF=${BUILD_opencv_dnn}
-DWITH_TBB=${WITH_TBB}
- -DWITH_VTK=${WITH_VTK}
-DWITH_OPENJPEG=OFF
###### WITH PROPERTIES explicitly disabled, they have problems with libraries if already installed by user and that are "involuntarily" found during install
-DWITH_LAPACK=OFF
@@ -406,7 +399,7 @@ find_dependency(Tesseract)")
if(WITH_TBB)
string(APPEND DEPS_STRING "\nfind_dependency(TBB)")
endif()
- if(WITH_VTK)
+ if("vtk" IN_LIST FEATURES)
string(APPEND DEPS_STRING "\nfind_dependency(VTK)")
endif()
if("sfm" IN_LIST FEATURES)
diff --git a/ports/tesseract/CONTROL b/ports/tesseract/CONTROL
index eb90d70e1..530abc04d 100644
--- a/ports/tesseract/CONTROL
+++ b/ports/tesseract/CONTROL
@@ -1,9 +1,9 @@
Source: tesseract
Version: 4.1.1
-Port-Version: 3
+Port-Version: 5
Homepage: https://github.com/tesseract-ocr/tesseract
Description: An OCR Engine that was developed at HP Labs between 1985 and 1995... and now at Google.
-Build-Depends: leptonica
+Build-Depends: leptonica, libarchive
Feature: training-tools
Description: build training tools
diff --git a/ports/tesseract/portfile.cmake b/ports/tesseract/portfile.cmake
index d141625b6..d08e31907 100644
--- a/ports/tesseract/portfile.cmake
+++ b/ports/tesseract/portfile.cmake
@@ -39,6 +39,16 @@ vcpkg_configure_cmake(
vcpkg_install_cmake()
vcpkg_fixup_cmake_targets(CONFIG_PATH cmake)
+file(READ ${CURRENT_PACKAGES_DIR}/share/tesseract/TesseractConfig.cmake TESSERACT_CONFIG)
+string(REPLACE "find_package(Leptonica REQUIRED)"
+ "find_package(Leptonica REQUIRED)
+find_package(OpenSSL REQUIRED)
+find_package(ZLIB REQUIRED)
+find_package(BZip2 REQUIRED)
+find_package(LibXml2 REQUIRED)
+find_package(zstd REQUIRED)
+find_package(LibLZMA REQUIRED)" TESSERACT_CONFIG "${TESSERACT_CONFIG}")
+file(WRITE ${CURRENT_PACKAGES_DIR}/share/tesseract/TesseractConfig.cmake "${TESSERACT_CONFIG}")
vcpkg_copy_tools(TOOL_NAMES tesseract AUTO_CLEAN)
diff --git a/ports/vtk/module-name-mangling.patch b/ports/vtk/module-name-mangling.patch
new file mode 100644
index 000000000..d1bc96c39
--- /dev/null
+++ b/ports/vtk/module-name-mangling.patch
@@ -0,0 +1,18 @@
+--- a/CMake/vtkModule.cmake
++++ b/CMake/vtkModule.cmake
+@@ -4409,6 +4409,15 @@ endif ()\n\n")
+ foreach (_vtk_export_module IN LISTS _vtk_export_MODULES)
+ get_property(_vtk_export_target_name GLOBAL
+ PROPERTY "_vtk_module_${_vtk_export_module}_target_name")
++ # Use the export name of the target if it has one set.
++ get_property(_vtk_export_target_has_export_name
++ TARGET "${_vtk_export_target_name}"
++ PROPERTY EXPORT_NAME SET)
++ if (_vtk_export_target_has_export_name)
++ get_property(_vtk_export_target_name
++ TARGET "${_vtk_export_target_name}"
++ PROPERTY EXPORT_NAME)
++ endif ()
+ set(_vtk_export_base "_vtk_module_find_package_${_vtk_export_module}")
+ get_property(_vtk_export_packages GLOBAL
+ PROPERTY "${_vtk_export_base}")
diff --git a/ports/vtk/portfile.cmake b/ports/vtk/portfile.cmake
index d2dc3e2c7..c3ebfbe6e 100644
--- a/ports/vtk/portfile.cmake
+++ b/ports/vtk/portfile.cmake
@@ -123,9 +123,10 @@ vcpkg_from_github(
vtkm.patch # To include an external VTKm build (v.1.5 required)
pegtl.patch
pythonwrapper.patch # Required by ParaView to Wrap required classes
- NoUndefDebug.patch # Required to link against correct Python library depending on build type.
+ NoUndefDebug.patch # Required to link against correct Python library depending on build type.
python_debug.patch
fix-using-hdf5.patch
+ module-name-mangling.patch
# Last patch TODO: Patch out internal loguru
FindExpat.patch # The find_library calls are taken care of by vcpkg-cmake-wrapper.cmake of expat
)
@@ -271,29 +272,25 @@ endif()
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/include)
file(REMOVE_RECURSE ${CURRENT_PACKAGES_DIR}/debug/share)
-# =============================================================================
-# Handle copyright
-file(INSTALL ${SOURCE_PATH}/Copyright.txt DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT} RENAME copyright)
-
vcpkg_copy_tool_dependencies("${CURRENT_PACKAGES_DIR}/tools/vtk")
## Files Modules needed by ParaView
if("paraview" IN_LIST FEATURES)
- set(VTK_CMAKE_NEEDED vtkCompilerChecks vtkCompilerPlatformFlags vtkCompilerExtraFlags vtkInitializeBuildType
+ set(VTK_CMAKE_NEEDED vtkCompilerChecks vtkCompilerPlatformFlags vtkCompilerExtraFlags vtkInitializeBuildType
vtkSupportMacros vtkDirectories vtkVersion FindPythonModules vtkModuleDebugging vtkExternalData)
foreach(module ${VTK_CMAKE_NEEDED})
file(INSTALL "${SOURCE_PATH}/CMake/${module}.cmake" DESTINATION "${CURRENT_PACKAGES_DIR}/share/vtk")
endforeach()
-
+
## Check List on UPDATE !!
file(INSTALL "${SOURCE_PATH}/CMake/vtkRequireLargeFilesSupport.cxx" DESTINATION "${CURRENT_PACKAGES_DIR}/share/vtk")
file(INSTALL "${SOURCE_PATH}/GUISupport/Qt/QVTKOpenGLWidget.h" DESTINATION "${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION}") # Legacy header
-
+
file(INSTALL "${SOURCE_PATH}/Common/Core/vtkRange.h" DESTINATION "${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION}") # this should get installed by VTK
file(INSTALL "${SOURCE_PATH}/Common/Core/vtkRangeIterableTraits.h" DESTINATION "${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION}") # this should get installed by VTK
file(INSTALL "${SOURCE_PATH}/Common/DataModel/vtkCompositeDataSetNodeReference.h" DESTINATION "${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION}") # this should get installed by VTK
- #ParaView requires some internal headers
+ #ParaView requires some internal headers
file(INSTALL "${SOURCE_PATH}/Rendering/Annotation/vtkScalarBarActorInternal.h" DESTINATION "${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION}")
file(INSTALL "${SOURCE_PATH}/Filters/Statistics/vtkStatisticsAlgorithmPrivate.h" DESTINATION "${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION}")
file(INSTALL "${SOURCE_PATH}/Rendering/OpenGL2/vtkCompositePolyDataMapper2Internal.h" DESTINATION "${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION}")
@@ -306,13 +303,13 @@ if(VCPKG_LIBRARY_LINKAGE STREQUAL "static")
file(INSTALL ${STATIC_PYTHON_FILES} DESTINATION ${CURRENT_PACKAGES_DIR}/include/vtk-${VTK_SHORT_VERSION})
endif()
endif()
-
+
#remove one get_filename_component(_vtk_module_import_prefix "${_vtk_module_import_prefix}" DIRECTORY) from vtk-prefix.cmake and VTK-vtk-module-properties and vtk-python.cmake
set(filenames_fix_prefix vtk-prefix VTK-vtk-module-properties vtk-python)
foreach(name IN LISTS filenames_fix_prefix)
if(EXISTS "${CURRENT_PACKAGES_DIR}/share/vtk/${name}.cmake")
file(READ "${CURRENT_PACKAGES_DIR}/share/vtk/${name}.cmake" _contents)
- string(REPLACE
+ string(REPLACE
[[set(_vtk_module_import_prefix "${CMAKE_CURRENT_LIST_DIR}")
get_filename_component(_vtk_module_import_prefix "${_vtk_module_import_prefix}" DIRECTORY)]]
[[set(_vtk_module_import_prefix "${CMAKE_CURRENT_LIST_DIR}")]] _contents "${_contents}")
@@ -321,3 +318,7 @@ else()
debug_message("FILE:${CURRENT_PACKAGES_DIR}/share/vtk/${name}.cmake does not exist! No prefix correction!")
endif()
endforeach()
+
+# =============================================================================
+# Handle copyright
+file(INSTALL ${SOURCE_PATH}/Copyright.txt DESTINATION ${CURRENT_PACKAGES_DIR}/share/${PORT} RENAME copyright)
diff --git a/scripts/test_ports/vcpkg-ci-opencv/CONTROL b/scripts/test_ports/vcpkg-ci-opencv/CONTROL
new file mode 100644
index 000000000..3456988cf
--- /dev/null
+++ b/scripts/test_ports/vcpkg-ci-opencv/CONTROL
@@ -0,0 +1,6 @@
+Source: vcpkg-ci-opencv
+Version: 1
+Port-Version: 1
+Homepage: https://github.com/microsoft/vcpkg
+Description: Port to force features of certain ports within CI
+Build-Depends: opencv[nonfree,ade,contrib,dnn,eigen,ffmpeg,gdcm,ipp,jasper,jpeg,openexr,opengl,openmp,png,qt,sfm,tiff,vtk]
diff --git a/scripts/test_ports/vcpkg-ci-opencv/portfile.cmake b/scripts/test_ports/vcpkg-ci-opencv/portfile.cmake
new file mode 100644
index 000000000..0015715fb
--- /dev/null
+++ b/scripts/test_ports/vcpkg-ci-opencv/portfile.cmake
@@ -0,0 +1 @@
+set(VCPKG_POLICY_EMPTY_PACKAGE enabled) \ No newline at end of file