src/ChartiSpindel.cpp

changeset 371
d03a426e0b6b
parent 334
9203fa01ddbf
child 372
d9c78eb19728
--- 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();
+    }
+}
+

mercurial