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
102 lines
2.9 KiB
C
3 weeks ago
|
/*=========================================================================
|
||
|
|
||
|
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
|