/*========================================================================= Program: Visualization Toolkit Module: TestTreeMapView.cxx ------------------------------------------------------------------------- Copyright 2008 Sandia Corporation. Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains certain rights in this software. ------------------------------------------------------------------------- Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen All rights reserved. See Copyright.txt or http://www.kitware.com/Copyright.htm for details. This software is distributed WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the above copyright notice for more information. =========================================================================*/ #include "vtkDataRepresentation.h" #include "vtkRegressionTestImage.h" #include "vtkRenderWindow.h" #include "vtkRenderWindowInteractor.h" #include "vtkRenderedTreeAreaRepresentation.h" #include "vtkRenderer.h" #include "vtkSplineGraphEdges.h" #include "vtkTestUtilities.h" #include "vtkTreeMapView.h" #include "vtkViewTheme.h" #include "vtkXMLTreeReader.h" #include "vtkSmartPointer.h" #define VTK_CREATE(type, name) vtkSmartPointer name = vtkSmartPointer::New() using std::string; int TestTreeMapView(int argc, char* argv[]) { VTK_CREATE(vtkTesting, testHelper); testHelper->AddArguments(argc, const_cast(argv)); string dataRoot = testHelper->GetDataRoot(); string treeFileName = dataRoot + "/Data/Infovis/XML/vtkclasses.xml"; string graphFileName = dataRoot + "/Data/Infovis/XML/vtklibrary.xml"; // We need to put the graph and tree edges in different domains. VTK_CREATE(vtkXMLTreeReader, reader1); reader1->SetFileName(treeFileName.c_str()); reader1->SetEdgePedigreeIdArrayName("tree edge"); reader1->GenerateVertexPedigreeIdsOff(); reader1->SetVertexPedigreeIdArrayName("id"); VTK_CREATE(vtkXMLTreeReader, reader2); reader2->SetFileName(graphFileName.c_str()); reader2->SetEdgePedigreeIdArrayName("graph edge"); reader2->GenerateVertexPedigreeIdsOff(); reader2->SetVertexPedigreeIdArrayName("id"); reader1->Update(); reader2->Update(); VTK_CREATE(vtkTreeMapView, view); view->DisplayHoverTextOff(); view->SetTreeFromInputConnection(reader2->GetOutputPort()); view->SetGraphFromInputConnection(reader1->GetOutputPort()); view->SetAreaColorArrayName("level"); view->SetEdgeColorToSplineFraction(); view->SetColorEdges(true); view->SetAreaLabelArrayName("id"); view->SetAreaHoverArrayName("id"); view->SetAreaLabelVisibility(true); view->SetAreaSizeArrayName("VertexDegree"); view->Update(); vtkRenderedTreeAreaRepresentation::SafeDownCast(view->GetRepresentation()) ->SetGraphSplineType(vtkSplineGraphEdges::CUSTOM, 0); // Apply a theme to the views vtkViewTheme* const theme = vtkViewTheme::CreateMellowTheme(); view->ApplyViewTheme(theme); theme->Delete(); view->GetRenderWindow()->SetMultiSamples(0); view->GetRenderWindow()->SetAlphaBitPlanes(1); view->Update(); view->ResetCamera(); int retVal = vtkRegressionTestImage(view->GetRenderWindow()); if (retVal == vtkRegressionTester::DO_INTERACTOR) { view->GetInteractor()->Initialize(); view->GetInteractor()->Start(); retVal = vtkRegressionTester::PASSED; } return !retVal; }