/** ****************************************************************************** * * @file mixercurve.cpp * @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010. * @addtogroup GCSPlugins GCS Plugins * @{ * @addtogroup ConfigPlugin Config Plugin * @{ * @brief A MixerCurve Gadget used to update settings in the firmware *****************************************************************************/ /* * 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. * * This program 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 this program; if not, write to the Free Software Foundation, Inc., * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include #include "mixercurve.h" #include "doublespindelegate.h" MixerCurve::MixerCurve(QWidget *parent) : QFrame(parent), m_mixerUI(new Ui::MixerCurve), m_curveType(MixerCurve::MIXERCURVE_THROTTLE) { m_mixerUI->setupUi(this); m_curve = m_mixerUI->CurveWidget; m_settings = m_mixerUI->CurveSettings; DoubleSpinDelegate *sbd = new DoubleSpinDelegate(); for (int i=0; isetItemDelegateForRow(i, sbd); } UpdateCurveUI(); connect(m_mixerUI->CurveType, SIGNAL(currentIndexChanged(int)), this, SLOT(CurveTypeChanged())); connect(m_mixerUI->ResetCurve, SIGNAL(clicked()), this, SLOT(ResetCurve())); connect(m_mixerUI->GenerateCurve, SIGNAL(clicked()), this, SLOT(GenerateCurve())); connect(m_curve, SIGNAL(curveUpdated()), this, SLOT(UpdateSettingsTable())); connect(m_settings, SIGNAL(itemChanged(QTableWidgetItem*)), this, SLOT(SettingsTableChanged())); connect(m_mixerUI->CurveMin, SIGNAL(valueChanged(double)), this, SLOT(CurveMinChanged(double))); connect(m_mixerUI->CurveMax, SIGNAL(valueChanged(double)), this, SLOT(CurveMaxChanged(double))); connect(m_mixerUI->CurveStep, SIGNAL(valueChanged(double)), this, SLOT(GenerateCurve())); } MixerCurve::~MixerCurve() { delete m_mixerUI; } void MixerCurve::setMixerType(MixerCurveType curveType) { m_curveType = curveType; m_mixerUI->CurveGroup->setTitle( (m_curveType == MixerCurve::MIXERCURVE_THROTTLE) ? "Throttle Curve" : "Pitch Curve"); } void MixerCurve::ResetCurve() { m_mixerUI->CurveMin->setValue(m_curve->getMin()); m_mixerUI->CurveMax->setValue(m_curve->getMax()); m_mixerUI->CurveType->setCurrentIndex(m_mixerUI->CurveType->findText("Linear")); initLinearCurve(MixerCurveWidget::NODE_NUMELEM, m_curve->getMax(), m_curve->getMin()); UpdateSettingsTable(); } void MixerCurve::UpdateCurveUI() { //get the user settings QString curveType = m_mixerUI->CurveType->currentText(); switch (m_curveType) { case MixerCurve::MIXERCURVE_THROTTLE: { m_mixerUI->CurveMin->setMinimum(0.0); m_mixerUI->CurveMax->setMinimum(0.0); break; } case MixerCurve::MIXERCURVE_PITCH: { m_mixerUI->CurveMin->setMinimum(-1.0); m_mixerUI->CurveMax->setMinimum(-1.0); break; } } m_mixerUI->CurveMin->setMaximum(m_curve->getMax()); m_mixerUI->CurveMax->setMaximum(m_curve->getMax()); m_mixerUI->CurveStep->setMinimum(0.0); m_mixerUI->CurveStep->setMaximum(100.0); //set default visible m_mixerUI->minLabel->setText("Min"); m_mixerUI->minLabel->setVisible(true); m_mixerUI->CurveMin->setVisible(true); m_mixerUI->maxLabel->setVisible(false); m_mixerUI->CurveMax->setVisible(false); m_mixerUI->stepLabel->setVisible(false); m_mixerUI->CurveStep->setVisible(false); if ( curveType.compare("Flat")==0) { m_mixerUI->minLabel->setText("Value"); } if ( curveType.compare("Linear")==0) { m_mixerUI->maxLabel->setVisible(true); m_mixerUI->CurveMax->setVisible(true); } if ( curveType.compare("Step")==0) { m_mixerUI->maxLabel->setVisible(true); m_mixerUI->CurveMax->setVisible(true); m_mixerUI->stepLabel->setText("Step at"); m_mixerUI->stepLabel->setVisible(true); m_mixerUI->CurveStep->setVisible(true); } if ( curveType.compare("Exp")==0) { m_mixerUI->maxLabel->setVisible(true); m_mixerUI->CurveMax->setVisible(true); m_mixerUI->stepLabel->setText("Strength"); m_mixerUI->stepLabel->setVisible(true); m_mixerUI->CurveStep->setVisible(true); m_mixerUI->CurveStep->setMinimum(1.0); } if ( curveType.compare("Log")==0) { m_mixerUI->maxLabel->setVisible(true); m_mixerUI->CurveMax->setVisible(true); m_mixerUI->stepLabel->setText("Strength"); m_mixerUI->stepLabel->setVisible(true); m_mixerUI->CurveStep->setVisible(true); m_mixerUI->CurveStep->setMinimum(1.0); } GenerateCurve(); } void MixerCurve::GenerateCurve() { double scale; double newValue; //get the user settings double value1 = getCurveMin(); double value2 = getCurveMax(); double value3 = getCurveStep(); QString CurveType = m_mixerUI->CurveType->currentText(); QList points; for (int i=0; i* points) { m_curve->setCurve(points); UpdateSettingsTable(); } QList MixerCurve::getCurve() { return m_curve->getCurve(); } void MixerCurve::initLinearCurve(int numPoints, double maxValue, double minValue) { setMin(minValue); setMax(maxValue); m_curve->initLinearCurve(numPoints, maxValue, minValue); } void MixerCurve::setCurve(const QList* points) { m_curve->setCurve(points); UpdateSettingsTable(); } void MixerCurve::setMin(double value) { m_curve->setMin(value); m_mixerUI->CurveMin->setMinimum(value); } double MixerCurve::getMin() { return m_curve->getMin(); } void MixerCurve::setMax(double value) { m_curve->setMax(value); m_mixerUI->CurveMax->setMaximum(value); } double MixerCurve::getMax() { return m_curve->getMax(); } double MixerCurve::setRange(double min, double max) { return m_curve->setRange(min, max); } double MixerCurve::getCurveMin() { return m_mixerUI->CurveMin->value(); } double MixerCurve::getCurveMax() { return m_mixerUI->CurveMax->value(); } double MixerCurve::getCurveStep() { return m_mixerUI->CurveStep->value(); } void MixerCurve::UpdateSettingsTable() { QList points = m_curve->getCurve(); int ptCnt = points.count(); for (int i=0; iitem(i, 0); if (item) item->setText(QString().sprintf("%.2f",points.at( (ptCnt - 1) - i ))); } } void MixerCurve::SettingsTableChanged() { QList points; for (int i=0; i < m_settings->rowCount(); i++) { QTableWidgetItem* item = m_settings->item(i, 0); if (item) points.push_front(item->text().toDouble()); } m_curve->setCurve(&points); } void MixerCurve::CurveTypeChanged() { // setup the ui for this curvetype UpdateCurveUI(); // and generate a curve based on the selection GenerateCurve(); } void MixerCurve::CurveMinChanged(double value) { // the min changed so redraw the curve // mixercurvewidget::setCurve will trim any points below min QList points = m_curve->getCurve(); points.removeFirst(); points.push_front(value); setCurve(&points); } void MixerCurve::CurveMaxChanged(double value) { // the max changed so redraw the curve // mixercurvewidget::setCurve will trim any points above max QList points = m_curve->getCurve(); points.removeLast(); points.append(value); setCurve(&points); } void MixerCurve::showEvent(QShowEvent *event) { Q_UNUSED(event); m_curve->showEvent(event); } void MixerCurve::resizeEvent(QResizeEvent* event) { Q_UNUSED(event); m_curve->resizeEvent(event); }