#include "TestWidgetParamScatterPlots.h" #include #include #include #include TestWidgetParamScatterPlots::TestWidgetParamScatterPlots(QWidget *parent) : QWidget(parent) { QVBoxLayout* layoutPSP=new QVBoxLayout(this); setLayout(layoutPSP); resize(1000, 800); plotPSP=new JKQTPlotter(true, this); plotPSP->setPlotUpdateEnabled(false); plotPSP->getPlotter()->setPlotLabel(tr("\\textbf{parametrized scatter plots}")); plotPSP->setObjectName("plotPSP"); plotPSP->getPlotter()->setUserSettigsFilename(QApplication::applicationDirPath()+"/usersettings.ini", "plot_peaks/"); layoutPSP->addWidget(plotPSP); QVector dataX, dataY, dataY1, dataY2, dataY3, dataC, dataS, dataI, dataSy ; for (int i=0; i<100; i++) { dataI<getDatastore()->addCopiedColumn(dataX, "x"); int pspy=plotPSP->getDatastore()->addCopiedColumn(dataY, "y"); int pspy1=plotPSP->getDatastore()->addCopiedColumn(dataY1, "y1"); int pspy2=plotPSP->getDatastore()->addCopiedColumn(dataY2, "y2"); int pspy3=plotPSP->getDatastore()->addCopiedColumn(dataY2, "y3"); int pspc=plotPSP->getDatastore()->addCopiedColumn(dataC, "color"); int psps=plotPSP->getDatastore()->addCopiedColumn(dataS, "size"); int pspsy=plotPSP->getDatastore()->addCopiedColumn(dataSy, "symbol"); pltePSPCol=new JKQTPXYParametrizedErrorScatterGraph(plotPSP->getPlotter()); pltePSPCol->set_title(tr("changing color")); pltePSPCol->set_xColumn(pspx); pltePSPCol->set_yColumn(pspy); pltePSPCol->set_colorColumn(pspc); pltePSPCol->set_yErrorColumn(pspy1); pltePSPCol->set_yErrorColumnLower(pspy2); pltePSPCol->set_yErrorSymmetric(true); pltePSPCol->set_drawLine(true); plotPSP->getPlotter()->addGraph(pltePSPCol); pltePSPSize=new JKQTPXYParametrizedScatterGraph(plotPSP->getPlotter()); pltePSPSize->set_xColumn(pspx); pltePSPSize->set_yColumn(pspy1); pltePSPSize->set_sizeColumn(psps); pltePSPSize->set_title(tr("changing size")); plotPSP->getPlotter()->addGraph(pltePSPSize); pltePSPSymb=new JKQTPXYParametrizedScatterGraph(plotPSP->getPlotter()); pltePSPSymb->set_xColumn(pspx); pltePSPSymb->set_yColumn(pspy3); pltePSPSymb->set_symbolColumn(pspsy); pltePSPSymb->set_title(tr("changing symbol")); plotPSP->getPlotter()->addGraph(pltePSPSymb); plotPSP->setPlotUpdateEnabled(true); plotPSP->zoomToFit(); QCheckBox* chkPSPErrorSymmetric=new QCheckBox(tr("symmetric errors"), this); chkPSPErrorSymmetric->setChecked(true); connect(chkPSPErrorSymmetric, SIGNAL(toggled(bool)), this, SLOT(setPSPSymmErrors(bool))); layoutPSP->addWidget(chkPSPErrorSymmetric); } void TestWidgetParamScatterPlots::setPSPSymmErrors(bool checked) { pltePSPCol->set_yErrorSymmetric(checked); plotPSP->redrawPlot(); }