Redesign the cover page

This commit is contained in:
Matti Viljanen 2022-08-28 00:51:24 +03:00
parent 317cd5bb6a
commit c18491afd6
No known key found for this signature in database
GPG key ID: CF32A1495158F888
5 changed files with 58 additions and 47 deletions

View file

@ -0,0 +1,26 @@
/**
* Battery Buddy, a Sailfish application to prolong battery lifetime
*
* Copyright (C) 2019-2020 Matti Viljanen
*
* Battery Buddy 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.
*
* Battery Buddy 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 Battery Buddy. If not, see <http://www.gnu.org/licenses/>.
*
* Author: Matti Viljanen
*/
import QtQuick 2.6
import Sailfish.Silica 1.0
Label {
width: parent.width
anchors.topMargin: height / 2
color: Theme.highlightColor
horizontalAlignment: Text.AlignHCenter
}

View file

@ -22,46 +22,28 @@ import "../components"
CoverBackground {
id: coverPage
onStatusChanged: batteryGraph.updateView()
BatteryGraph {
id: batteryGraph
x: coverPage.width * 0.3
y: coverPage.width * 0.25
width: 0.4 * coverPage.width
Component.onCompleted: updateView()
onStateChanged: updateView()
onChargerConnectedChanged: updateView()
onChargeChanged: updateView()
function updateView() {
if(charge <= settings.lowerLimit && battery.state === "discharging") {
coverText.text = qsTr("Connect charger")
}
else if(battery.charge >= settings.upperLimit &&
(battery.state === "charging" || battery.state === "idle")) {
coverText.text = qsTr("Disconnect charger")
}
else if(battery.chargerConnected && battery.state === "charging") {
coverText.text = qsTr("Charging")
}
else if(battery.chargerConnected && battery.state === "discharging") {
coverText.text = qsTr("Not charging")
}
else { // Discharging
coverText.text = qsTr("Battery Buddy")
}
Column {
spacing: coverPage.width / 20
anchors {
left: coverPage.left
right: coverPage.right
verticalCenter: parent.verticalCenter
}
BatteryGraph {
x: coverPage.width * 0.3
y: coverPage.width * 0.25
width: 0.35 * coverPage.width
}
CoverLabel {
id: chargeLabel
text: "🔋 " + battery.charge + "%"
}
CoverLabel {
text: "🔌 " + Math.floor(battery.current / 1000) + " mA"
}
CoverLabel {
height: text === '🌡️ ' ? 0 : chargeLabel.height
text: "🌡️ " + (battery.temperature === 0x7FFFFFFF ? '? °C' : formatTemperature(battery.temperature))
}
}
Label {
id: coverText
anchors.top: batteryGraph.bottom
anchors.bottom: coverPage.bottom
anchors.horizontalCenter: coverPage.horizontalCenter
width: coverPage.width * 0.9
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
wrapMode: Text.Wrap
maximumLineCount: 2
}
}

View file

@ -25,4 +25,11 @@ ApplicationWindow
initialPage: Component { MainPage { } }
cover: Qt.resolvedUrl("cover/CoverPage.qml")
allowedOrientations: Orientation.LandscapeMask | Orientation.Portrait
function formatTemperature(temp) {
if(Qt.locale().measurementSystem === Locale.ImperialUSSystem) {
return Math.floor((battery.temperature / 10) * 1.8 + 32) + " °F"
}
return Math.floor(battery.temperature / 10) + " °C"
}
}

View file

@ -139,13 +139,6 @@ Page {
label: qsTr("Temperature:")
value: battery.temperature === 0x7FFFFFFF ? healthText["unknown"] : formatTemperature(battery.temperature)
visible: battery.temperature !== 0x7FFFFFFF
function formatTemperature(temp) {
if(Qt.locale().measurementSystem === Locale.ImperialUSSystem) {
return Math.floor((battery.temperature / 10) * 1.8 + 32) + " °F"
}
return Math.floor(battery.temperature / 10) + " °C"
}
}
}
}

View file

@ -1,3 +1,6 @@
TEMPLATE = subdirs
CONFIG += ordered
SUBDIRS = application service
DISTFILES += \
application/qml/components/CoverLabel.qml