#include <vtkVersion.h> #include <vtkSmartPointer.h> #include <vtkChartXY.h> #include <vtkContextScene.h> #include <vtkContextView.h> #include <vtkFloatArray.h> #include <vtkPlotPoints.h> #include <vtkRenderWindow.h> #include <vtkRenderWindowInteractor.h> #include <vtkRenderer.h> #include <vtkTable.h> int main(int, char*[]) { // Set up a 2D scene, add an XY chart to it vtkSmartPointer<vtkContextView> view = vtkSmartPointer<vtkContextView>::New(); view->GetRenderer()->SetBackground(1.0, 1.0, 1.0); view->GetRenderWindow()->SetSize(400, 300); vtkSmartPointer<vtkChartXY> chart = vtkSmartPointer<vtkChartXY>::New(); view->GetScene()->AddItem(chart); chart->SetShowLegend(true); // Create a table with some points in it... vtkSmartPointer<vtkTable> table = vtkSmartPointer<vtkTable>::New(); vtkSmartPointer<vtkFloatArray> arrX = vtkSmartPointer<vtkFloatArray>::New(); arrX->SetName("X Axis"); table->AddColumn(arrX); vtkSmartPointer<vtkFloatArray> arrC = vtkSmartPointer<vtkFloatArray>::New(); arrC->SetName("Cosine"); table->AddColumn(arrC); vtkSmartPointer<vtkFloatArray> arrS = vtkSmartPointer<vtkFloatArray>::New(); arrS->SetName("Sine"); table->AddColumn(arrS); vtkSmartPointer<vtkFloatArray> arrT = vtkSmartPointer<vtkFloatArray>::New(); arrT->SetName("Sine - Cosine"); table->AddColumn(arrT); // Test charting with a few more points... int numPoints = 40; float inc = 7.5 / (numPoints-1); table->SetNumberOfRows(numPoints); for (int i = 0; i < numPoints; ++i) { table->SetValue(i, 0, i * inc); table->SetValue(i, 1, cos(i * inc) + 0.0); table->SetValue(i, 2, sin(i * inc) + 0.0); table->SetValue(i, 3, sin(i * inc) - cos(i * inc)); } // Add multiple scatter plots, setting the colors etc vtkRenderWindow *renWin = vtkRenderWindow::New(); CWnd *pWnd=GetDlgItem(IDC_result); HWND hwnd =pWnd->GetSafeHwnd(); renWin->SetParentId(hwnd); renWin->SetSize(rect.Width(),rect.Height()); //view->SetRenderer(ren); view->GetRenderer()->SetBackground(1.0, 1.0, 1.0); // Add multiple line plots, setting the colors etc vtkSmartPointer<vtkChartXY> chart = vtkSmartPointer<vtkChartXY>::New(); chart->SetShowLegend(1); chart->AutoAxesOn(); chart->GetAxis(0)->SetGridVisible(true); view->GetScene()->AddItem(chart); vtkPlot *line = chart->AddPlot(vtkChart::LINE); #if VTK_MAJOR_VERSION <= 5 line->SetInput(table, 0, 1); #else line->SetInputData(table, 0, 1); #endif line->SetColor(0, 255, 0, 255); line->SetWidth(1.0); line = chart->AddPlot(vtkChart::LINE); #if VTK_MAJOR_VERSION <= 5 line->SetInput(table, 0, 2); #else line->SetInputData(table, 0, 2); #endif line->SetColor(255, 0, 0, 255); line->SetWidth(1.0); line->GetPen()->SetLineType(2);//For dotted line, can be from 2 to 5 for different dot patterns view->SetRenderWindow(renWin); // Start interactor view->GetInteractor()->Initialize(); view->GetInteractor()->Start(); return EXIT_SUCCESS;
}