/*************************************************************************** BionxControl Copyright © 2025 christoph holzheuer christoph.holzheuer@gmail.com Using: BigXionFlasher USB V 0.2.4 rev. 97 © 2011-2013 by Thomas Koenig @see www.bigxionflasher.org Bionx Bike Info © 2018 Thorsten Schmidt (tschmidt@ts-soft.de) @see www.ts-soft.de mhs_can_drv.c 3.00 © 2011 - 2015 by MHS-Elektronik GmbH & Co. KG, Germany Demlehner Klaus, info@mhs-elektronik.de @see www.mhs-elektronik.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 BCVALUE_H #define BCVALUE_H #include #include #include #include #include /* Werte haben verschiedene Längen (1,2 und 4 Byte) und werder auf unterschiedliche Art und Weise ausgelesen und geschrieben (Siehe ODO). Sin können also Wert-Typen zugeordnet werden. Ein Werttyp lässet über eine ID identifizieren, die mit der phyikalische Einheit des Wertes überschneiden kann, aber nicht muss: : Km/h, kWh, ODO ... bilden eigene Typen, SoC, Assistence Level sind auch eigene Typen, Teilen sich jedoch die Einheit '%'. Das ist natürlich annalog zu den ItemTypes: - ein Value hat einen ValueType, der bestimmt folgendes: - long or short or quad - unit (mm, km/h, odo ... ) - */ using optDouble = std::optional; struct BCValueType { Q_GADGET public: enum class TypeID : uint8_t { Invalid = 0x0, Text, Number, Float, Percent, KWh, Watt, Km, Kmh, Mm, Sec, SoC, Odo, Assist, AssistFac, Date }; Q_ENUM(TypeID) BCValueType( TypeID ID_, QString unitLabel_="", optDouble factor_=std::nullopt, optDouble min_=std::nullopt, optDouble max_= std::nullopt ); TypeID ID; QString unitLabel; optDouble factor; optDouble min; optDouble max; }; class BCValue { public: BCValue() = default; BCValue( BCDevice::ID deviceID, BC::ID targetID ); void setLongValue( uint8_t value); uint8_t getLongValue(); BCDevice::ID deviceID{BCDevice::ID::Invalid}; BC::ID targetID{BC::ID::Invalid}; BCValueType::TypeID typeID{BCValueType::TypeID::Invalid};; QString label; QVariant value; QVariant defaultValue; bool inSync{false}; bool readOnly{false}; }; // Damit QVariant dieses Struct transportieren kann: Q_DECLARE_METATYPE(BCValue) struct BCValueParams { QString ID; QString Label; QString Default; QString Current; QString Enabled; QString UnitType; QString Min; QString Max; QString Factor; }; // abbreviations: // SOC = State Of Charge // LMD = Last Measured Discharge // NIP = ? /* Needed ? #include template constexpr auto to_u(E e) noexcept { return static_cast>(e); } */ using BCValueList = QVector; #endif // BCVALUE_H