mirror of
https://github.com/OpenFOAM/ThirdParty-6.git
synced 2025-12-08 06:57:43 +00:00
427 lines
16 KiB
C++
427 lines
16 KiB
C++
/*=========================================================================
|
|
|
|
Program: ParaView
|
|
Module: vtkPVXYChartView.h
|
|
|
|
Copyright (c) Kitware, Inc.
|
|
All rights reserved.
|
|
See Copyright.txt or http://www.paraview.org/HTML/Copyright.html 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.
|
|
|
|
=========================================================================*/
|
|
// .NAME vtkPVXYChartView - vtkPVView subclass for drawing charts
|
|
// .SECTION Description
|
|
// vtkPVXYChartView is a concrete subclass of vtkPVContextView -- which
|
|
// in turn inherits vtkPVView -- that creates a vtkChart to perform
|
|
// rendering.
|
|
|
|
#ifndef vtkPVXYChartView_h
|
|
#define vtkPVXYChartView_h
|
|
|
|
#include "vtkPVClientServerCoreRenderingModule.h" //needed for exports
|
|
#include "vtkPVContextView.h"
|
|
#include "vtkAxis.h" //for enums.
|
|
|
|
class vtkChart;
|
|
class vtkPVPlotTime;
|
|
class vtkChartWarning;
|
|
|
|
|
|
#define GENERATE_AXIS_FUNCTIONS(name, type) \
|
|
void SetLeft ## name (type value) \
|
|
{\
|
|
Set ## name(vtkAxis::LEFT, value); \
|
|
}\
|
|
void SetBottom ## name(type value) \
|
|
{\
|
|
Set ## name(vtkAxis::BOTTOM, value); \
|
|
}\
|
|
void SetRight ## name(type value) \
|
|
{\
|
|
Set ## name(vtkAxis::RIGHT, value); \
|
|
}\
|
|
void SetTop ## name(type value) \
|
|
{\
|
|
Set ## name(vtkAxis::TOP, value); \
|
|
}
|
|
|
|
#define GENERATE_AXIS_FUNCTIONS2(name, type1, type2) \
|
|
void SetLeft ## name (type1 value1, type2 value2) \
|
|
{\
|
|
Set ## name(vtkAxis::LEFT, value1, value2); \
|
|
}\
|
|
void SetBottom ## name(type1 value1, type2 value2) \
|
|
{\
|
|
Set ## name(vtkAxis::BOTTOM, value1, value2); \
|
|
}\
|
|
void SetRight ## name(type1 value1, type2 value2) \
|
|
{\
|
|
Set ## name(vtkAxis::RIGHT, value1, value2); \
|
|
}\
|
|
void SetTop ## name(type1 value1, type2 value2) \
|
|
{\
|
|
Set ## name(vtkAxis::TOP, value1, value2); \
|
|
}
|
|
|
|
#define GENERATE_AXIS_FUNCTIONS3(name, type1, type2, type3) \
|
|
void SetLeft ## name (type1 value1, type2 value2, type3 value3) \
|
|
{\
|
|
Set ## name(vtkAxis::LEFT, value1, value2, value3); \
|
|
}\
|
|
void SetBottom ## name(type1 value1, type2 value2, type3 value3) \
|
|
{\
|
|
Set ## name(vtkAxis::BOTTOM, value1, value2, value3); \
|
|
}\
|
|
void SetRight ## name(type1 value1, type2 value2, type3 value3) \
|
|
{\
|
|
Set ## name(vtkAxis::RIGHT, value1, value2, value3); \
|
|
}\
|
|
void SetTop ## name(type1 value1, type2 value2, type3 value3) \
|
|
{\
|
|
Set ## name(vtkAxis::TOP, value1, value2, value3); \
|
|
}
|
|
|
|
class VTKPVCLIENTSERVERCORERENDERING_EXPORT vtkPVXYChartView :
|
|
public vtkPVContextView
|
|
{
|
|
public:
|
|
static vtkPVXYChartView* New();
|
|
vtkTypeMacro(vtkPVXYChartView, vtkPVContextView);
|
|
void PrintSelf(ostream& os, vtkIndent indent);
|
|
|
|
// Description:
|
|
// Set the chart type, defaults to line chart
|
|
void SetChartType(const char *type);
|
|
void SetChartTypeToLine() { this->SetChartType("Line"); }
|
|
void SetChartTypeToBar() { this->SetChartType("Bar"); }
|
|
void SetChartTypeToBag() { this->SetChartType("Bag"); }
|
|
void SetChartTypeToBox() { this->SetChartType("Box"); }
|
|
void SetChartTypeToArea() { this->SetChartType("Area"); }
|
|
void SetChartTypeToFunctionalBag() { this->SetChartType("FunctionalBag"); }
|
|
void SetChartTypeToParallelCoordinates()
|
|
{ this->SetChartType("ParallelCoordinates"); }
|
|
|
|
// Description:
|
|
// Set the title of the chart.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetTitle(const char* title);
|
|
|
|
// Description:
|
|
// Set the chart title's font.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetTitleFont(const char* family, int pointSize, bool bold, bool italic);
|
|
void SetTitleFontFamily(const char* family);
|
|
void SetTitleFontSize(int pointSize);
|
|
void SetTitleBold(bool bold);
|
|
void SetTitleItalic(bool bold);
|
|
|
|
// Description:
|
|
// Set the chart title's color.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetTitleColor(double red, double green, double blue);
|
|
|
|
// Description:
|
|
// Set the chart title's alignment.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetTitleAlignment(int alignment);
|
|
|
|
// Description:
|
|
// Set the legend visibility.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetLegendVisibility(int visible);
|
|
|
|
// Description:
|
|
// Set the legend location.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetLegendLocation(int location);
|
|
|
|
// Description:
|
|
// Set the legend position.
|
|
void SetLegendPosition(int x, int y);
|
|
|
|
// Description:
|
|
// Set the legend font family.
|
|
void SetLegendFontFamily(const char* family);
|
|
|
|
// Description:
|
|
// Set the legend font size.
|
|
void SetLegendFontSize(int pointSize);
|
|
|
|
// Description:
|
|
// Set the legend font bold.
|
|
void SetLegendBold(bool bold);
|
|
|
|
// Description:
|
|
// Set the legend font italic.
|
|
void SetLegendItalic(bool italic);
|
|
|
|
// Description:
|
|
// Sets whether or not the grid for the given axis is visible.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetGridVisibility(int index, bool visible);
|
|
GENERATE_AXIS_FUNCTIONS(GridVisibility,bool);
|
|
|
|
// Description:
|
|
// Sets the color for the given axis.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisColor(int index, double red, double green, double blue);
|
|
GENERATE_AXIS_FUNCTIONS3(AxisColor,double,double,double);
|
|
|
|
// Description:
|
|
// Sets the color for the given axis.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetGridColor(int index, double red, double green, double blue);
|
|
GENERATE_AXIS_FUNCTIONS3(GridColor,double,double,double);
|
|
|
|
// Description:
|
|
// Sets whether or not the labels for the given axis are visible.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisLabelVisibility(int index, bool visible);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelVisibility,bool);
|
|
|
|
// Description:
|
|
// Set the axis label font for the given axis.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisLabelFont(int index, const char* family, int pointSize, bool bold,
|
|
bool italic);
|
|
|
|
// Description:
|
|
// Set the axis label font family for the given axis.
|
|
void SetAxisLabelFontFamily(int index, const char* family);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelFontFamily,const char*);
|
|
|
|
// Description:
|
|
// Set the axis label font size for the given axis.
|
|
void SetAxisLabelFontSize(int index, int pointSize);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelFontSize,int);
|
|
|
|
// Description:
|
|
// Set the axis label font bold for the given axis.
|
|
void SetAxisLabelBold(int index, bool bold);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelBold,bool);
|
|
|
|
// Description:
|
|
// Set the axis label font italic for the given axis.
|
|
void SetAxisLabelItalic(int index, bool italic);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelItalic,bool);
|
|
|
|
// Description:
|
|
// Sets the axis label color for the given axis.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisLabelColor(int index, double red, double green, double blue);
|
|
GENERATE_AXIS_FUNCTIONS3(AxisLabelColor,double,double,double);
|
|
|
|
// Description:
|
|
// Sets the axis label notation for the given axis.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisLabelNotation(int index, int notation);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelNotation,int);
|
|
|
|
// Description:
|
|
// Sets the axis label precision for the given axis.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisLabelPrecision(int index, int precision);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelPrecision,int);
|
|
|
|
// Description:
|
|
// For axis ranges, ParaView overrides the VTK charts behavior.
|
|
// Users can either specify an explicit range or let the VTK chart determine
|
|
// the range based on the data. To specify a range explicitly, users should
|
|
// use SetAxisUseCustomRange() to on for the corresponding axis and then use
|
|
// these methods to set the ranges. Note these ranges are only respected when
|
|
// the corresponding AxisUseCustomRange flag it set.
|
|
GENERATE_AXIS_FUNCTIONS(AxisRangeMinimum,double);
|
|
GENERATE_AXIS_FUNCTIONS(AxisRangeMaximum,double);
|
|
|
|
// Description:
|
|
// Set whether to use the range specified by SetAxisRange(..) (or variants) or
|
|
// to let the chart determine the range automatically based on the data being
|
|
// shown.
|
|
void SetAxisUseCustomRange(int index, bool useCustomRange);
|
|
GENERATE_AXIS_FUNCTIONS(AxisUseCustomRange,bool);
|
|
|
|
// Description:
|
|
// Sets whether or not the given axis uses a log10 scale.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisLogScale(int index, bool logScale);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLogScale,bool);
|
|
|
|
|
|
// Description:
|
|
// Set the chart axis title for the given index.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisTitle(int index, const char* title);
|
|
GENERATE_AXIS_FUNCTIONS(AxisTitle,const char*);
|
|
|
|
// Description:
|
|
// Set the chart axis title's font for the given index.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisTitleFont(int index, const char* family, int pointSize,
|
|
bool bold, bool italic);
|
|
|
|
// Description:
|
|
// Set the chart axis title's font family for the given index.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisTitleFontFamily(int index, const char* family);
|
|
GENERATE_AXIS_FUNCTIONS(AxisTitleFontFamily,const char*);
|
|
|
|
// Description:
|
|
// Set the chart axis title's font size for the given index.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisTitleFontSize(int index, int pointSize);
|
|
GENERATE_AXIS_FUNCTIONS(AxisTitleFontSize,int);
|
|
|
|
// Description:
|
|
// Set the chart axis title's font bold for the given index.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisTitleBold(int index, bool bold);
|
|
GENERATE_AXIS_FUNCTIONS(AxisTitleBold,bool);
|
|
|
|
// Description:
|
|
// Set the chart axis title's font italic for the given index.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisTitleItalic(int index, bool italic);
|
|
GENERATE_AXIS_FUNCTIONS(AxisTitleItalic,bool);
|
|
|
|
// Description:
|
|
// Set the chart axis title's color for the given index.
|
|
// These methods should not be called directly. They are made public only so
|
|
// that the client-server-stream-interpreter can invoke them. Use the
|
|
// corresponding properties to change these values.
|
|
void SetAxisTitleColor(int index, double red, double green, double blue);
|
|
GENERATE_AXIS_FUNCTIONS3(AxisTitleColor,double,double,double);
|
|
|
|
// Description:
|
|
// Set whether the chart uses custom labels or if the labels/ticks are placed
|
|
// automatically.
|
|
void SetAxisUseCustomLabels(int index, bool useCustomLabels);
|
|
GENERATE_AXIS_FUNCTIONS(AxisUseCustomLabels,bool);
|
|
|
|
|
|
// Description:
|
|
// Set the number of labels for the supplied axis.
|
|
void SetAxisLabelsNumber(int axis, int number);
|
|
GENERATE_AXIS_FUNCTIONS(AxisLabelsNumber,int);
|
|
|
|
// Description:
|
|
// Set the axis label positions for the supplied axis at the given index.
|
|
void SetAxisLabels(int axis, int index, double value);
|
|
GENERATE_AXIS_FUNCTIONS2(AxisLabels,int,double);
|
|
|
|
void SetTooltipNotation(int notation);
|
|
void SetTooltipPrecision(int precision);
|
|
|
|
// Description:
|
|
// Set the visibility for the time-marker in the view. Note, you cannot force
|
|
// the time-marker to be shown. One can only hide it when the view would have
|
|
// shown it otherwise.
|
|
vtkSetMacro(HideTimeMarker, bool);
|
|
vtkGetMacro(HideTimeMarker, bool);
|
|
|
|
// Description:
|
|
// Provides access to the chart view.
|
|
virtual vtkChart* GetChart();
|
|
|
|
// Description:
|
|
// Get the context item.
|
|
virtual vtkAbstractContextItem* GetContextItem();
|
|
|
|
// Description:
|
|
// Representations can use this method to set the selection for a particular
|
|
// representation. Subclasses override this method to pass on the selection to
|
|
// the chart using annotation link. Note this is meant to pass selection for
|
|
// the local process alone. The view does not manage data movement for the
|
|
// selection.
|
|
virtual void SetSelection(
|
|
vtkChartRepresentation* repr, vtkSelection* selection);
|
|
|
|
// Description:
|
|
// Overridden to rescale axes range on every update.
|
|
virtual void Update();
|
|
|
|
//BTX
|
|
protected:
|
|
vtkPVXYChartView();
|
|
~vtkPVXYChartView();
|
|
|
|
void SetAxisRangeMinimum(int index, double min);
|
|
void SetAxisRangeMaximum(int index, double max);
|
|
|
|
// Description:
|
|
// Actual rendering implementation.
|
|
virtual void Render(bool interactive);
|
|
|
|
// Description:
|
|
// Set the internal title, for managing time replacement in the chart title.
|
|
vtkSetStringMacro(InternalTitle);
|
|
|
|
// Description:
|
|
// Store the unreplaced chart title in the case where ${TIME} is used...
|
|
char* InternalTitle;
|
|
|
|
// Description:
|
|
// Pointer to the proxy's chart instance.
|
|
vtkChart* Chart;
|
|
vtkPVPlotTime* PlotTime;
|
|
vtkChartWarning* LogScaleWarningLabel;
|
|
|
|
void SelectionChanged();
|
|
|
|
bool HideTimeMarker;
|
|
|
|
private:
|
|
vtkPVXYChartView(const vtkPVXYChartView&); // Not implemented
|
|
void operator=(const vtkPVXYChartView&); // Not implemented
|
|
|
|
class vtkInternals;
|
|
vtkInternals* Internals;
|
|
//ETX
|
|
};
|
|
|
|
#endif
|