mirror of
https://bitbucket.org/librepilot/librepilot.git
synced 2025-01-18 03:52:11 +01:00
Merge branch 'ConfigHardware' into MikeL_MixerCurve
This commit is contained in:
commit
584d173de6
@ -41,8 +41,30 @@ ConfigCCHWWidget::ConfigCCHWWidget(QWidget *parent) : ConfigTaskWidget(parent)
|
||||
m_telemetry = new Ui_CC_HW_Widget();
|
||||
m_telemetry->setupUi(this);
|
||||
|
||||
m_telemetry->label_2->setPixmap(QPixmap(":/configgadget/images/coptercontrol.svg"));
|
||||
ExtensionSystem::PluginManager *pm = ExtensionSystem::PluginManager::instance();
|
||||
UAVObjectUtilManager* utilMngr = pm->getObject<UAVObjectUtilManager>();
|
||||
int id = utilMngr->getBoardModel();
|
||||
|
||||
switch (id) {
|
||||
case 0x0101:
|
||||
m_telemetry->label_2->setPixmap(QPixmap(":/uploader/images/deviceID-0101.svg"));
|
||||
break;
|
||||
case 0x0301:
|
||||
m_telemetry->label_2->setPixmap(QPixmap(":/uploader/images/deviceID-0301.svg"));
|
||||
break;
|
||||
case 0x0401:
|
||||
m_telemetry->label_2->setPixmap(QPixmap(":/uploader/images/deviceID-0401.svg"));
|
||||
break;
|
||||
case 0x0402:
|
||||
m_telemetry->label_2->setPixmap(QPixmap(":/uploader/images/deviceID-0402.svg"));
|
||||
break;
|
||||
case 0x0201:
|
||||
m_telemetry->label_2->setPixmap(QPixmap(":/uploader/images/deviceID-0201.svg"));
|
||||
break;
|
||||
default:
|
||||
m_telemetry->label_2->setPixmap(QPixmap(":/configgadget/images/coptercontrol.svg"));
|
||||
break;
|
||||
}
|
||||
addApplySaveButtons(m_telemetry->saveTelemetryToRAM,m_telemetry->saveTelemetryToSD);
|
||||
addUAVObjectToWidgetRelation("HwSettings","CC_FlexiPort",m_telemetry->cbFlexi);
|
||||
addUAVObjectToWidgetRelation("HwSettings","CC_MainPort",m_telemetry->cbTele);
|
||||
|
@ -389,7 +389,7 @@ void Telemetry::processObjectQueue()
|
||||
if ( ( objInfo.event != EV_UNPACKED ) && ( ( objInfo.event != EV_UPDATED_PERIODIC ) || ( updateMode != UAVObject::UPDATEMODE_THROTTLED ) ) )
|
||||
{
|
||||
UAVObject::Metadata metadata = objInfo.obj->getMetadata();
|
||||
ObjectTransactionInfo *transInfo = new ObjectTransactionInfo();
|
||||
ObjectTransactionInfo *transInfo = new ObjectTransactionInfo(this);
|
||||
transInfo->obj = objInfo.obj;
|
||||
transInfo->allInstances = objInfo.allInstances;
|
||||
transInfo->retriesRemaining = MAX_RETRIES;
|
||||
@ -402,9 +402,9 @@ void Telemetry::processObjectQueue()
|
||||
{
|
||||
transInfo->objRequest = true;
|
||||
}
|
||||
transInfo->telem = this;
|
||||
// Insert the transaction into the transaction map.
|
||||
transMap.insert(objInfo.obj->getObjID(), transInfo);
|
||||
transInfo->telem = this;
|
||||
// Insert the transaction into the transaction map.
|
||||
transMap.insert(objInfo.obj->getObjID(), transInfo);
|
||||
processObjectTransaction(transInfo);
|
||||
}
|
||||
|
||||
@ -559,7 +559,7 @@ void Telemetry::newInstance(UAVObject* obj)
|
||||
registerObject(obj);
|
||||
}
|
||||
|
||||
ObjectTransactionInfo::ObjectTransactionInfo()
|
||||
ObjectTransactionInfo::ObjectTransactionInfo(QObject* parent):QObject(parent)
|
||||
{
|
||||
obj = 0;
|
||||
allInstances = false;
|
||||
@ -582,6 +582,6 @@ ObjectTransactionInfo::~ObjectTransactionInfo()
|
||||
|
||||
void ObjectTransactionInfo::timeout()
|
||||
{
|
||||
if (telem)
|
||||
if (!telem.isNull())
|
||||
telem->transactionTimeout(this);
|
||||
}
|
||||
|
@ -41,14 +41,14 @@ class ObjectTransactionInfo: public QObject {
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
ObjectTransactionInfo();
|
||||
ObjectTransactionInfo(QObject * parent);
|
||||
~ObjectTransactionInfo();
|
||||
UAVObject* obj;
|
||||
bool allInstances;
|
||||
bool objRequest;
|
||||
qint32 retriesRemaining;
|
||||
bool acked;
|
||||
class Telemetry* telem;
|
||||
QPointer<class Telemetry>telem;
|
||||
QTimer* timer;
|
||||
private slots:
|
||||
void timeout();
|
||||
|
@ -159,6 +159,8 @@ void UAVTalk::cancelTransaction(UAVObject* obj)
|
||||
{
|
||||
QMutexLocker locker(mutex);
|
||||
quint32 objId = obj->getObjID();
|
||||
if(io.isNull())
|
||||
return;
|
||||
QMap<quint32, Transaction*>::iterator itr = transMap.find(objId);
|
||||
if ( itr != transMap.end() )
|
||||
{
|
||||
@ -827,7 +829,7 @@ bool UAVTalk::transmitSingleObject(UAVObject* obj, quint8 type, bool allInstance
|
||||
txBuffer[dataOffset+length] = updateCRC(0, txBuffer, dataOffset + length);
|
||||
|
||||
// Send buffer, check that the transmit backlog does not grow above limit
|
||||
if (io && io->isWritable() && io->bytesToWrite() < TX_BUFFER_SIZE )
|
||||
if (!io.isNull() && io->isWritable() && io->bytesToWrite() < TX_BUFFER_SIZE )
|
||||
{
|
||||
io->write((const char*)txBuffer, dataOffset+length+CHECKSUM_LENGTH);
|
||||
}
|
||||
|
@ -94,6 +94,9 @@ void runningDeviceWidget::populate()
|
||||
case 0x0401:
|
||||
devicePic->renderer()->load(QString(":/uploader/images/deviceID-0401.svg"));
|
||||
break;
|
||||
case 0x0402:
|
||||
devicePic->renderer()->load(QString(":/uploader/images/deviceID-0402.svg"));
|
||||
break;
|
||||
case 0x0201:
|
||||
devicePic->renderer()->load(QString(":/uploader/images/deviceID-0201.svg"));
|
||||
break;
|
||||
|
Loading…
x
Reference in New Issue
Block a user