1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
// ************************************************************************************************
//
// BornAgain: simulate and fit reflection and scattering
//
//! @file GUI/View/Plotter/HistogramPlot.cpp
//! @brief Implements class HistogramPlot.
//!
//! @homepage http://www.bornagainproject.org
//! @license GNU General Public License v3 or higher (see COPYING)
//! @copyright Forschungszentrum Jülich GmbH 2018
//! @authors Scientific Computing Group at MLZ (see CITATION, AUTHORS)
//
// ************************************************************************************************
#include "GUI/View/Plotter/HistogramPlot.h"
#include "GUI/View/Base/Fontsize.h"
HistogramPlot::HistogramPlot()
{
setAttribute(Qt::WA_NoMousePropagation, false);
initGraph();
const QFont font1(QFont().family(), GUI::Font::fontSizeSmall());
xAxis->setTickLabelFont(font1);
yAxis->setTickLabelFont(font1);
yAxis->setScaleType(QCPAxis::stLogarithmic);
yAxis->setNumberFormat("eb");
yAxis->setNumberPrecision(0);
xAxis->setLabel("iteration");
yAxis->setLabel("chi2");
const QFont font2(QFont().family(), GUI::Font::fontSizeRegular());
xAxis->setLabelFont(font2);
yAxis->setLabelFont(font2);
}
void HistogramPlot::addData(double x, double y)
{
graph()->addData(x, y);
graph()->rescaleAxes();
replot();
}
void HistogramPlot::addData(const QVector<double>& x, const QVector<double>& y)
{
graph()->addData(x, y);
graph()->rescaleAxes();
replot();
}
void HistogramPlot::setData(const QVector<double>& x, const QVector<double>& y)
{
graph()->setData(x, y);
graph()->rescaleAxes();
replot();
}
void HistogramPlot::clearData()
{
removeGraph(graph());
initGraph();
replot();
}
void HistogramPlot::initGraph()
{
addGraph();
QPen pen(QColor(0, 0, 255, 200));
graph()->setLineStyle(QCPGraph::lsLine);
graph()->setPen(pen);
graph()->setBrush(QBrush(QColor(255 / 4, 160, 50, 150)));
auto base_size = GUI::Font::SizeOfLetterM();
auto* axisRectangle = axisRect();
axisRectangle->setAutoMargins(QCP::msTop | QCP::msBottom);
axisRectangle->setMargins(QMargins(base_size.width() * 4, base_size.height() * 2,
base_size.width() * 2, base_size.height() * 2));
}
|