VTK/Examples/Cxx/GeometricObjects/TriangleStrip
From KitwarePublic
A triangle strip is a compact representation of a series of triangles. See this wikipedia article for an explanation.
TriangleStrip.cxx
#include <vtkVersion.h> #include <vtkActor.h> #include <vtkCellArray.h> #include <vtkDataSetMapper.h> #include <vtkPoints.h> #include <vtkPolyData.h> #include <vtkProperty.h> #include <vtkRenderer.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkSmartPointer.h> #include <vtkTriangleStrip.h> int main(int argc, char *argv[]) { vtkSmartPointer<vtkPoints> points = vtkSmartPointer<vtkPoints>::New(); points->InsertNextPoint(0,0,0); points->InsertNextPoint(0,1,0); points->InsertNextPoint(1,0,0); points->InsertNextPoint(1.5,1,0); vtkSmartPointer<vtkTriangleStrip> triangleStrip = vtkSmartPointer<vtkTriangleStrip>::New(); triangleStrip->GetPointIds()->SetNumberOfIds(4); triangleStrip->GetPointIds()->SetId(0,0); triangleStrip->GetPointIds()->SetId(1,1); triangleStrip->GetPointIds()->SetId(2,2); triangleStrip->GetPointIds()->SetId(3,3); vtkSmartPointer<vtkCellArray> cells = vtkSmartPointer<vtkCellArray>::New(); cells->InsertNextCell(triangleStrip); vtkSmartPointer<vtkPolyData> polydata = vtkSmartPointer<vtkPolyData>::New(); polydata->SetPoints(points); polydata->SetStrips(cells); // Create an actor and mapper vtkSmartPointer<vtkDataSetMapper> mapper = vtkSmartPointer<vtkDataSetMapper>::New(); #if VTK_MAJOR_VERSION <= 5 mapper->SetInput(polydata); #else mapper->SetInputData(polydata); #endif vtkSmartPointer<vtkActor> actor = vtkSmartPointer<vtkActor>::New(); actor->SetMapper(mapper); actor->GetProperty()->SetRepresentationToWireframe(); // Create a renderer, render window, and interactor vtkSmartPointer<vtkRenderer> renderer = vtkSmartPointer<vtkRenderer>::New(); vtkSmartPointer<vtkRenderWindow> renderWindow = vtkSmartPointer<vtkRenderWindow>::New(); renderWindow->AddRenderer(renderer); vtkSmartPointer<vtkRenderWindowInteractor> renderWindowInteractor = vtkSmartPointer<vtkRenderWindowInteractor>::New(); renderWindowInteractor->SetRenderWindow(renderWindow); renderer->AddActor(actor); renderWindow->Render(); renderWindowInteractor->Start(); return EXIT_SUCCESS; }
CMakeLists.txt
cmake_minimum_required(VERSION 2.8) PROJECT(TriangleStrip) find_package(VTK REQUIRED) include(${VTK_USE_FILE}) if (APPLE) add_executable(TriangleStrip MACOSX_BUNDLE TriangleStrip.cxx) else() add_executable(TriangleStrip TriangleStrip.cxx) endif() if(VTK_LIBRARIES) target_link_libraries(TriangleStrip ${VTK_LIBRARIES}) else() target_link_libraries(TriangleStrip vtkHybrid ) endif()
