You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

102 lines
2.9 KiB
C++

/*=========================================================================
Program: Visualization Toolkit
Module: vtkPiecewiseControlPointsItem.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 vtkPiecewiseControlPointsItem
* @brief Control points for
* vtkPiecewiseFunction.
*
* vtkPiecewiseControlPointsItem draws the control points of a vtkPiecewiseFunction.
* @sa
* vtkControlPointsItem
* vtkPiecewiseFunctionItem
* vtkCompositeTransferFunctionItem
*/
#ifndef vtkPiecewiseControlPointsItem_h
#define vtkPiecewiseControlPointsItem_h
#include "vtkChartsCoreModule.h" // For export macro
#include "vtkControlPointsItem.h"
class vtkPiecewiseFunction;
class VTKCHARTSCORE_EXPORT vtkPiecewiseControlPointsItem : public vtkControlPointsItem
{
public:
vtkTypeMacro(vtkPiecewiseControlPointsItem, vtkControlPointsItem);
void PrintSelf(ostream& os, vtkIndent indent) override;
/**
* Creates a piecewise control points object
*/
static vtkPiecewiseControlPointsItem* New();
/**
* Set the piecewise function to draw its points
*/
virtual void SetPiecewiseFunction(vtkPiecewiseFunction* function);
//@{
/**
* Get the piecewise function
*/
vtkGetObjectMacro(PiecewiseFunction, vtkPiecewiseFunction);
//@}
/**
* Add a point to the function. Returns the index of the point (0 based),
* or -1 on error.
* Subclasses should reimplement this function to do the actual work.
*/
vtkIdType AddPoint(double* newPos) override;
/**
* Remove a point of the function. Returns the index of the point (0 based),
* or -1 on error.
* Subclasses should reimplement this function to do the actual work.
*/
vtkIdType RemovePoint(double* pos) override;
//@{
/**
* Controls whether or not control points are drawn (true) or clicked and
* moved (false).
* False by default.
*/
vtkSetMacro(StrokeMode, bool);
//@}
protected:
vtkPiecewiseControlPointsItem();
~vtkPiecewiseControlPointsItem() override;
void emitEvent(unsigned long event, void* params = nullptr) override;
vtkMTimeType GetControlPointsMTime() override;
vtkIdType GetNumberOfPoints() const override;
void GetControlPoint(vtkIdType index, double* point) const override;
void SetControlPoint(vtkIdType index, double* point) override;
void EditPoint(float tX, float tY) override;
vtkPiecewiseFunction* PiecewiseFunction;
private:
vtkPiecewiseControlPointsItem(const vtkPiecewiseControlPointsItem&) = delete;
void operator=(const vtkPiecewiseControlPointsItem&) = delete;
};
#endif