/*========================================================================= Program: Visualization Toolkit Module: vtkChart2DHistogram.h 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. =========================================================================*/ /** * @class vtkChart2DHistogram * @brief Chart for 2D histograms. * * * This defines the interface for a 2D histogram chart. */ #ifndef vtkChartHistogram2D_h #define vtkChartHistogram2D_h #include "vtkChartXY.h" #include "vtkChartsCoreModule.h" // For export macro #include "vtkSmartPointer.h" // For SP ivars class vtkColorLegend; class vtkPlotHistogram2D; class vtkImageData; class vtkScalarsToColors; class VTKCHARTSCORE_EXPORT vtkChartHistogram2D : public vtkChartXY { public: vtkTypeMacro(vtkChartHistogram2D, vtkChartXY); void PrintSelf(ostream& os, vtkIndent indent) override; /** * Creates a 2D histogram chart */ static vtkChartHistogram2D* New(); /** * Perform any updates to the item that may be necessary before rendering. * The scene should take care of calling this on all items before their * Paint function is invoked. */ void Update() override; virtual void SetInputData(vtkImageData* data, vtkIdType z = 0); virtual void SetTransferFunction(vtkScalarsToColors* function); /** * Return true if the supplied x, y coordinate is inside the item. */ bool Hit(const vtkContextMouseEvent& mouse) override; /** * Get the plot at the specified index, returns null if the index is invalid. */ vtkPlot* GetPlot(vtkIdType index) override; protected: vtkChartHistogram2D(); ~vtkChartHistogram2D() override; vtkSmartPointer Histogram; /** * The point cache is marked dirty until it has been initialized. */ vtkTimeStamp BuildTime; class Private; Private* Storage; bool UpdateLayout(vtkContext2D* painter) override; private: vtkChartHistogram2D(const vtkChartHistogram2D&) = delete; void operator=(const vtkChartHistogram2D&) = delete; }; #endif // vtkChartHistogram2D_h