#7 Add upstream patches for VTK 9.0 support (bz#1840977)
Closed 3 years ago by kwizart. Opened 3 years ago by orion.
rpms/ orion/opencv vtk9  into  master

file added
+24
@@ -0,0 +1,24 @@ 

+ From 7856f14558f37021c1d5b76ade40ac78e59a422d Mon Sep 17 00:00:00 2001

+ From: Maksim Shabunin <maksim.shabunin@gmail.com>

+ Date: Sat, 30 May 2020 06:07:39 +0300

+ Subject: [PATCH] Added VTK 9 support

+ 

+ ---

+  cmake/OpenCVDetectVTK.cmake | 7 +++++++

+  1 file changed, 7 insertions(+)

+ 

+ diff --git a/cmake/OpenCVDetectVTK.cmake b/cmake/OpenCVDetectVTK.cmake

+ index 0f2b9584e12..23d17c35241 100644

+ --- a/cmake/OpenCVDetectVTK.cmake

+ +++ b/cmake/OpenCVDetectVTK.cmake

+ @@ -1,3 +1,10 @@

+ +# VTK 9.0

+ +find_package(VTK QUIET NAMES vtk COMPONENTS InteractionStyle RenderingLOD IOPLY FiltersTexture RenderingFreeType IOExport IOGeometry FiltersExtraction RenderingCore NO_MODULE)

+ +if(VTK_FOUND)

+ +  set(HAVE_VTK ON)

+ +  return()

+ +endif()

+ +

+  # VTK 6.x components

+  find_package(VTK QUIET COMPONENTS vtkInteractionStyle vtkRenderingLOD vtkIOPLY vtkFiltersTexture vtkRenderingFreeType vtkIOExport NO_MODULE)

+  IF(VTK_FOUND)

file added
+507
@@ -0,0 +1,507 @@ 

+ From c4b3b920461f9c7207d4c184a5bedf7608a51ed1 Mon Sep 17 00:00:00 2001

+ From: Maksim Shabunin <maksim.shabunin@gmail.com>

+ Date: Sat, 30 May 2020 06:09:02 +0300

+ Subject: [PATCH 1/3] Added VTK 9 support

+ 

+ ---

+  modules/viz/CMakeLists.txt           |  4 +++-

+  modules/viz/src/precomp.hpp          |  8 +++++++-

+  modules/viz/src/types.cpp            |  3 ++-

+  modules/viz/src/vizimpl.cpp          | 13 +++++++++++--

+  modules/viz/src/vtk/vtkOBJWriter.cpp | 14 +++++++++-----

+  modules/viz/src/vtk/vtkXYZReader.cpp |  2 +-

+  modules/viz/src/vtk/vtkXYZWriter.cpp |  2 +-

+  7 files changed, 34 insertions(+), 12 deletions(-)

+ 

+ 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);

+ 

+ From 4281df7fe0090c03b6a40db44292ba6268239cbb Mon Sep 17 00:00:00 2001

+ From: Maksim Shabunin <maksim.shabunin@gmail.com>

+ Date: Tue, 2 Jun 2020 19:21:19 +0300

+ Subject: [PATCH 2/3] viz: tests are non-interactive now

+ 

+ ---

+  modules/viz/test/test_tutorial2.cpp |  4 +--

+  modules/viz/test/test_tutorial3.cpp |  2 +-

+  modules/viz/test/test_viz3d.cpp     |  2 +-

+  modules/viz/test/tests_simple.cpp   | 56 ++++++++++++++---------------

+  4 files changed, 32 insertions(+), 32 deletions(-)

+ 

+ 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

+ 

+ From f46c6cadbe751b2dbf60b34e85aaf575511e9794 Mon Sep 17 00:00:00 2001

+ From: Maksim Shabunin <maksim.shabunin@gmail.com>

+ Date: Tue, 2 Jun 2020 22:46:53 +0300

+ Subject: [PATCH 3/3] fixup! Added VTK 9 support

+ 

+ ---

+  modules/viz/CMakeLists.txt | 12 ++++++++----

+  modules/viz/src/types.cpp  |  1 +

+  2 files changed, 9 insertions(+), 4 deletions(-)

+ 

+ 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();

file modified
+9 -7
@@ -31,12 +31,7 @@ 

  %bcond_with     atlas

  %bcond_without  openblas

  %bcond_without  gdcm

- #if 0%{?fedora} > 29

- #bcond_without  vtk

- #else

- #VTK support disabled. Incompatible combination: OpenCV + Qt5 and VTK ver.7.1.1 + Qt4 in <= F29

- %bcond_with  vtk

- #endif

+ %bcond_without  vtk

  

  %ifarch x86_64

  %bcond_without  libmfx
@@ -60,7 +55,7 @@ 

  

  Name:           opencv

  Version:        4.3.0

- Release:        1%{?dist}

+ Release:        2%{?dist}

  Summary:        Collection of algorithms for computer vision

  # This is normal three clause BSD.

  License:        BSD
@@ -76,6 +71,8 @@ 

  Source4:        b624b995ec9c439cbc2e9e6ee940d3a2-v0.1.1f.zip

  

  Patch0:         opencv-4.1.0-install_3rdparty_licenses.patch

+ Patch1:         https://patch-diff.githubusercontent.com/raw/opencv/opencv/pull/17431.patch

+ Patch2:         https://patch-diff.githubusercontent.com/raw/opencv/opencv_contrib/pull/2549.patch

  # Comment out removed vulkan symbols

  Patch3:         opencv_vulkan.patch

  
@@ -252,9 +249,11 @@ 

  %endif

  

  %patch0 -p1 -b .install_3rdparty_licenses

+ %patch1 -p1

  %patch3 -p1

  

  pushd %{name}_contrib-%{version}

+ %patch2 -p1

  popd

  

  # Install ADE, needed for opencv_gapi
@@ -469,6 +468,9 @@ 

  %{_libdir}/libopencv_xphoto.so.%{abiver}*

  

  %changelog

+ * Tue Jun 02 2020 Orion Poplawski <orion@nwra.com> - 4.3.0-2

+ - Add upstream patches for VTK 9.0 support (bz#1840977)

+ 

  * Fri May 28 2020 Nicolas Chauvet <kwizart@gmail.com> - 4.3.0-1

  - Update to 4.3.0

  

This allows opencv to build against VTK 8.2 and 9.0. Though there still may be run-time issues - https://github.com/opencv/opencv/issues/17401

rebased onto b332cf0

3 years ago

rebased onto 656fd9b

3 years ago

Pull-Request has been closed by kwizart

3 years ago