/*===================================================================== QGroundControl Open Source Ground Control Station (c) 2009, 2010 QGROUNDCONTROL PROJECT This file is part of the QGROUNDCONTROL project QGROUNDCONTROL 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. QGROUNDCONTROL 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 QGROUNDCONTROL. If not, see . ======================================================================*/ /** * @file * @brief Implementation of QGCRemoteControlView * @author Lorenz Meier * @author Bryan Godbolt */ #include #include #include #include #include #include #include "QGCRemoteControlView.h" #include "ui_QGCRemoteControlView.h" #include "UASManager.h" QGCRemoteControlView::QGCRemoteControlView(QWidget *parent) : QWidget(parent), uasId(-1), rssi(0.0f), updated(false), channelLayout(new QVBoxLayout())//, //ui(new Ui::QGCRemoteControlView) { ui->setupUi(this); QGridLayout* layout = new QGridLayout(this); layout->addLayout(channelLayout, 1, 0, 1, 2); nameLabel = new QLabel(this); layout->addWidget(nameLabel, 0, 0, 1, 2); this->setVisible(false); //setVisible(false); calibrate = new QPushButton(tr("Calibrate"), this); QHBoxLayout *calibrateButtonLayout = new QHBoxLayout(); calibrateButtonLayout->addWidget(calibrate, 0, Qt::AlignHCenter); layout->addItem(calibrateButtonLayout, 3, 0, 1, 2); calibrationWindow = new RadioCalibrationWindow(this); connect(calibrate, SIGNAL(clicked()), calibrationWindow, SLOT(show())); connect(UASManager::instance(), SIGNAL(activeUASSet(int)), this, SLOT(setUASId(int))); } QGCRemoteControlView::~QGCRemoteControlView() { delete ui; delete channelLayout; } void QGCRemoteControlView::setUASId(int id) { if (uasId != -1) { UASInterface* uas = UASManager::instance()->getUASForId(id); if (uas) { // The UAS exists, disconnect any existing connections disconnect(uas, SIGNAL(remoteControlChannelRawChanged(int,float,float)), this, SLOT(setChannel(int,float,float))); disconnect(uas, SIGNAL(remoteControlRSSIChanged(float)), this, SLOT(setRemoteRSSI(float))); disconnect(uas, SIGNAL(radioCalibrationRawReceived(const QPointer)), calibrationWindow, SLOT(receive(const QPointer&))); disconnect(uas, SIGNAL(remoteControlChannelRawChanged(int,float)), calibrationWindow, SLOT(setChannelRaw(int,float))); disconnect(uas, SIGNAL(remoteControlChannelScaledChanged(int,float,float)), calibrationWindow, SLOT(setChannelScaled(int,float))); } } // Connect the new UAS UASInterface* newUAS = UASManager::instance()->getUASForId(id); if (newUAS) { // New UAS exists, connect nameLabel->setText(QString("RC Input of %1").arg(newUAS->getUASName())); calibrationWindow->setUASId(id); connect(newUAS, SIGNAL(radioCalibrationReceived(const QPointer&)), calibrationWindow, SLOT(receive(const QPointer&))); connect(newUAS, SIGNAL(remoteControlRSSIChanged(float)), this, SLOT(setRemoteRSSI(float))); connect(newUAS, SIGNAL(remoteControlChannelRawChanged(int,float)), this, SLOT(setChannelRaw(int,float))); connect(newUAS, SIGNAL(remoteControlChannelScaledChanged(int,float)), this, SLOT(setChannelScaled(int,float))); } } void QGCRemoteControlView::setChannelRaw(int channelId, float raw) { if (this->raw.size() <= channelId) { // This is a new channel, append it this->raw.append(raw); //this->normalized.append(0); appendChannelWidget(channelId); } else { // This is an existing channel, aupdate it this->raw[channelId] = raw; } updated = true; // FIXME Will be timer based in the future redraw(); } //void QGCRemoteControlView::setChannelScaled(int channelId, float normalized) //{ // if (this->raw.size() <= channelId) // using raw vector as size indicator // { // // This is a new channel, append it // this->normalized.append(normalized); // this->raw.append(0); // appendChannelWidget(channelId); // } // else // { // // This is an existing channel, update it // this->normalized[channelId] = normalized; // } // updated = true; // // FIXME Will be timer based in the future // redraw(); //} void QGCRemoteControlView::setRemoteRSSI(float rssiNormalized) { rssi = rssiNormalized; updated = true; } void QGCRemoteControlView::appendChannelWidget(int channelId) { // Create new layout QHBoxLayout* layout = new QHBoxLayout(); // Add content layout->addWidget(new QLabel(QString("Channel %1").arg(channelId + 1), this)); QLabel* raw = new QLabel(this); // Append raw label rawLabels.append(raw); layout->addWidget(raw); // Append progress bar QProgressBar* normalized = new QProgressBar(this); normalized->setMinimum(-100); normalized->setMaximum(100); normalized->setFormat("%v%"); progressBars.append(normalized); layout->addWidget(normalized); channelLayout->addLayout(layout); } void QGCRemoteControlView::redraw() { if(isVisible() && updated) { // Update raw values //for(int i = 0; i < rawLabels.count(); i++) //{ //rawLabels.at(i)->setText(QString("%1 us").arg(raw.at(i), 4, 10, QChar('0'))); //} // Update percent bars for(int i = 0; i < progressBars.count(); i++) { rawLabels.at(i)->setText(QString("%1 us").arg(raw.at(i), 4, 10, QChar('0'))); //int vv = normalized.at(i)*100.0f; //progressBars.at(i)->setValue(vv); int vv = raw.at(i)*1.0f; progressBars.at(i)->setValue(vv); } // Update RSSI if(rssi>0) { //rssiBar->setValue(rssi);//*100); } updated = false; } } void QGCRemoteControlView::changeEvent(QEvent *e) { Q_UNUSED(e); // FIXME If the lines below are commented in // runtime errors can occur on x64 systems. // QWidget::changeEvent(e); // switch (e->type()) { // case QEvent::LanguageChange: // //ui->retranslateUi(this); // break; // default: // break; // } }