VTK/Examples/Cxx/Graphs/ScaleVertices

From KitwarePublic

Jump to: navigation, search
VTK Examples Baseline Graphs TestScaleVertices.png

Scale the vertices based on a data array.

ScaleVertices.cxx

#include <vtkSmartPointer.h>
#include <vtkRenderedGraphRepresentation.h>
#include <vtkFloatArray.h>
#include <vtkMutableUndirectedGraph.h>
#include <vtkGraphWriter.h>
#include <vtkGraphLayoutView.h>
#include <vtkRenderWindowInteractor.h>
#include <vtkDataSetAttributes.h>
#include <vtkGraphToGlyphs.h>
 
int main(int, char *[])
{
  vtkSmartPointer<vtkMutableUndirectedGraph> g =
    vtkSmartPointer<vtkMutableUndirectedGraph>::New();
 
  vtkIdType v1 = g->AddVertex();
  vtkIdType v2 = g->AddVertex();
 
  g->AddEdge(v1, v2);
  g->AddEdge(v1, v2);
 
  vtkSmartPointer<vtkFloatArray> scales =
    vtkSmartPointer<vtkFloatArray>::New();
  scales->SetNumberOfComponents(1);
  scales->SetName("Scales");
  scales->InsertNextValue(1.0);
  scales->InsertNextValue(4.0);
 
  g->GetVertexData()->AddArray(scales);
 
  vtkSmartPointer<vtkGraphLayoutView> layoutView =
    vtkSmartPointer<vtkGraphLayoutView>::New();
  layoutView->AddRepresentationFromInput(g);
  layoutView->ScaledGlyphsOn();
  layoutView->SetScalingArrayName("Scales");
  vtkRenderedGraphRepresentation::SafeDownCast(layoutView->GetRepresentation())
            ->SetGlyphType(vtkGraphToGlyphs::CIRCLE);
  layoutView->ResetCamera();
  layoutView->Render();
  layoutView->GetInteractor()->Start();
 
  return EXIT_SUCCESS;
}

CMakeLists.txt

cmake_minimum_required(VERSION 2.6)
 
PROJECT(ScaleVertices)
 
FIND_PACKAGE(VTK REQUIRED)
INCLUDE(${VTK_USE_FILE})
 
ADD_EXECUTABLE(ScaleVertices ScaleVertices.cxx)
TARGET_LINK_LIBRARIES(ScaleVertices vtkHybrid  vtkViews)
Personal tools