2022-09-11 04:35:30 +08:00
|
|
|
/** \example barchart_errorbars.cpp
|
|
|
|
* Shows how to draw Barcharts with errorbars in a JKQTPlotter
|
|
|
|
*
|
|
|
|
* \ref JKQTPlotterBarchartsErrorBars
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "jkqtpexampleapplication.h"
|
|
|
|
#include <QApplication>
|
|
|
|
#include "jkqtplotter/jkqtplotter.h"
|
|
|
|
#include "jkqtplotter/graphs/jkqtpscatter.h"
|
|
|
|
#include "jkqtplotter/graphs/jkqtpbarchart.h"
|
|
|
|
#include "jkqtpexampleapplication.h"
|
|
|
|
#include "jkqtcommon/jkqtpmathtools.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
template <class TCHART>
|
|
|
|
void doExample(JKQTPlotter& plot, const QString& title)
|
|
|
|
{
|
|
|
|
// 1. create a plotter window and get a pointer to the internal datastore (for convenience)
|
|
|
|
JKQTPDatastore* ds=plot.getDatastore();
|
|
|
|
|
|
|
|
// 2. now we create three columns for key and value
|
|
|
|
size_t columnK=ds->addLinearColumn(6, 0.4*JKQTPSTATISTICS_PI, 2.2*JKQTPSTATISTICS_PI,"k");
|
2024-02-05 04:42:53 +08:00
|
|
|
size_t columnV=ds->addCalculatedColumnFromColumn(columnK, [](double x) { return cos(x); }, "v");
|
|
|
|
size_t columnE=ds->addCalculatedColumnFromColumn(columnK, [](double x) { return 0.05+0.06*(1.0+sin(x)); }, "error");
|
2022-09-11 04:35:30 +08:00
|
|
|
|
|
|
|
// 3. create a graph in the plot, which plots the dataset with symmetric:
|
|
|
|
TCHART* graph1=new TCHART(&plot);
|
|
|
|
graph1->setKeyColumn(columnK);
|
|
|
|
graph1->setValueColumn(columnV);
|
|
|
|
graph1->setBarErrorColumn(columnE);
|
|
|
|
// set error indicator style
|
|
|
|
graph1->setBarErrorStyle(JKQTPErrorBars);
|
|
|
|
graph1->setTitle(QObject::tr("JKQTPErrorBars"));
|
|
|
|
plot.addGraph(graph1);
|
|
|
|
|
|
|
|
// 4. create a second graph in the plot, which plots the second dataset with outer error bars only:
|
|
|
|
TCHART* graph2=new TCHART(&plot);
|
|
|
|
graph2->setKeyColumn(columnK);
|
|
|
|
graph2->setValueColumn(columnV);
|
|
|
|
graph2->setBarErrorColumn(columnE);
|
|
|
|
// set error indicator style
|
|
|
|
graph2->setBarErrorStyle(JKQTPErrorHalfBarsOutwards);
|
|
|
|
graph2->setTitle(QObject::tr("JKQTPErrorHalfBarsOutwards"));
|
|
|
|
plot.addGraph(graph2);
|
|
|
|
|
|
|
|
// 5. now we set the graphs, so they are plotted side-by-side
|
|
|
|
// This function searches all JKQTPBarHorizontalGraph in the current
|
|
|
|
// plot and sets their shift/scale so they form a nice plot with
|
|
|
|
// side-by-side groups
|
|
|
|
graph1->autoscaleBarWidthAndShift(0.9, 0.9);
|
|
|
|
|
|
|
|
|
|
|
|
// 6 autoscale the plot so the graph is contained
|
|
|
|
plot.zoomToFit();
|
|
|
|
|
|
|
|
// 7. show plotter and make it a decent size
|
|
|
|
plot.getPlotter()->setKeyPosition(JKQTPKeyInsideTopLeft);
|
|
|
|
plot.setWindowTitle(title);
|
|
|
|
plot.show();
|
|
|
|
plot.resize(400,400);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(int argc, char* argv[])
|
|
|
|
{
|
|
|
|
|
|
|
|
JKQTPAppSettingController highDPIController(argc,argv);
|
|
|
|
JKQTPExampleApplication app(argc, argv);
|
|
|
|
|
|
|
|
|
|
|
|
JKQTPlotter plotV, plotH;
|
|
|
|
doExample<JKQTPBarVerticalErrorGraph>(plotV, "1: JKQTPBarVerticalErrorGraph");
|
|
|
|
doExample<JKQTPBarHorizontalErrorGraph>(plotH, "2: JKQTPBarHorizontalErrorGraph");
|
|
|
|
|
|
|
|
return app.exec();
|
|
|
|
}
|