--- a/src/ChartiSpindel.cpp Tue Jul 26 11:15:37 2022 +0200 +++ b/src/ChartiSpindel.cpp Tue Jul 26 14:26:50 2022 +0200 @@ -15,6 +15,7 @@ * along with this program. If not, see <http://www.gnu.org/licenses/>. */ #include "ChartiSpindel.h" +#include "callout.h" #include "MainWindow.h" @@ -31,17 +32,21 @@ dialog->setWindowFlags(Qt::Window | Qt::WindowTitleHint | Qt::CustomizeWindowHint); dialog->resize(1024, 600); + QPushButton *saveButton = new QPushButton(tr("Save")); + saveButton->setAutoDefault(false); + QIcon icon1; + icon1.addFile(QString::fromUtf8(":icons/silk/disk.png"), QSize(), QIcon::Normal, QIcon::Off); + saveButton->setIcon(icon1); + QDialogButtonBox *buttonBox = new QDialogButtonBox(dialog); buttonBox->setObjectName(QString::fromUtf8("buttonBox")); - buttonBox->setGeometry(QRect(40, 565, 944, 36)); - buttonBox->setLayoutDirection(Qt::LeftToRight); - buttonBox->setOrientation(Qt::Horizontal); + buttonBox->setOrientation(Qt::Vertical); buttonBox->setStandardButtons(QDialogButtonBox::Ok); - buttonBox->setCenterButtons(true); + buttonBox->addButton(saveButton,QDialogButtonBox::ActionRole); - QSplineSeries *temperature = new QSplineSeries(); - QSplineSeries *density = new QSplineSeries(); - QSplineSeries *battery = new QSplineSeries(); + temperature = new QSplineSeries(); + density = new QSplineSeries(); + battery = new QSplineSeries(); query.prepare("SELECT * FROM log_ispindel WHERE code=:code ORDER BY datetime"); query.bindValue(":code", code); @@ -53,7 +58,7 @@ battery ->append(timestamp, query.value("battery").toDouble()); } - temperature->setName(tr("Temp °C")); + temperature->setName(tr("Temperature")); temperature->setColor(QColorConstants::Svg::red); density->setName(tr("SG")); QPen pen(QColorConstants::Svg::navy); @@ -62,7 +67,7 @@ battery->setName(tr("Battery")); battery->setColor(QColorConstants::Svg::limegreen); - QChart *chart = new QChart(); + chart = new QChart(); chart->setTitle(QString("%1 \"%2\"").arg(code).arg(name)); chart->addSeries(battery); chart->addSeries(temperature); @@ -102,14 +107,19 @@ chart->addAxis(axisYB, Qt::AlignRight); battery->attachAxis(axisYB); - QChartView *chartView = new QChartView(chart); + connect(temperature, &QSplineSeries::hovered, this, &ChartiSpindel::tooltip); + connect(density, &QSplineSeries::hovered, this, &ChartiSpindel::tooltip); + connect(battery, &QSplineSeries::hovered, this, &ChartiSpindel::tooltip); + + chartView = new QChartView(chart); chartView->setRenderHint(QPainter::Antialiasing); - dialog->setLayout(new QVBoxLayout); + dialog->setLayout(new QHBoxLayout); dialog->layout()->addWidget(chartView); dialog->layout()->addWidget(buttonBox); QObject::connect(buttonBox, SIGNAL(accepted()), dialog, SLOT(accept())); QObject::connect(buttonBox, SIGNAL(rejected()), dialog, SLOT(reject())); + QObject::connect(saveButton, SIGNAL(clicked()), this, SLOT(savePNG())); dialog->setModal(true); dialog->exec(); @@ -118,3 +128,47 @@ ChartiSpindel::~ChartiSpindel() {} + +void ChartiSpindel::savePNG() +{ + QString path = QFileDialog::getSaveFileName(this, tr("Save Image"), QDir::homePath() + "/ispindel.png", tr("Image (*.png)")); + if (path.isEmpty()) { + QMessageBox::warning(this, tr("Save File"), tr("No image file selected.")); + return; + } + + QImage img((chartView->size()), QImage::Format_ARGB32); + QPainter painter; + painter.begin(&img); + chartView->render(&painter); + painter.setRenderHint(QPainter::Antialiasing); + painter.end(); + img.save(path); +} + + +void ChartiSpindel::tooltip(QPointF point, bool state) +{ + QAbstractSeries *series = qobject_cast<QAbstractSeries *>(sender()); + + if (t_tooltip == 0) + t_tooltip = new Callout(chart, series); + + if (state) { + QDateTime timeis = QDateTime::fromMSecsSinceEpoch(point.x()); + t_tooltip->setSeries(series); + if (series == temperature) + t_tooltip->setText(QString("%1\nTemperature %2°C").arg(timeis.toString("dd-MM-yyyy hh:mm")).arg(point.y(), 2, 'f', 1)); + else if (series == density) + t_tooltip->setText(QString("%1\nDensity %2 SG").arg(timeis.toString("dd-MM-yyyy hh:mm")).arg(point.y(), 5, 'f', 4)); + else if (series == battery) + t_tooltip->setText(QString("%1\nBattery %2 volt").arg(timeis.toString("dd-MM-yyyy hh:mm")).arg(point.y(), 3, 'f', 2)); + t_tooltip->setAnchor(point); + t_tooltip->setZValue(11); + t_tooltip->updateGeometry(); + t_tooltip->show(); + } else { + t_tooltip->hide(); + } +} +