2025-12-26 23:10:53 +01:00
|
|
|
/***************************************************************************
|
|
|
|
|
|
|
|
|
|
BionxControl
|
2026-01-03 23:51:14 +01:00
|
|
|
© 2025 -2026 christoph holzheuer
|
2025-12-26 23:10:53 +01:00
|
|
|
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
|
|
|
|
|
|
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
|
|
|
2026-01-06 13:58:02 +01:00
|
|
|
#include <QHeaderView>
|
|
|
|
|
|
2025-12-29 23:29:56 +01:00
|
|
|
#include <bcdeviceview.h>
|
|
|
|
|
#include <bcanimateddelegate.h>
|
2025-12-26 23:10:53 +01:00
|
|
|
|
2025-12-29 23:29:56 +01:00
|
|
|
BCDeviceView::BCDeviceView(QWidget *parent)
|
|
|
|
|
: QTableView(parent)
|
2025-12-26 23:10:53 +01:00
|
|
|
{
|
2025-12-29 23:29:56 +01:00
|
|
|
|
|
|
|
|
setModel( &_valueModel );
|
|
|
|
|
//resizeColumnsToContents();
|
|
|
|
|
//horizontalHeader()->setSectionResizeMode(QHeaderView::ResizeToContents);
|
2025-12-29 15:44:06 +01:00
|
|
|
|
2025-12-29 20:10:05 +01:00
|
|
|
// __fix! ziemlich wildes ge-pointere, hier
|
2025-12-29 23:29:56 +01:00
|
|
|
_itemDelegate = new BCAnimatedDelegate( _valueModel.getValueList(), this);
|
|
|
|
|
setItemDelegate( _itemDelegate );
|
2025-12-26 23:10:53 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-12-29 23:29:56 +01:00
|
|
|
void BCDeviceView::setDeviceID( BCDevice::ID deviceID )
|
2025-12-27 19:49:41 +01:00
|
|
|
{
|
2026-01-06 13:58:02 +01:00
|
|
|
_devideID = deviceID;
|
2025-12-27 19:49:41 +01:00
|
|
|
}
|
2025-12-29 00:04:15 +01:00
|
|
|
|
2025-12-29 23:29:56 +01:00
|
|
|
BCDevice::ID BCDeviceView::getDeviceID() const
|
2025-12-27 19:49:41 +01:00
|
|
|
{
|
|
|
|
|
return _devideID;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2026-01-06 13:58:02 +01:00
|
|
|
/**
|
|
|
|
|
* @brief Gibt eine Referenz auf der ValueList zurück.
|
|
|
|
|
*/
|
2025-12-29 23:29:56 +01:00
|
|
|
|
|
|
|
|
const BCValueList& BCDeviceView::getValueListX()
|
2025-12-28 14:42:12 +01:00
|
|
|
{
|
|
|
|
|
return _valueModel.getValueList();
|
|
|
|
|
}
|
|
|
|
|
|
2025-12-31 13:38:46 +01:00
|
|
|
|
2026-01-08 14:55:47 +01:00
|
|
|
/**
|
|
|
|
|
* @brief Flag, ob diese View schonmal angezeigt wurde.
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
bool BCDeviceView::firstExpose()
|
|
|
|
|
{
|
|
|
|
|
bool stored = _firstExpose;
|
|
|
|
|
_firstExpose = false;
|
|
|
|
|
return stored;
|
|
|
|
|
}
|
|
|
|
|
|
2026-01-06 13:58:02 +01:00
|
|
|
/**
|
|
|
|
|
* @brief SLOT, der aufgerufen wird, wenn die ValueList vom XML-Lader fertig geladen wurde.
|
|
|
|
|
* Die DeviceView nimmt die ValueList dann in Besitz.
|
|
|
|
|
*/
|
2025-12-29 23:29:56 +01:00
|
|
|
void BCDeviceView::onValueListReady( BCDevice::ID deviceID, BCValueList valueList )
|
2025-12-27 18:43:15 +01:00
|
|
|
{
|
2025-12-27 19:49:41 +01:00
|
|
|
if(_devideID == deviceID)
|
2025-12-28 14:42:12 +01:00
|
|
|
_valueModel.takeValueList( valueList );
|
2025-12-26 23:10:53 +01:00
|
|
|
}
|
|
|
|
|
|
2026-01-06 13:58:02 +01:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief SLOT, der aufgerufen wird, wenn ein Value geändert wurde. Gibt dem ItemDelegate Bescheid.
|
|
|
|
|
*/
|
|
|
|
|
|
2026-01-08 20:47:05 +01:00
|
|
|
void BCDeviceView::updateValue(int index,BCValue::Flags newState, uint32_t rawValue )
|
2026-01-03 23:51:14 +01:00
|
|
|
{
|
2026-01-08 20:47:05 +01:00
|
|
|
_valueModel.updateValue( index, newState, rawValue );
|
2025-12-29 20:10:05 +01:00
|
|
|
_itemDelegate->onHighlightRow( index );
|
|
|
|
|
}
|
2025-12-28 22:48:18 +01:00
|
|
|
|
2026-01-08 14:55:47 +01:00
|
|
|
/**
|
|
|
|
|
* @brief Die Spalte mit dem Label soll immer bei 60% der Gesamtbreite liegen.
|
|
|
|
|
* @param event
|
|
|
|
|
*/
|
2025-12-28 22:48:18 +01:00
|
|
|
|
2026-01-06 13:58:02 +01:00
|
|
|
void BCDeviceView::resizeEvent(QResizeEvent *event)
|
|
|
|
|
{
|
|
|
|
|
// Zuerst die Basisklasse aufrufen (Wichtig für Layouts!)
|
|
|
|
|
QWidget::resizeEvent(event);
|
|
|
|
|
|
|
|
|
|
// Berechnung: 40% der aktuellen Breite
|
|
|
|
|
// Tipp: viewport()->width() ist genauer als width(), da es Scrollbars rausrechnet!
|
|
|
|
|
int totalWidth = viewport()->width();
|
|
|
|
|
int col0Width = static_cast<int>(totalWidth * 0.60);
|
|
|
|
|
|
|
|
|
|
// Setzen der Breite
|
|
|
|
|
horizontalHeader()->resizeSection(0, col0Width);
|
|
|
|
|
}
|