/* * Copyright (C) 2023 Arseniy Movshev * 2019 Florent Revest * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ import QtQuick 2.15 import org.asteroid.controls 1.0 import org.asteroid.health 1.0 import org.asteroid.sensorlogd 1.0 Item { id: graph property date startTime: new Date() property date endTime: new Date() onStartTimeChanged: hrGraph.loadGraphData(hrDataLoader.getDataFromTo(startTime,endTime)) onEndTimeChanged: hrGraph.loadGraphData(hrDataLoader.getDataFromTo(startTime,endTime)) Component.onCompleted: { hrGraph.loadGraphData(hrDataLoader.getDataFromTo(startTime,endTime)) } HrDataLoader { id: hrDataLoader } VerticalLabels { // labels column id: markerParent width: parent.width/8 startValue: 0 endValue: hrGraph.maxValue anchors { left: parent.left top: hrGraph.top bottom: hrGraph.bottom topMargin: hrGraph.lineWidth/2 bottomMargin: anchors.topMargin } } LineGraph { id: hrGraph anchors { left: markerParent.right right: parent.right top: parent.top bottom: labelsRow.top } relativeMode: false lineWidth: 4 } TimeLabels { id: labelsRow height: Dims.w(5) startTime: hrGraph.minTime / 1000 endTime: hrGraph.maxTime / 1000 anchors { bottom: parent.bottom left: hrGraph.left right: hrGraph.right rightMargin: hrGraph.lineWidth/2 leftMargin: anchors.rightMargin } } }