URANOS/dialogshowpic.cpp
2022-05-22 20:48:39 +02:00

100 lines
2.8 KiB
C++

#include "dialogshowpic.h"
#include "ui_dialogshowpic.h"
#include "qcustomplot.h"
#include "mainwindow.h"
#include "Toolkit.h"
DialogShowPic::DialogShowPic(QWidget *parent) :
QDialog(parent),
ui(new Ui::DialogShowPic)
{
ui->setupUi(this);
setupShowGraph(ui->widget);
}
int number=1;
void DialogShowPic::setupShowGraph(QCustomPlot *customPlot)
{
TMatrixF matrix = MainWindow::getTMatrix(number);
// TMatrixF matrix(1,1);
QCPColorMap *colorMap = new QCPColorMap(customPlot->xAxis,customPlot->yAxis);
customPlot->axisRect()->setupFullAxesBox(true);
customPlot->xAxis->setLabel("x [pixel]");
customPlot->yAxis->setLabel("y [pixel]");
//customPlot->addPlottable(colorMap);
colorMap->data()->setSize(matrix.GetColUpb(), matrix.GetColUpb());
colorMap->data()->setRange(QCPRange(0, matrix.GetColUpb()), QCPRange(0, matrix.GetColUpb()));
for (int x=0; x<matrix.GetColUpb(); ++x)
for (int y=0; y<matrix.GetColUpb(); ++y)
colorMap->data()->setCell(x, y, matrix(x,y));
colorMap->setGradient(QCPColorGradient::gpJet);
colorMap->rescaleDataRange(true);
customPlot->rescaleAxes();
colorMap->setDataRange(QCPRange(0,256));
customPlot->replot();
}
DialogShowPic::~DialogShowPic()
{
delete ui;
}
void DialogShowPic::replotGraph()
{
TMatrixF matrix = MainWindow::getTMatrix(number);
ui->widget->clearPlottables();
ui->widget->xAxis->setRange(QCPRange(0, matrix.GetColUpb()));
ui->widget->yAxis->setRange(QCPRange(0, matrix.GetColUpb()));
QCPColorMap *colorMap = new QCPColorMap( ui->widget->xAxis, ui->widget->yAxis);
Int_t a = matrix.GetColUpb();
Int_t b = matrix.GetNcols();
//cout<<castIntToString(a)<<" "<<castIntToString(b)<<endl;
// ui->widget->addPlottable(colorMap);
colorMap->data()->setSize(matrix.GetNcols(), matrix.GetNcols());
colorMap->data()->setRange(QCPRange(0, matrix.GetColUpb()), QCPRange(0, matrix.GetColUpb()));
for (int x=0; x<matrix.GetColUpb(); ++x)
for (int y=0; y<matrix.GetColUpb(); ++y)
colorMap->data()->setCell(x, y, matrix(x,y));
colorMap->setGradient(QCPColorGradient::gpCold);
colorMap->rescaleDataRange(true);
ui->widget->rescaleAxes();
colorMap->setDataRange(QCPRange(0,256));
ui->widget->replot();
}
void DialogShowPic::on_pushButtonPlus_clicked()
{
number++;
int newInt = number+1;
string numberString = castIntToString(newInt);
ui->labelNo->setText(QString::fromStdString(numberString));
replotGraph();
}
void DialogShowPic::on_pushButtonMinus_clicked()
{
if (number>0)
{
number--;
int newInt = number+1;
string numberString = castIntToString(newInt);
ui->labelNo->setText(QString::fromStdString(numberString));
replotGraph();
}
}