Compare commits
5 Commits
193579e798
...
4f1af0f4ae
| Author | SHA1 | Date | |
|---|---|---|---|
| 4f1af0f4ae | |||
| 3e9c1cc20b | |||
| e118fa4a20 | |||
| 2c9e9be6b3 | |||
| c36e9053c4 |
95
aalegacy.cpp
@@ -185,102 +185,7 @@ double gSetSpeedLimit = -1, gSetMinSpeedLimit = -1, gSetThrottleSpeedLimit = -1;
|
|||||||
#define BATTERY 3
|
#define BATTERY 3
|
||||||
#define BIB 4
|
#define BIB 4
|
||||||
|
|
||||||
/*
|
|
||||||
class BCThemeSwitchButton : public QPushButton {
|
|
||||||
Q_OBJECT
|
|
||||||
|
|
||||||
public:
|
|
||||||
explicit BCThemeSwitchButton(QWidget *parent = nullptr)
|
|
||||||
: QPushButton(parent), m_isDarkMode(true)
|
|
||||||
{
|
|
||||||
// 1. Visuelles Setup: Flach, keine Ränder, Hand-Cursor
|
|
||||||
setFlat(true);
|
|
||||||
setCursor(Qt::PointingHandCursor);
|
|
||||||
setFixedSize(32, 24); // Kleiner Footprint im StatusBar
|
|
||||||
|
|
||||||
// CSS: Transparent, damit es sich nahtlos in den StatusBar einfügt
|
|
||||||
// Schriftgröße etwas erhöhen, damit die Emojis gut erkennbar sind
|
|
||||||
setStyleSheet(R"(
|
|
||||||
QPushButton {
|
|
||||||
border: none;
|
|
||||||
background-color: transparent;
|
|
||||||
font-size: 14pt;
|
|
||||||
}
|
|
||||||
QPushButton:hover {
|
|
||||||
background-color: rgba(128, 128, 128, 30); // Leichter Hover-Effekt
|
|
||||||
border-radius: 4px;
|
|
||||||
}
|
|
||||||
)");
|
|
||||||
|
|
||||||
// 2. Initialer Status (Startet im Dark Mode -> zeigt Mond)
|
|
||||||
updateIcon();
|
|
||||||
|
|
||||||
// 3. Klick verbinden
|
|
||||||
connect(this, &QPushButton::clicked, this, &BCThemeSwitchButton::toggle);
|
|
||||||
}
|
|
||||||
|
|
||||||
signals:
|
|
||||||
void themeChanged(bool isDark);
|
|
||||||
|
|
||||||
private slots:
|
|
||||||
void toggle() {
|
|
||||||
m_isDarkMode = !m_isDarkMode;
|
|
||||||
updateIcon();
|
|
||||||
emit themeChanged(m_isDarkMode);
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
void updateIcon() {
|
|
||||||
// Logik:
|
|
||||||
// Ist Dark Mode an? Zeige Mond (oder Sonne, je nach Geschmack).
|
|
||||||
// Hier: Zeige das Symbol des AKTUELLEN Modus.
|
|
||||||
setText(m_isDarkMode ? "🌙" : "☀️");
|
|
||||||
setToolTip(m_isDarkMode ? "Switch to Light Mode" : "Switch to Dark Mode");
|
|
||||||
}
|
|
||||||
|
|
||||||
bool m_isDarkMode;
|
|
||||||
};
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
class MainWindow : public QMainWindow
|
|
||||||
{
|
|
||||||
Q_OBJECT
|
|
||||||
public:
|
|
||||||
MainWindow(QWidget *parent = nullptr)
|
|
||||||
: QMainWindow(parent)
|
|
||||||
{
|
|
||||||
setWindowTitle("Fluent Theme Switcher");
|
|
||||||
resize(800, 600);
|
|
||||||
|
|
||||||
// --- STATUSBAR SETUP ---
|
|
||||||
QStatusBar *statBar = statusBar();
|
|
||||||
|
|
||||||
// Optional: Normale Nachricht links
|
|
||||||
statBar->showMessage("Ready");
|
|
||||||
|
|
||||||
// 1. Unseren Switcher erstellen
|
|
||||||
BCThemeSwitchButton *themeBtn = new BCThemeSwitchButton(this);
|
|
||||||
|
|
||||||
// 2. WICHTIG: Rechts hinzufügen
|
|
||||||
statBar->addPermanentWidget(themeBtn);
|
|
||||||
|
|
||||||
// 3. Signal verbinden: Button klick -> Theme ändern
|
|
||||||
connect(themeBtn, &BCThemeSwitchButton::themeChanged, this, [this](bool isDark){
|
|
||||||
if (isDark) {
|
|
||||||
applyFluentDarkTheme(*qApp); // Funktion von vorhin
|
|
||||||
statusBar()->showMessage("Dark Mode Activated", 3000);
|
|
||||||
} else {
|
|
||||||
applyFluentLightTheme(*qApp); // Funktion von vorhin
|
|
||||||
statusBar()->showMessage("Light Mode Activated", 3000);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// Initiale Anwendung (Dark Mode)
|
|
||||||
applyFluentDarkTheme(*qApp);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
*/
|
|
||||||
|
|
||||||
char *getNodeName(unsigned char id)
|
char *getNodeName(unsigned char id)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -135,19 +135,28 @@ BCDriver::DriverStateResult BCDriverTinyCan::setConsoleSlaveMode()
|
|||||||
{
|
{
|
||||||
|
|
||||||
uint32_t console = static_cast<uint32_t>(BCDevice::ID::Console);
|
uint32_t console = static_cast<uint32_t>(BCDevice::ID::Console);
|
||||||
uint8_t slaveFlag = static_cast<uint8_t>(BC::ID::Cons_Status_Slave);
|
uint8_t slaveFlag = static_cast<uint8_t> (BC::ID::Cons_Status_Slave);
|
||||||
|
|
||||||
qDebug() << "XXX BCDriverTinyCan::Driver Init: putting Console in slave mode ... ";
|
qDebug() << "XXX BCDriverTinyCan::Driver Init: putting Console in slave mode ... ";
|
||||||
|
|
||||||
// Console already in slave mode. good!
|
TransmitResult isSlave = 0;
|
||||||
if( readRawByte( console, slaveFlag ) )
|
// Already slave?
|
||||||
return DriverState::DeviceReady;
|
isSlave = readRawByte( console, slaveFlag );
|
||||||
|
if( isSlave.has_value() )
|
||||||
|
{
|
||||||
|
qDebug() << "Console responded: " << isSlave.value();
|
||||||
|
if( isSlave.value() == 1 )
|
||||||
|
{
|
||||||
|
qDebug() << "Console already in slave mode. good!";
|
||||||
|
return DriverState::DeviceReady;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
qDebug() << "BCDriverTinyCan::BCDriverTinyCan::XXX Driver Init: putting Console in slave mode ... ";
|
qDebug() << "BCDriverTinyCan::BCDriverTinyCan::XXX Driver Init: putting Console in slave mode ... ";
|
||||||
|
|
||||||
unsigned int retry = cTimeOuts;
|
unsigned int retry = cTimeOuts;
|
||||||
|
|
||||||
TransmitResult isSlave = 0;
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
writeRawByte( console, slaveFlag, 1 );
|
writeRawByte( console, slaveFlag, 1 );
|
||||||
@@ -185,17 +194,75 @@ void BCDriverTinyCan::resetDriver()
|
|||||||
TransmitResult BCDriverTinyCan::readRawByte( uint32_t deviceID, uint8_t registerID ) const
|
TransmitResult BCDriverTinyCan::readRawByte( uint32_t deviceID, uint8_t registerID ) const
|
||||||
{
|
{
|
||||||
|
|
||||||
|
qDebug() << " --- CAN Read Byte: Device: "<< deviceID << " register: " << registerID << " TRY! ";
|
||||||
|
|
||||||
|
struct TCanMsg msg;
|
||||||
|
int err, retry = 20;
|
||||||
|
int timeout = 80;
|
||||||
|
|
||||||
|
unsigned char receipient = (unsigned char) deviceID;
|
||||||
|
unsigned char reg = (unsigned char) registerID;
|
||||||
|
|
||||||
|
msg.MsgFlags = 0L;
|
||||||
|
msg.Id = receipient;
|
||||||
|
msg.MsgLen = 2;
|
||||||
|
msg.MsgData[0] = 0x00;
|
||||||
|
msg.MsgData[1] = reg;
|
||||||
|
|
||||||
|
CanTransmit(0, &msg, 1);
|
||||||
|
|
||||||
|
while(timeout-- && CanTransmitGetCount(0))
|
||||||
|
bc::delay_millis( cTIMEOUT_MS );
|
||||||
|
|
||||||
|
if (timeout == -1)
|
||||||
|
qDebug() << "error: could not send value to node ";
|
||||||
|
|
||||||
|
retry:
|
||||||
|
|
||||||
|
timeout = 80;
|
||||||
|
while(timeout-- && !CanReceiveGetCount(0))
|
||||||
|
bc::delay_millis( cTIMEOUT_MS );
|
||||||
|
|
||||||
|
if (timeout == -1)
|
||||||
|
{
|
||||||
|
qDebug() << "error: no response from node";
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((err = CanReceive(0, &msg, 1)) > 0)
|
||||||
|
{
|
||||||
|
qDebug() << " retry: " << retry << " BIB:" << BC::ID::ID_Bib << " msg.Id: " << msg.Id << " msg.MsgLen: " << msg.MsgLen << " msg.MsgData[1]: " << msg.MsgData[1] << " reg: " << reg;
|
||||||
|
if (--retry && (msg.Id != (uint32_t)BC::ID::ID_Bib|| msg.MsgLen != 4 || msg.MsgData[1] != reg))
|
||||||
|
goto retry;
|
||||||
|
|
||||||
|
if (!retry)
|
||||||
|
{
|
||||||
|
qDebug() << "XXX error: no response from node: " << err;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
qDebug() << " --- CAN Read Byte: Device: "<< deviceID << " register: " << registerID << " BYTE: " << (uint32_t) msg.MsgData[3];
|
||||||
|
return (unsigned int) msg.MsgData[3];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qDebug() << "Error:" <<err;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/*
|
||||||
//TransmitResult
|
//TransmitResult
|
||||||
qDebug() << " --- BCDriverTinyCan::readRawByte DriverState: " << getDriverState();
|
qDebug() << " --- BCDriverTinyCan::readRawByte DriverState: " << getDriverState();
|
||||||
|
|
||||||
if( _driverState <DriverState::Opened )
|
if( _driverState <DriverState::Opened )
|
||||||
return std::unexpected(QString("readRawValue error: driver not loaded." ) );
|
return std::unexpected(QString("readRawValue error: driver not loaded." ) );
|
||||||
|
|
||||||
|
unsigned char receipient = (unsigned char ) deviceID;
|
||||||
::TCanMsg msg;
|
::TCanMsg msg;
|
||||||
|
|
||||||
// msg verpacken
|
// msg verpacken
|
||||||
msg.MsgFlags = 0L;
|
msg.MsgFlags = 0L;
|
||||||
msg.Id = deviceID;
|
msg.Id = receipient;//deviceID;
|
||||||
msg.MsgLen = 2;
|
msg.MsgLen = 2;
|
||||||
msg.MsgData[0] = 0x00;
|
msg.MsgData[0] = 0x00;
|
||||||
msg.MsgData[1] = registerID;
|
msg.MsgData[1] = registerID;
|
||||||
@@ -244,13 +311,14 @@ retry:
|
|||||||
if( !timeOuts )
|
if( !timeOuts )
|
||||||
return std::unexpected(QString("CAN response errror: timeout" ));
|
return std::unexpected(QString("CAN response errror: timeout" ));
|
||||||
|
|
||||||
|
qDebug() << " --- CAN Read Byte: " << (uint32_t) msg.MsgData[3] << " Device:: "<< deviceID << " register: " << registerID;
|
||||||
return (uint32_t) msg.MsgData[3];
|
return (uint32_t) msg.MsgData[3];
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// void BCDriverTinyCan::setValue( unsigned char receipient, unsigned char reg, unsigned char value )
|
// void BCDriverTinyCan::setValue( unsigned char receipient, unsigned char reg, unsigned char value )
|
||||||
TransmitResult BCDriverTinyCan::writeRawByte( uint32_t deviceID, uint8_t registerID ,uint8_t value ) const
|
TransmitResult BCDriverTinyCan::writeRawByte( uint32_t deviceID, uint8_t registerID, uint8_t value ) const
|
||||||
{
|
{
|
||||||
|
|
||||||
if( _driverState <DriverState::Opened )
|
if( _driverState <DriverState::Opened )
|
||||||
@@ -261,6 +329,7 @@ TransmitResult BCDriverTinyCan::writeRawByte( uint32_t deviceID, uint8_t registe
|
|||||||
::TCanMsg msg;
|
::TCanMsg msg;
|
||||||
int timeout_count = cTIMEOUT_COUNT;
|
int timeout_count = cTIMEOUT_COUNT;
|
||||||
|
|
||||||
|
|
||||||
msg.MsgFlags = 0L;
|
msg.MsgFlags = 0L;
|
||||||
msg.Id = deviceID;
|
msg.Id = deviceID;
|
||||||
msg.MsgLen = 4;
|
msg.MsgLen = 4;
|
||||||
|
|||||||
@@ -63,9 +63,6 @@ private:
|
|||||||
static constexpr int cTIMEOUT_MS = 10; // 10ms
|
static constexpr int cTIMEOUT_MS = 10; // 10ms
|
||||||
static constexpr int cTIMEOUT_COUNT = 10;
|
static constexpr int cTIMEOUT_COUNT = 10;
|
||||||
|
|
||||||
//const unsigned int BATTERY = 0x010;
|
|
||||||
//const unsigned int MOTOR = 0x020;
|
|
||||||
const unsigned int BIB = 0x048;
|
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|||||||
188
bcguihelpers.cpp
Normal file
@@ -0,0 +1,188 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
|
||||||
|
BionxControl
|
||||||
|
© 2025 -2026 christoph holzheuer
|
||||||
|
christoph.holzheuer@gmail.com
|
||||||
|
|
||||||
|
Using:
|
||||||
|
|
||||||
|
mhs_can_drv.c
|
||||||
|
© 2011 - 2023 by MHS-Elektronik GmbH & Co. KG, Germany
|
||||||
|
Klaus Demlehner, klaus@mhs-elektronik.de
|
||||||
|
@see www.mhs-elektronik.de
|
||||||
|
|
||||||
|
Based on Bionx data type descriptions from:
|
||||||
|
|
||||||
|
BigXionFlasher USB V 0.2.4 rev. 97
|
||||||
|
© 2011-2013 by Thomas Koenig <info@bigxionflasher.org>
|
||||||
|
@see www.bigxionflasher.org
|
||||||
|
|
||||||
|
Bionx Bike Info
|
||||||
|
© 2018 Thorsten Schmidt (tschmidt@ts-soft.de)
|
||||||
|
@see www.ts-soft.de
|
||||||
|
|
||||||
|
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.
|
||||||
|
@see https://github.com/bikemike/bionx-bikeinfo
|
||||||
|
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#include <bcguihelpers.h>
|
||||||
|
|
||||||
|
BCThemeSwitchButton::BCThemeSwitchButton(QWidget *parent )
|
||||||
|
: QPushButton(parent), _isDarkMode(true)
|
||||||
|
{
|
||||||
|
// 1. Visuelles Setup: Flach, keine Ränder, Hand-Cursor
|
||||||
|
setFlat(true);
|
||||||
|
setCursor(Qt::PointingHandCursor);
|
||||||
|
setFixedSize(24, 24); // Kleiner Footprint im StatusBar
|
||||||
|
|
||||||
|
// CSS: Transparent, damit es sich nahtlos in den StatusBar einfügt
|
||||||
|
// Schriftgröße etwas erhöhen, damit die Emojis gut erkennbar sind
|
||||||
|
setStyleSheet(R"(
|
||||||
|
QPushButton {
|
||||||
|
border: none;
|
||||||
|
background-color: transparent;
|
||||||
|
font-size: 11pt;
|
||||||
|
}
|
||||||
|
QPushButton:hover {
|
||||||
|
background-color: rgba(128, 128, 128, 30); // Leichter Hover-Effekt
|
||||||
|
border-radius: 24px;
|
||||||
|
}
|
||||||
|
)");
|
||||||
|
|
||||||
|
// 2. Initialer Status (Startet im Dark Mode -> zeigt Mond)
|
||||||
|
updateIcon();
|
||||||
|
|
||||||
|
// 3. Klick verbinden
|
||||||
|
connect(this, &QPushButton::clicked, this, &BCThemeSwitchButton::toggle);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void BCThemeSwitchButton::toggle()
|
||||||
|
{
|
||||||
|
_isDarkMode = !_isDarkMode;
|
||||||
|
updateIcon();
|
||||||
|
emit themeChanged(_isDarkMode);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void BCThemeSwitchButton::updateIcon()
|
||||||
|
{
|
||||||
|
// Logik:
|
||||||
|
// Ist Dark Mode an? Zeige Mond (oder Sonne, je nach Geschmack).
|
||||||
|
// Hier: Zeige das Symbol des AKTUELLEN Modus.
|
||||||
|
setText(_isDarkMode ? "🌙" : "☀️");
|
||||||
|
setToolTip(_isDarkMode ? "Switch to Light Mode" : "Switch to Dark Mode");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// -----------------------------------------------------------------------------------
|
||||||
|
/// -----------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
BCDriverStateWidget::BCDriverStateWidget(QWidget* parent)
|
||||||
|
: QWidget(parent)
|
||||||
|
{
|
||||||
|
QHBoxLayout* layout = new QHBoxLayout(this);
|
||||||
|
layout->setContentsMargins(10, 2, 10, 2);
|
||||||
|
layout->setSpacing(8);
|
||||||
|
|
||||||
|
_label = new QLabel(this);
|
||||||
|
_label->setStyleSheet("font-weight: 500;"); // Medium weight
|
||||||
|
|
||||||
|
_led = new QLabel(this);
|
||||||
|
_led->setFixedSize(12, 12);
|
||||||
|
|
||||||
|
layout->addWidget(_label);
|
||||||
|
layout->addWidget(_led);
|
||||||
|
|
||||||
|
// Startzustand
|
||||||
|
onDriverStateChanged(BCDriver::DriverState::NotPresent, "Not Present");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
// Hauptfunktion zum Setzen des Status
|
||||||
|
// 'customMessage' ist optional. Wenn leer, wird ein Standardtext genommen.
|
||||||
|
void BCDriverStateWidget::onDriverStateChanged(BCDriver::DriverState state, const QString& customMessage)
|
||||||
|
{
|
||||||
|
_state = state;
|
||||||
|
qDebug() << " --- StateWidget: " << state << " - " << customMessage;
|
||||||
|
// Standard-Texte, falls keine Nachricht übergeben wurde
|
||||||
|
QString text = customMessage;
|
||||||
|
if (text.isEmpty())
|
||||||
|
{
|
||||||
|
switch (_state)
|
||||||
|
{
|
||||||
|
case BCDriver::DriverState::DeviceReady:
|
||||||
|
text = "Device Ready";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case BCDriver::DriverState::Error:
|
||||||
|
text = "Driver Error";
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
text = "Not Present";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
_label->setText(text);
|
||||||
|
|
||||||
|
updateStyle();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void BCDriverStateWidget::updateStyle()
|
||||||
|
{
|
||||||
|
QString ledStyle;
|
||||||
|
QString labelColor;
|
||||||
|
QString toolTipText;
|
||||||
|
|
||||||
|
switch (_state)
|
||||||
|
{
|
||||||
|
case BCDriver::DriverState::DeviceReady:
|
||||||
|
// FLUENT GREEN (Success)
|
||||||
|
ledStyle = "background-color: #107C10; border: 1px solid #0E600E;#FF5F1F; #FF8C00;<- das isses #FF6700";
|
||||||
|
labelColor = "#FFFFFF"; // Weiß (Hervorgehoben)
|
||||||
|
toolTipText = "Verbindung erfolgreich hergestellt.";
|
||||||
|
break;
|
||||||
|
|
||||||
|
case BCDriver::DriverState::Error:
|
||||||
|
// FLUENT RED (Critical)
|
||||||
|
ledStyle = "background-color: #C42B1C; border: 1px solid #A80000;";
|
||||||
|
labelColor = "#FF99A4"; // Ein helleres Rot für Text, damit es auf Dunkel lesbar ist
|
||||||
|
toolTipText = "Kritischer Fehler bei der Verbindung!";
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
// FLUENT GRAY (Neutral)
|
||||||
|
// Wir machen es dunkelgrau mit hellem Rand -> "Ausgeschaltet"-Look
|
||||||
|
ledStyle = "background-color: #3B3B3B; border: 1px solid #606060;";
|
||||||
|
labelColor = "#9E9E9E"; // Ausgegrauter Text
|
||||||
|
toolTipText = "System ist offline.";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Styles anwenden (immer rund machen)
|
||||||
|
_led->setStyleSheet(ledStyle + "border-radius: 6px;");
|
||||||
|
|
||||||
|
// Textfarbe setzen
|
||||||
|
_label->setStyleSheet(QString("color: %1; font-weight: %2;")
|
||||||
|
.arg(labelColor)
|
||||||
|
.arg(_state == BCDriver::DriverState::DeviceReady ? "bold" : "normal"));
|
||||||
|
|
||||||
|
setToolTip(toolTipText);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
97
bcguihelpers.h
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
|
||||||
|
BionxControl
|
||||||
|
© 2025 -2026 christoph holzheuer
|
||||||
|
christoph.holzheuer@gmail.com
|
||||||
|
|
||||||
|
Using:
|
||||||
|
|
||||||
|
mhs_can_drv.c
|
||||||
|
© 2011 - 2023 by MHS-Elektronik GmbH & Co. KG, Germany
|
||||||
|
Klaus Demlehner, klaus@mhs-elektronik.de
|
||||||
|
@see www.mhs-elektronik.de
|
||||||
|
|
||||||
|
Based on Bionx data type descriptions from:
|
||||||
|
|
||||||
|
BigXionFlasher USB V 0.2.4 rev. 97
|
||||||
|
© 2011-2013 by Thomas Koenig <info@bigxionflasher.org>
|
||||||
|
@see www.bigxionflasher.org
|
||||||
|
|
||||||
|
Bionx Bike Info
|
||||||
|
© 2018 Thorsten Schmidt (tschmidt@ts-soft.de)
|
||||||
|
@see www.ts-soft.de
|
||||||
|
|
||||||
|
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.
|
||||||
|
@see https://github.com/bikemike/bionx-bikeinfo
|
||||||
|
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
#ifndef BCGUIHELPERS_H
|
||||||
|
#define BCGUIHELPERS_H
|
||||||
|
|
||||||
|
#include <QPushButton>
|
||||||
|
#include <QLabel>
|
||||||
|
#include <QHBoxLayout>
|
||||||
|
|
||||||
|
#include <bcdriver.h>
|
||||||
|
|
||||||
|
|
||||||
|
class BCThemeSwitchButton : public QPushButton
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
explicit BCThemeSwitchButton(QWidget *parent = nullptr);
|
||||||
|
|
||||||
|
signals:
|
||||||
|
|
||||||
|
void themeChanged(bool isDark);
|
||||||
|
|
||||||
|
private slots:
|
||||||
|
|
||||||
|
void toggle();
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
void updateIcon();
|
||||||
|
|
||||||
|
bool _isDarkMode;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/// -----------------------------------------------------------------------------------
|
||||||
|
/// -----------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
class BCDriverStateWidget : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
explicit BCDriverStateWidget(QWidget *parent = nullptr);
|
||||||
|
|
||||||
|
public slots:
|
||||||
|
|
||||||
|
// Hauptfunktion zum Setzen des Status
|
||||||
|
// 'customMessage' ist optional. Wenn leer, wird ein Standardtext genommen.
|
||||||
|
void onDriverStateChanged(BCDriver::DriverState state, const QString& customMessage = QString());
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
void updateStyle();
|
||||||
|
|
||||||
|
QLabel* _led;
|
||||||
|
QLabel* _label;
|
||||||
|
BCDriver::DriverState _state;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // BCGUIHELPERS_H
|
||||||
@@ -204,7 +204,7 @@ void BCTransmitter::processValue()
|
|||||||
|
|
||||||
TransmitResult BCTransmitter::readByteValue( uint32_t deviceID, uint8_t registerID )
|
TransmitResult BCTransmitter::readByteValue( uint32_t deviceID, uint8_t registerID )
|
||||||
{
|
{
|
||||||
qDebug() << " --- YES: Read ByteValue: " << registerID;
|
//qDebug() << " --- YES: Read ByteValue: " << registerID;
|
||||||
// Wir lesen nur ein Byte und gut.
|
// Wir lesen nur ein Byte und gut.
|
||||||
return _canDriver->readRawByte( deviceID, registerID );
|
return _canDriver->readRawByte( deviceID, registerID );
|
||||||
}
|
}
|
||||||
@@ -212,7 +212,7 @@ TransmitResult BCTransmitter::readByteValue( uint32_t deviceID, uint8_t register
|
|||||||
|
|
||||||
TransmitResult BCTransmitter::readWordValue( uint32_t deviceID, uint8_t registerID )
|
TransmitResult BCTransmitter::readWordValue( uint32_t deviceID, uint8_t registerID )
|
||||||
{
|
{
|
||||||
qDebug() << " --- YES: Read WordValue: " << registerID;
|
//qDebug() << " --- YES: Read WordValue: " << registerID;
|
||||||
|
|
||||||
uint32_t result{};
|
uint32_t result{};
|
||||||
// hi byte Leseversuch.
|
// hi byte Leseversuch.
|
||||||
|
|||||||
@@ -88,9 +88,9 @@ void BCValueModel::onValueUpdated( int row, BCValue::State state, const QString&
|
|||||||
BCValue& value = *(_valueList[row].get());
|
BCValue& value = *(_valueList[row].get());
|
||||||
QModelIndex idx = index(row,1);
|
QModelIndex idx = index(row,1);
|
||||||
|
|
||||||
qDebug();
|
//qDebug();
|
||||||
qDebug() << " --- OLD:";
|
//qDebug() << " --- OLD:"<< newVisisbleValue;
|
||||||
value.dumpValue();
|
//value.dumpValue();
|
||||||
|
|
||||||
value.state = state;
|
value.state = state;
|
||||||
|
|
||||||
@@ -99,8 +99,8 @@ void BCValueModel::onValueUpdated( int row, BCValue::State state, const QString&
|
|||||||
value.visibleValue = newVisisbleValue;
|
value.visibleValue = newVisisbleValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
qDebug() << " NEW: " << newVisisbleValue << "";
|
//qDebug() << " --- NEW: " << newVisisbleValue;
|
||||||
value.dumpValue();
|
//value.dumpValue();
|
||||||
|
|
||||||
// wir schicken auf jeden fall einen update request
|
// wir schicken auf jeden fall einen update request
|
||||||
emit dataChanged(idx, idx, {Qt::DisplayRole, Qt::EditRole});
|
emit dataChanged(idx, idx, {Qt::DisplayRole, Qt::EditRole});
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 2.6 KiB |
|
Before Width: | Height: | Size: 2.9 KiB |
|
Before Width: | Height: | Size: 2.7 KiB |
|
Before Width: | Height: | Size: 3.0 KiB |
|
Before Width: | Height: | Size: 2.9 KiB |
|
Before Width: | Height: | Size: 3.2 KiB |
|
Before Width: | Height: | Size: 3.1 KiB |
|
Before Width: | Height: | Size: 2.9 KiB |
|
Before Width: | Height: | Size: 3.4 KiB |
|
Before Width: | Height: | Size: 2.7 KiB |
|
Before Width: | Height: | Size: 2.7 KiB |
|
Before Width: | Height: | Size: 2.8 KiB |
|
Before Width: | Height: | Size: 3.2 KiB |
|
Before Width: | Height: | Size: 3.2 KiB |
|
Before Width: | Height: | Size: 2.9 KiB |
|
Before Width: | Height: | Size: 3.3 KiB |
|
Before Width: | Height: | Size: 4.7 KiB |
|
Before Width: | Height: | Size: 4.6 KiB |
|
Before Width: | Height: | Size: 4.2 KiB |
|
Before Width: | Height: | Size: 4.6 KiB |
|
Before Width: | Height: | Size: 2.6 KiB |
|
Before Width: | Height: | Size: 3.2 KiB |
|
Before Width: | Height: | Size: 4.2 KiB |
BIN
resources/TinyCan_812.exe
Normal file
@@ -1,24 +1,17 @@
|
|||||||
<?xml version='1.0' encoding='UTF-8'?>
|
<?xml version='1.0' encoding='UTF-8'?>
|
||||||
|
|
||||||
<!--
|
|
||||||
QString ID;
|
|
||||||
QString Label;
|
|
||||||
QString UnitLabel;
|
|
||||||
QString Factor;
|
|
||||||
QString Min;
|
|
||||||
QString Max;
|
|
||||||
QString IsWord;
|
|
||||||
QString ValueType;
|
|
||||||
-->
|
|
||||||
<Bike name='franken-wheeler'>
|
<Bike name='franken-wheeler'>
|
||||||
|
|
||||||
<Device Type="Console">
|
<Device Type="Console">
|
||||||
<Value ID='Cons_Rev_Hw' Label='Hardware Version' />
|
<Value ID='Cons_Rev_Hw' Label='Hardware Version' />
|
||||||
<Value ID='Cons_Rev_Sw' Label='Software Version' />
|
<Value ID='Cons_Rev_Sw' Label='Software Version' />
|
||||||
<Value ID='Cons_Sn_Product_Hi' Label='Product Number' IsWord='1'/>
|
|
||||||
|
<Value ID='Cons_Sn_Product_Hi' Label='Product Number' IsWord='1'/>
|
||||||
<Value ID='Cons_Sn_Oem_Hi' Label='OEM Number' IsWord='1' />
|
<Value ID='Cons_Sn_Oem_Hi' Label='OEM Number' IsWord='1' />
|
||||||
|
|
||||||
<Value ID='Cons_Assist_Initlevel' Label='Assistance Init Level' Min='0' Max='4'/>
|
<Value ID='Cons_Assist_Initlevel' Label='Assistance Init Level' Min='0' Max='4'/>
|
||||||
|
|
||||||
|
|
||||||
<Value ID='Cons_Assist_Level_1' Label='Assistance Level 1' Factor='1.5625' UnitLabel='%' Min='0' Max='400' />
|
<Value ID='Cons_Assist_Level_1' Label='Assistance Level 1' Factor='1.5625' UnitLabel='%' Min='0' Max='400' />
|
||||||
<Value ID='Cons_Assist_Level_2' Label='Assistance Level 2' Factor='1.5625' UnitLabel='%' Min='0' Max='400' />
|
<Value ID='Cons_Assist_Level_2' Label='Assistance Level 2' Factor='1.5625' UnitLabel='%' Min='0' Max='400' />
|
||||||
<Value ID='Cons_Assist_Level_3' Label='Assistance Level 3' Factor='1.5625' UnitLabel='%' Min='0' Max='400' />
|
<Value ID='Cons_Assist_Level_3' Label='Assistance Level 3' Factor='1.5625' UnitLabel='%' Min='0' Max='400' />
|
||||||
@@ -37,6 +30,7 @@ QString ValueType;
|
|||||||
<Value ID='Cons_Assist_Mountain_Cap' Label='Mountain Cap' UnitLabel='%' Factor='1.5625' />
|
<Value ID='Cons_Assist_Mountain_Cap' Label='Mountain Cap' UnitLabel='%' Factor='1.5625' />
|
||||||
</Device>
|
</Device>
|
||||||
|
|
||||||
|
<!--
|
||||||
<Device Type="Motor">
|
<Device Type="Motor">
|
||||||
<Value ID='Motor_Rev_Hw' Label='Hardware Version' />
|
<Value ID='Motor_Rev_Hw' Label='Hardware Version' />
|
||||||
<Value ID='Motor_Rev_Sw' Label='Software Version' />
|
<Value ID='Motor_Rev_Sw' Label='Software Version' />
|
||||||
@@ -52,7 +46,7 @@ QString ValueType;
|
|||||||
<Value ID='Battery_Rev_Hw' Label='Hardware Version' />
|
<Value ID='Battery_Rev_Hw' Label='Hardware Version' />
|
||||||
<Value ID='Battery_Rev_Sw' Label='Software Version' />
|
<Value ID='Battery_Rev_Sw' Label='Software Version' />
|
||||||
</Device>
|
</Device>
|
||||||
|
-->
|
||||||
</Bike>
|
</Bike>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
|
|||||||