initial take on QtCharts

This commit is contained in:
Michael Zanetti 2018-10-24 11:06:31 +02:00
parent c84cd88d76
commit 10cbc9941b
7 changed files with 149 additions and 7 deletions

View File

@ -15,7 +15,7 @@ include(../nymea-remoteproxy/libnymea-remoteproxyclient/libnymea-remoteproxyclie
QT -= gui
QT += network websockets bluetooth
QT += network websockets bluetooth charts
LIBS += -lssl -lcrypto

View File

@ -7,7 +7,8 @@
#include "types/logentry.h"
#include "logmanager.h"
LogsModelNg::LogsModelNg(QObject *parent) : QAbstractListModel(parent)
LogsModelNg::LogsModelNg(QObject *parent) : QAbstractListModel(parent),
m_lineSeries(new QtCharts::QLineSeries(this))
{
}
@ -133,9 +134,19 @@ void LogsModelNg::setEndTime(const QDateTime &endTime)
}
}
QtCharts::QLineSeries *LogsModelNg::lineSeries() const
{
return m_lineSeries;
}
void LogsModelNg::setLineSeries(QtCharts::QLineSeries *lineSeries)
{
m_lineSeries = lineSeries;
}
void LogsModelNg::logsReply(const QVariantMap &data)
{
qDebug() << "logs reply" << data;
// qDebug() << "logs reply" << data;
m_busy = false;
emit busyChanged();
@ -170,6 +181,8 @@ void LogsModelNg::logsReply(const QVariantMap &data)
beginInsertRows(QModelIndex(), offset, offset + newBlock.count() - 1);
for (int i = 0; i < newBlock.count(); i++) {
m_list.insert(offset + i, newBlock.at(i));
qDebug() << "Adding line series point:" << i << newBlock.at(i)->timestamp().toSecsSinceEpoch() << newBlock.at(i)->value().toReal();
m_lineSeries->insert(offset + i, QPointF(newBlock.at(i)->timestamp().toSecsSinceEpoch(), newBlock.at(i)->value().toReal()));
}
endInsertRows();
emit countChanged();

View File

@ -4,6 +4,7 @@
#include <QObject>
#include <QAbstractListModel>
#include <QDateTime>
#include <QLineSeries>
class LogEntry;
class Engine;
@ -20,6 +21,8 @@ class LogsModelNg : public QAbstractListModel
Q_PROPERTY(QDateTime startTime READ startTime WRITE setStartTime NOTIFY startTimeChanged)
Q_PROPERTY(QDateTime endTime READ endTime WRITE setEndTime NOTIFY endTimeChanged)
Q_PROPERTY(QtCharts::QLineSeries *lineSeries READ lineSeries WRITE setLineSeries NOTIFY lineSeriesChanged)
public:
enum Roles {
RoleTimestamp,
@ -56,6 +59,9 @@ public:
QDateTime endTime() const;
void setEndTime(const QDateTime &endTime);
QtCharts::QLineSeries *lineSeries() const;
void setLineSeries(QtCharts::QLineSeries *lineSeries);
protected:
virtual void fetchMore(const QModelIndex &parent = QModelIndex()) override;
virtual bool canFetchMore(const QModelIndex &parent = QModelIndex()) const override;
@ -69,6 +75,7 @@ signals:
void startTimeChanged();
void endTimeChanged();
void engineChanged();
void lineSeriesChanged();
private slots:
void newLogEntryReceived(const QVariantMap &data);
@ -89,6 +96,8 @@ private:
int m_blockSize = 100;
bool m_canFetchMore = true;
QtCharts::QLineSeries *m_lineSeries = nullptr;
QList<QPair<QDateTime, bool> > m_fetchedPeriods;
};

View File

@ -18,7 +18,7 @@
* *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
#include <QGuiApplication>
#include <QApplication>
#include <QCommandLineParser>
#include <QtQml/QQmlContext>
#include <QQmlApplicationEngine>
@ -58,7 +58,7 @@ int main(int argc, char *argv[])
{
QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
QGuiApplication application(argc, argv);
QApplication application(argc, argv);
application.setApplicationName("nymea-app");
application.setOrganizationName("nymea");
@ -71,7 +71,7 @@ int main(int argc, char *argv[])
applicationFont.setCapitalization(QFont::MixedCase);
applicationFont.setPixelSize(16);
applicationFont.setWeight(QFont::Normal);
QGuiApplication::setFont(applicationFont);
QApplication::setFont(applicationFont);
QTranslator qtTranslator;
qtTranslator.load("qt_" + QLocale::system().name(),

View File

@ -2,7 +2,7 @@ TEMPLATE=app
TARGET=nymea-app
include(../config.pri)
QT += network qml quick quickcontrols2 svg websockets bluetooth
QT += network qml quick quickcontrols2 svg websockets bluetooth charts
INCLUDEPATH += $$top_srcdir/libnymea-common \
$$top_srcdir/libnymea-app-core

View File

@ -0,0 +1,58 @@
{
"templates": [
{
"interfaceName": "",
"description": "",
"ruleNameTemplate": "%0 ...",
"eventDescriptorTemplates": [ // optional
{
"interfaceName": "",
"interfaceEvent": "",
"selectionId": 0,
"params": [ // optional
{
"name": "",
"value": "", //optional
}
]
}
],
"stateEvaluatorTemplate": {
"stateDescriptorTemplate": {
"interfaceName": "",
"interfaceState": "",
"selectionId": 1,
"operator": "ValueOperatorEquals",
"value": true
}
},
"ruleActionTemplates": [
{
"interfaceName": "",
"interfaceAction": "",
"selectionId": 2,
"params": [
{
"name": "",
"value": ""
}
]
}
],
"ruleExitActionTemplates": [
{
"interfaceName": "",
"interfaceAction": "",
"selectionId": 2,
"params": [
{
"name": "",
"value": ""
}
]
}
]
}
]
}

View File

@ -4,6 +4,7 @@ import QtQuick.Layouts 1.1
import Nymea 1.0
import "../components"
import "../customviews"
import QtCharts 2.2
Page {
id: root
@ -43,6 +44,7 @@ Page {
deviceId: root.device.id
typeIds: [root.stateType.id]
live: true
lineSeries: lineSeries1
}
ColumnLayout {
@ -58,6 +60,9 @@ Page {
TabButton {
text: qsTr("Graph")
}
TabButton {
text: qsTr("Graph NG")
}
}
SwipeView {
@ -163,6 +168,63 @@ Page {
}
}
Item {
width: swipeView.width
height: swipeView.height
ChartView {
id: chartView
anchors.fill: parent
ValueAxis {
id: yAxis
min: 0
max: 50
}
ValueAxis {
id: xAxis
min: Math.floor(startTime.getTime() / 1000)
max: Math.floor(endTime.getTime() / 1000)
property date startTime: {
var date = new Date();
date.setHours(date.getHours() - 6);
return date;
}
property date endTime: new Date()
Component.onCompleted: print("creating axis:", startTime, endTime)
}
LineSeries {
id: lineSeries1
axisX: xAxis
axisY: yAxis
}
MouseArea {
anchors.fill: parent
property int lastX: 0
property int lastY: 0
onPressed: {
lastX = mouse.x
lastY = mouse.y
}
onPositionChanged: {
if (lastX !== mouse.x) {
chartView.scrollRight(lastX - mouse.x)
lastX = mouse.x
}
if (lastY !== mouse.y) {
chartView.scrollDown(lastY - mouse.y)
lastY = mouse.y
}
}
}
}
}
}
}
}