21 #ifndef vtkXYChartRepresentationInternals_h 22 #define vtkXYChartRepresentationInternals_h 50 class PlotsMap :
public std::map<std::string, PlotsMapItem>
52 bool Contains(
const std::string&
key,
const std::string& role)
const 54 PlotsMap::const_iterator iter1 = this->find(key);
55 if (iter1 != this->end())
57 PlotsMapItem::const_iterator iter2 = iter1->second.find(role);
58 return (iter2 != iter1->second.end());
65 const std::string& columnName,
const std::string& role = std::string())
const 67 const std::string key =
self->GetDefaultSeriesLabel(tableName, columnName);
68 PlotsMap::const_iterator iter1 = this->find(key);
69 if (iter1 != this->end())
71 PlotsMapItem::const_iterator iter2 = iter1->second.find(role);
72 if (iter2 != iter1->second.end())
74 return iter2->second.Plot;
81 const std::string& columnName,
const std::string& role = std::string())
83 const std::string key =
self->GetDefaultSeriesLabel(tableName, columnName);
84 PlotsMap::iterator iter1 = this->find(key);
85 if (iter1 != this->end())
87 PlotsMapItem::iterator iter2 = iter1->second.find(role);
88 if (iter2 != iter1->second.end())
90 iter1->second.erase(iter2);
98 const std::string& columnName,
const std::string& role,
vtkPlot* plot)
100 const std::string key =
self->GetDefaultSeriesLabel(tableName, columnName);
109 for (PlotsMap::const_iterator iter1 = this->begin(); iter1 != this->end(); ++iter1)
111 for (PlotsMapItem::const_iterator iter2 = iter1->second.begin();
112 iter2 != iter1->second.end(); ++iter2)
114 iter2->second.Plot->SetVisible(val);
121 for (PlotsMap::const_iterator iter1 = this->begin(); iter1 != this->end(); ++iter1)
123 for (PlotsMapItem::const_iterator iter2 = iter1->second.begin();
124 iter2 != iter1->second.end(); ++iter2)
134 for (PlotsMap::iterator iter1 = this->begin(); iter1 != this->end(); ++iter1)
136 for (PlotsMapItem::iterator iter2 = iter1->second.begin(); iter2 != iter1->second.end();)
138 if (other.Contains(iter1->first, iter2->first) ==
false)
141 PlotsMapItem::iterator iter2old = iter2;
143 iter1->second.erase(iter2old);
167 const std::string& columnName,
const std::string& vtkNotUsed(role),
168 const std::map<std::string, T>& parameter_map,
const T default_value = T())
const 170 typename std::map<std::string, T>::const_iterator iter;
177 std::string key =
self->GetDefaultSeriesLabel(tableName, columnName);
178 iter = parameter_map.find(key);
179 if (iter != parameter_map.end())
185 key =
self->GetDefaultSeriesLabel(std::string(), columnName);
186 iter = parameter_map.find(key);
187 if (iter != parameter_map.end())
191 return default_value;
203 std::map<std::string, vtkColor3d>
Colors;
207 std::map<std::string, std::string>
Labels;
209 std::map<std::string, vtkScalarsToColors*>
Lut;
218 : PreviousUseIndexForXAxis(false)
243 const std::string& vtkNotUsed(tableName),
const std::string& vtkNotUsed(columnName))
245 return { std::string() };
253 const std::string& columnName,
const std::string& role)
263 return chartXY->
AddPlot(self->GetChartType());
268 const std::string& vtkNotUsed(columnName),
const std::string& vtkNotUsed(role))
280 assert(
self !=
nullptr);
283 std::multimap<int, std::pair<vtkTable*, std::array<std::string, 3> > > orderMap;
284 for (MapOfTables::const_iterator tablesIter = tables.begin(); tablesIter != tables.end();
287 const std::string& tableName = tablesIter->first;
288 vtkTable* table = tablesIter->second.GetPointer();
290 for (
vtkIdType cc = 0; cc < numCols; ++cc)
295 for (
const auto& role : roles)
302 std::array<std::string, 3> mapValue;
303 mapValue[0] = tableName;
304 mapValue[1] = columnName;
306 orderMap.insert(std::make_pair(order, std::make_pair(table, mapValue)));
312 for (
auto it = orderMap.begin(); it != orderMap.end(); ++it)
315 const std::string& tableName = it->second.second[0];
316 const std::string& columnName = it->second.second[1];
317 const std::string& role = it->second.second[2];
323 plot = this->
NewPlot(
self, tableName, columnName, role);
333 this->SeriesPlots.
AddPlot(
self, tableName, columnName, role, plot);
334 newPlots.
AddPlot(
self, tableName, columnName, role, plot);
338 this->SeriesPlots.
Intersect(newPlots, chartXY);
348 vtkPlot* lastFunctionalBagPlot = 0;
349 for (PlotsMap::iterator iter1 = this->SeriesPlots.begin(); iter1 != this->SeriesPlots.end();
352 for (PlotsMapItem::const_iterator iter2 = iter1->second.begin(); iter2 != iter1->second.end();
355 const PlotInfo& plotInfo = iter2->second;
356 const std::string& tableName = plotInfo.
TableName;
357 const std::string& columnName = plotInfo.
ColumnName;
359 const std::string& role = iter2->first;
368 if (columnName ==
"QMedianLine")
372 if (plotBag->
IsBag())
374 if (!lastFunctionalBagPlot)
382 lastFunctionalBagPlot = plotBag;
396 for (PlotsMap::iterator iter1 = this->SeriesPlots.begin(); iter1 != this->SeriesPlots.end();
399 for (PlotsMapItem::const_iterator iter2 = iter1->second.begin(); iter2 != iter1->second.end();
402 const PlotInfo& plotInfo = iter2->second;
408 const std::string& columnName = plotInfo.
ColumnName;
414 if (yarray !=
nullptr)
429 const std::string& tableName,
const std::string& columnName,
const std::string& role,
434 this->
GetSeriesParameter(
self, tableName, columnName, role, this->SeriesVisibilities,
false);
441 std::string default_label =
self->GetDefaultSeriesLabel(tableName, columnName);
443 this->
GetSeriesParameter(
self, tableName, columnName, role, this->Labels, default_label);
444 if (self->GetSeriesLabelPrefix())
446 label = std::string(self->GetSeriesLabelPrefix()) + label;
451 self, tableName, columnName, role, this->Colors,
vtkColor3d(0, 0, 0));
456 this->
GetSeriesParameter(
self, tableName, columnName, role, this->LineThicknesses, 2));
458 self, tableName, columnName, role, this->LineStyles, static_cast<int>(
vtkPen::SOLID_LINE)));
462 plotPoints->SetMarkerStyle(this->
GetSeriesParameter(
self, tableName, columnName, role,
464 plotPoints->SetMarkerSize(
469 plotPoints->SetValidPointMaskName(
"vtkValidPointMask");
473 plot, this->
GetSeriesParameter(
self, tableName, columnName, role, this->AxisCorners, 0));
477 if (plotBar && columnName ==
"bin_values")
480 this->
GetSeriesParameter(
self, tableName, columnName, role, this->UseColorMapping,
false);
484 self, tableName, columnName, role, this->Lut, static_cast<vtkScalarsToColors*>(
nullptr));
std::map< std::string, vtkScalarsToColors * > Lut
bool RemovePlot(vtkChartRepresentation *self, const std::string &tableName, const std::string &columnName, const std::string &role=std::string())
std::map< std::string, PlotInfo > PlotsMapItem
bool PreviousUseIndexForXAxis
static vtkDataArray * SafeDownCast(vtkObjectBase *o)
T GetSeriesParameter(vtkXYChartRepresentation *self, const std::string &tableName, const std::string &columnName, const std::string &vtkNotUsed(role), const std::map< std::string, T > ¶meter_map, const T default_value=T()) const
Makes is easy to obtain a value for a series parameter, is set, else the default. ...
virtual void SetWidth(float width)
const double & GetBlue() const
vtkXYChartRepresentation is representation that is used to add vtkPlot subclasses to a vtkChartXY ins...
std::map< std::string, std::string > Labels
void AddPlot(vtkChartRepresentation *self, const std::string &tableName, const std::string &columnName, const std::string &role, vtkPlot *plot)
vtkXYChartRepresentation::MapOfTables MapOfTables
static vtkPlotFunctionalBag * SafeDownCast(vtkObjectBase *o)
vtkSmartPointer< vtkPlot > Plot
std::map< std::string, int > AxisCorners
virtual void SetColor(unsigned char r, unsigned char g, unsigned char b, unsigned char a)
virtual std::vector< std::string > GetSeriesRoles(const std::string &vtkNotUsed(tableName), const std::string &vtkNotUsed(columnName))
Subclasses can override this method to assign a role for a specific data array in the input dataset...
std::map< std::string, int > LineStyles
void SetPlotCorner(vtkPlot *plot, int corner)
std::map< std::string, vtkSmartPointer< vtkTable > > MapOfTables
virtual int GetInputArrayIndex(const std::string &vtkNotUsed(tableName), const std::string &vtkNotUsed(columnName), const std::string &vtkNotUsed(role))
const double & GetRed() const
std::map< std::string, int > MarkerStyles
void AddColumn(vtkAbstractArray *yarray, const char *yarrayname=NULL, vtkDataArray *xarray=NULL)
In STREAM_COLUMNS mode, use this method to add a column (yarray).
virtual bool UpdateSinglePlotProperties(vtkXYChartRepresentation *self, const std::string &tableName, const std::string &columnName, const std::string &role, vtkPlot *plot)
Returns false for in-visible plots.
std::map< std::string, double > MarkerSizes
vtkSmartPointer< vtkPlot > GetPlot(vtkChartRepresentation *self, const std::string &tableName, const std::string &columnName, const std::string &role=std::string()) const
virtual void SetLookupTable(vtkScalarsToColors *lut)
vtkAbstractArray * GetColumnByName(const char *name)
std::map< std::string, bool > UseColorMapping
virtual vtkPlot * AddPlot(int type)
void RemoveAllPlots(vtkChartXY *chartXY)
Destroy all vtkPlot instances.
static vtkPlotPoints * SafeDownCast(vtkObjectBase *o)
const char * GetColumnName(vtkIdType col)
void RemoveAllPlots(vtkChartXY *chartXY)
virtual bool RemovePlotInstance(vtkPlot *plot)
virtual void UpdatePlotProperties(vtkXYChartRepresentation *self)
Update properties for plots in the chart.
virtual vtkTable * GetInput()
virtual void SetInputArray(int index, const vtkStdString &name)
vtkIdType LowerPlot(vtkPlot *plot)
std::map< std::string, bool > SeriesVisibilities
virtual void SetScalarVisibility(bool)
virtual void SetInputData(vtkTable *table)
virtual vtkIdType StackPlotAbove(vtkPlot *plot, vtkPlot *under)
std::map< std::string, int > LineThicknesses
virtual vtkStdString GetLabel()
std::string PreviousXAxisSeriesName
virtual void UpdatePlots(vtkXYChartRepresentation *self, const MapOfTables &tables)
Update i.e.
void SelectColorArray(vtkIdType arrayNum)
vtkChartRepresentation is the base representation for charting representations.
void SetColorF(double color[3])
virtual void SetUseIndexForXSeries(bool)
exporter used by certain views to export data as CSV.
static vtkPlotBar * SafeDownCast(vtkObjectBase *o)
virtual vtkPlot * NewPlot(vtkXYChartRepresentation *self, const std::string &tableName, const std::string &columnName, const std::string &role)
Add new plot.
void HideAllPlots()
Hide all plots.
vtkPen * GetSelectionPen()
std::map< std::string, int > SeriesOrder
virtual bool Export(vtkXYChartRepresentation *self, vtkCSVExporter *exporter)
Export visible plots to a CSV file.
void SetPlotVisibility(bool val) const
vtkIdType GetNumberOfColumns()
virtual void SetVisible(bool)
virtual void SetLabel(const vtkStdString &label)
void SetLineType(int type)
virtual bool GetVisible()
void Intersect(const PlotsMap &other, vtkChartXY *chartXY)
const double & GetGreen() const
virtual void SelectableOff()
std::map< std::string, vtkColor3d > Colors