1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-19 04:52:12 +01:00

OP-39 Added condition for multirotor type. If PWM input option is enable only up to Hex is selectable, otherwise Octo is selectable to.

Added initial configuration code that applies the users choices in the UAVOs.
Changed order of pages so that Input page comes before vehicle page.
This commit is contained in:
Fredrik Arvidsson 2012-08-15 01:04:54 +02:00
parent 25d13e4c35
commit 2b541219bf
6 changed files with 264 additions and 9 deletions

View File

@ -35,6 +35,7 @@ FlashPage::FlashPage(SetupWizard *wizard, QWidget *parent) :
ui(new Ui::FlashPage) ui(new Ui::FlashPage)
{ {
ui->setupUi(this); ui->setupUi(this);
connect(ui->applyButton, SIGNAL(clicked()), wizard, SLOT(writeConfiguration()));
} }
FlashPage::~FlashPage() FlashPage::~FlashPage()

View File

@ -45,9 +45,9 @@ p, li { white-space: pre-wrap; }
<property name="geometry"> <property name="geometry">
<rect> <rect>
<x>20</x> <x>20</x>
<y>240</y> <y>230</y>
<width>561</width> <width>561</width>
<height>141</height> <height>151</height>
</rect> </rect>
</property> </property>
<property name="sizePolicy"> <property name="sizePolicy">
@ -62,6 +62,19 @@ p, li { white-space: pre-wrap; }
<property name="alignment"> <property name="alignment">
<set>Qt::AlignLeading|Qt::AlignLeft|Qt::AlignVCenter</set> <set>Qt::AlignLeading|Qt::AlignLeft|Qt::AlignVCenter</set>
</property> </property>
<widget class="QPushButton" name="applyButton">
<property name="geometry">
<rect>
<x>440</x>
<y>30</y>
<width>100</width>
<height>100</height>
</rect>
</property>
<property name="text">
<string>Apply</string>
</property>
</widget>
</widget> </widget>
</widget> </widget>
<resources/> <resources/>

View File

@ -57,16 +57,23 @@ MultiPage::~MultiPage()
void MultiPage::initializePage() void MultiPage::initializePage()
{ {
updateAvailableTypes();
updateImageAndDescription(); updateImageAndDescription();
} }
bool MultiPage::validatePage()
{
SetupWizard::VEHICLE_SUB_TYPE type = (SetupWizard::VEHICLE_SUB_TYPE) ui->typeCombo->itemData(ui->typeCombo->currentIndex()).toInt();
getWizard()->setVehicleSubType(type);
}
void MultiPage::setupMultiTypesCombo() void MultiPage::setupMultiTypesCombo()
{ {
ui->typeCombo->addItem("Tricopter", SetupWizard::MULTI_ROTOR_TRI_Y); ui->typeCombo->addItem("Tricopter", SetupWizard::MULTI_ROTOR_TRI_Y);
ui->typeCombo->addItem("Quadcopter X", SetupWizard::MULTI_ROTOR_QUAD_X); ui->typeCombo->addItem("Quadcopter X", SetupWizard::MULTI_ROTOR_QUAD_X);
ui->typeCombo->addItem("Quadcopter +", SetupWizard::MULTI_ROTOR_QUAD_PLUS); ui->typeCombo->addItem("Quadcopter +", SetupWizard::MULTI_ROTOR_QUAD_PLUS);
ui->typeCombo->addItem("Hexacopter", SetupWizard::MULTI_ROTOR_HEXA); ui->typeCombo->addItem("Hexacopter", SetupWizard::MULTI_ROTOR_HEXA);
ui->typeCombo->addItem("Hexacopter Coax", SetupWizard::MULTI_ROTOR_HEXA_COAX_Y); ui->typeCombo->addItem("Hexacopter Coax (Y6)", SetupWizard::MULTI_ROTOR_HEXA_COAX_Y);
ui->typeCombo->addItem("Hexacopter H", SetupWizard::MULTI_ROTOR_HEXA_H); ui->typeCombo->addItem("Hexacopter H", SetupWizard::MULTI_ROTOR_HEXA_H);
ui->typeCombo->addItem("Octocopter", SetupWizard::MULTI_ROTOR_OCTO); ui->typeCombo->addItem("Octocopter", SetupWizard::MULTI_ROTOR_OCTO);
ui->typeCombo->addItem("Octocopter Coax X", SetupWizard::MULTI_ROTOR_OCTO_COAX_X); ui->typeCombo->addItem("Octocopter Coax X", SetupWizard::MULTI_ROTOR_OCTO_COAX_X);
@ -74,9 +81,18 @@ void MultiPage::setupMultiTypesCombo()
ui->typeCombo->addItem("Octocopter V", SetupWizard::MULTI_ROTOR_OCTO_V); ui->typeCombo->addItem("Octocopter V", SetupWizard::MULTI_ROTOR_OCTO_V);
} }
void MultiPage::updateAvailableTypes()
{
QVariant enable = (getWizard()->getInputType() == SetupWizard::INPUT_PWM) ? QVariant(0) : QVariant(1 | 32);
ui->typeCombo->model()->setData(ui->typeCombo->model()->index(6, 0), enable, Qt::UserRole - 1);
ui->typeCombo->model()->setData(ui->typeCombo->model()->index(7, 0), enable, Qt::UserRole - 1);
ui->typeCombo->model()->setData(ui->typeCombo->model()->index(8, 0), enable, Qt::UserRole - 1);
ui->typeCombo->model()->setData(ui->typeCombo->model()->index(9, 0), enable, Qt::UserRole - 1);
}
void MultiPage::updateImageAndDescription() void MultiPage::updateImageAndDescription()
{ {
SetupWizard::MULTI_ROTOR_SUB_TYPE type = (SetupWizard::MULTI_ROTOR_SUB_TYPE) ui->typeCombo->itemData(ui->typeCombo->currentIndex()).toInt(); SetupWizard::VEHICLE_SUB_TYPE type = (SetupWizard::VEHICLE_SUB_TYPE) ui->typeCombo->itemData(ui->typeCombo->currentIndex()).toInt();
QString elementId = ""; QString elementId = "";
QString description = "Descriptive text with information about "; QString description = "Descriptive text with information about ";
description.append(ui->typeCombo->currentText()); description.append(ui->typeCombo->currentText());

View File

@ -46,11 +46,14 @@ public:
~MultiPage(); ~MultiPage();
void initializePage(); void initializePage();
bool validatePage();
private: private:
Ui::MultiPage *ui; Ui::MultiPage *ui;
void setupMultiTypesCombo(); void setupMultiTypesCombo();
QGraphicsSvgItem *multiPic; QGraphicsSvgItem *multiPic;
void updateAvailableTypes();
private slots: private slots:
void updateImageAndDescription(); void updateImageAndDescription();

View File

@ -40,6 +40,11 @@
#include "pages/summarypage.h" #include "pages/summarypage.h"
#include "pages/flashpage.h" #include "pages/flashpage.h"
#include "pages/notyetimplementedpage.h" #include "pages/notyetimplementedpage.h"
#include "extensionsystem/pluginmanager.h"
#include "hwsettings.h"
#include "actuatorsettings.h"
#include "attitudesettings.h"
SetupWizard::SetupWizard(QWidget *parent) : QWizard(parent), SetupWizard::SetupWizard(QWidget *parent) : QWizard(parent),
m_controllerSelectionMode(CONTROLLER_SELECTION_UNKNOWN), m_controllerType(CONTROLLER_UNKNOWN), m_controllerSelectionMode(CONTROLLER_SELECTION_UNKNOWN), m_controllerType(CONTROLLER_UNKNOWN),
@ -47,6 +52,7 @@ SetupWizard::SetupWizard(QWidget *parent) : QWizard(parent),
m_levellingPerformed(false), m_connectionManager(0) m_levellingPerformed(false), m_connectionManager(0)
{ {
setWindowTitle("OpenPilot Setup Wizard"); setWindowTitle("OpenPilot Setup Wizard");
setOption(QWizard::IndependentPages, false);
createPages(); createPages();
} }
@ -60,7 +66,7 @@ int SetupWizard::nextId() const
{ {
case CONTROLLER_CC: case CONTROLLER_CC:
case CONTROLLER_CC3D: case CONTROLLER_CC3D:
return PAGE_VEHICLES; return PAGE_INPUT;
case CONTROLLER_REVO: case CONTROLLER_REVO:
case CONTROLLER_PIPX: case CONTROLLER_PIPX:
default: default:
@ -83,9 +89,9 @@ int SetupWizard::nextId() const
} }
} }
case PAGE_MULTI: case PAGE_MULTI:
return PAGE_INPUT;
case PAGE_INPUT:
return PAGE_OUTPUT; return PAGE_OUTPUT;
case PAGE_INPUT:
return PAGE_VEHICLES;
case PAGE_OUTPUT: case PAGE_OUTPUT:
{ {
if(getControllerSelectionMode() == CONTROLLER_SELECTION_AUTOMATIC) { if(getControllerSelectionMode() == CONTROLLER_SELECTION_AUTOMATIC) {
@ -196,6 +202,197 @@ QString SetupWizard::getSummaryText()
return summary; return summary;
} }
void SetupWizard::applyConfiguration()
{
UAVObjectManager* uavoMgr = getUAVObjectManager();
applyHardwareConfiguration(uavoMgr);
applyVehicleConfiguration(uavoMgr);
applyOutputConfiguration(uavoMgr);
applyLevellingConfiguration(uavoMgr);
}
UAVObjectManager* SetupWizard::getUAVObjectManager()
{
ExtensionSystem::PluginManager *pm = ExtensionSystem::PluginManager::instance();
UAVObjectManager * uavObjectManager = pm->getObject<UAVObjectManager>();
Q_ASSERT(uavObjectManager);
return uavObjectManager;
}
void SetupWizard::applyHardwareConfiguration(UAVObjectManager* uavoMgr)
{
HwSettings* hwSettings = HwSettings::GetInstance(uavoMgr);
switch(getControllerType())
{
case CONTROLLER_CC:
case CONTROLLER_CC3D:
// Reset all ports
hwSettings->setCC_RcvrPort(HwSettings::CC_RCVRPORT_DISABLED);
hwSettings->setCC_FlexiPort(HwSettings::CC_FLEXIPORT_DISABLED);
hwSettings->setCC_MainPort(HwSettings::CC_MAINPORT_DISABLED);
switch(getInputType())
{
case INPUT_PWM:
hwSettings->setCC_RcvrPort(HwSettings::CC_RCVRPORT_PWM);
break;
case INPUT_PPM:
hwSettings->setCC_RcvrPort(HwSettings::CC_RCVRPORT_PPM);
break;
case INPUT_SBUS:
hwSettings->setCC_MainPort(HwSettings::CC_MAINPORT_SBUS);
break;
case INPUT_DSM:
// TODO: Handle all of the DSM types ?? Which is most common?
hwSettings->setCC_MainPort(HwSettings::CC_MAINPORT_DSM2);
break;
}
break;
case CONTROLLER_REVO:
// TODO: Implement Revo settings
break;
}
}
void SetupWizard::applyVehicleConfiguration(UAVObjectManager *uavoMgr)
{
switch(getVehicleType())
{
case VEHICLE_MULTI:
{
switch(getVehicleSubType())
{
case SetupWizard::MULTI_ROTOR_TRI_Y:
setupTriCopter(uavoMgr);
break;
case SetupWizard::MULTI_ROTOR_QUAD_X:
case SetupWizard::MULTI_ROTOR_QUAD_PLUS:
setupQuadCopter(uavoMgr);
break;
case SetupWizard::MULTI_ROTOR_HEXA:
case SetupWizard::MULTI_ROTOR_HEXA_COAX_Y:
case SetupWizard::MULTI_ROTOR_HEXA_H:
setupHexaCopter(uavoMgr);
break;
case SetupWizard::MULTI_ROTOR_OCTO:
case SetupWizard::MULTI_ROTOR_OCTO_COAX_X:
case SetupWizard::MULTI_ROTOR_OCTO_COAX_PLUS:
case SetupWizard::MULTI_ROTOR_OCTO_V:
setupOctoCopter(uavoMgr);
break;
}
break;
}
case VEHICLE_FIXEDWING:
case VEHICLE_HELI:
case VEHICLE_SURFACE:
// TODO: Implement settings for other vehicle types?
break;
}
}
void SetupWizard::applyOutputConfiguration(UAVObjectManager *uavoMgr)
{
ActuatorSettings* actSettings = ActuatorSettings::GetInstance(uavoMgr);
switch(getVehicleType())
{
case VEHICLE_MULTI:
{
actSettings->setChannelUpdateFreq(0, DEFAULT_ESC_FREQUENCE);
actSettings->setChannelUpdateFreq(1, DEFAULT_ESC_FREQUENCE);
actSettings->setChannelUpdateFreq(2, DEFAULT_ESC_FREQUENCE);
actSettings->setChannelUpdateFreq(3, DEFAULT_ESC_FREQUENCE);
qint16 updateFrequence = DEFAULT_ESC_FREQUENCE;
switch(getESCType())
{
case ESC_DEFAULT:
updateFrequence = DEFAULT_ESC_FREQUENCE;
break;
case ESC_RAPID:
updateFrequence = RAPID_ESC_FREQUENCE;
break;
}
switch(getVehicleSubType())
{
case SetupWizard::MULTI_ROTOR_TRI_Y:
actSettings->setChannelUpdateFreq(0, updateFrequence);
break;
case SetupWizard::MULTI_ROTOR_QUAD_X:
case SetupWizard::MULTI_ROTOR_QUAD_PLUS:
actSettings->setChannelUpdateFreq(0, updateFrequence);
actSettings->setChannelUpdateFreq(1, updateFrequence);
break;
case SetupWizard::MULTI_ROTOR_HEXA:
case SetupWizard::MULTI_ROTOR_HEXA_COAX_Y:
case SetupWizard::MULTI_ROTOR_HEXA_H:
case SetupWizard::MULTI_ROTOR_OCTO:
case SetupWizard::MULTI_ROTOR_OCTO_COAX_X:
case SetupWizard::MULTI_ROTOR_OCTO_COAX_PLUS:
case SetupWizard::MULTI_ROTOR_OCTO_V:
actSettings->setChannelUpdateFreq(0, updateFrequence);
actSettings->setChannelUpdateFreq(1, updateFrequence);
actSettings->setChannelUpdateFreq(2, updateFrequence);
actSettings->setChannelUpdateFreq(3, updateFrequence);
break;
}
break;
}
case VEHICLE_FIXEDWING:
case VEHICLE_HELI:
case VEHICLE_SURFACE:
// TODO: Implement settings for other vehicle types?
break;
}
}
void SetupWizard::applyLevellingConfiguration(UAVObjectManager *uavoMgr)
{
if(isLevellingPerformed())
{
accelGyroBias bias = getLevellingBias();
AttitudeSettings::DataFields attitudeSettingsData = AttitudeSettings::GetInstance(uavoMgr)->getData();
attitudeSettingsData.AccelBias[0] += bias.m_accelerometerXBias;
attitudeSettingsData.AccelBias[1] += bias.m_accelerometerYBias;
attitudeSettingsData.AccelBias[2] += bias.m_accelerometerZBias;
attitudeSettingsData.GyroBias[0] = -bias.m_gyroXBias;
attitudeSettingsData.GyroBias[1] = -bias.m_gyroYBias;
attitudeSettingsData.GyroBias[2] = -bias.m_gyroZBias;
AttitudeSettings::GetInstance(uavoMgr)->setData(attitudeSettingsData);
}
}
void SetupWizard::setupTriCopter(UAVObjectManager *uavoMgr)
{
}
void SetupWizard::setupQuadCopter(UAVObjectManager *uavoMgr)
{
}
void SetupWizard::setupHexaCopter(UAVObjectManager *uavoMgr)
{
}
void SetupWizard::setupOctoCopter(UAVObjectManager *uavoMgr)
{
}
void SetupWizard::exportConfiguration()
{
applyConfiguration();
// Call export configuration function...
}
void SetupWizard::writeConfiguration()
{
applyConfiguration();
// Call Save UAVOs to controller
}
void SetupWizard::createPages() void SetupWizard::createPages()
{ {
setPage(PAGE_START, new StartPage(this)); setPage(PAGE_START, new StartPage(this));

View File

@ -32,6 +32,8 @@
#include "levellingutil.h" #include "levellingutil.h"
#include <coreplugin/icore.h> #include <coreplugin/icore.h>
#include <coreplugin/connectionmanager.h> #include <coreplugin/connectionmanager.h>
#include "uavobjectmanager.h"
class SetupWizard : public QWizard class SetupWizard : public QWizard
{ {
@ -43,9 +45,10 @@ public:
enum CONTROLLER_SELECTION_MODE {CONTROLLER_SELECTION_AUTOMATIC, CONTROLLER_SELECTION_MANUAL, CONTROLLER_SELECTION_UNKNOWN}; enum CONTROLLER_SELECTION_MODE {CONTROLLER_SELECTION_AUTOMATIC, CONTROLLER_SELECTION_MANUAL, CONTROLLER_SELECTION_UNKNOWN};
enum CONTROLLER_TYPE {CONTROLLER_UNKNOWN, CONTROLLER_CC, CONTROLLER_CC3D, CONTROLLER_REVO, CONTROLLER_PIPX}; enum CONTROLLER_TYPE {CONTROLLER_UNKNOWN, CONTROLLER_CC, CONTROLLER_CC3D, CONTROLLER_REVO, CONTROLLER_PIPX};
enum VEHICLE_TYPE {VEHICLE_UNKNOWN, VEHICLE_MULTI, VEHICLE_FIXEDWING, VEHICLE_HELI, VEHICLE_SURFACE}; enum VEHICLE_TYPE {VEHICLE_UNKNOWN, VEHICLE_MULTI, VEHICLE_FIXEDWING, VEHICLE_HELI, VEHICLE_SURFACE};
enum MULTI_ROTOR_SUB_TYPE {MULTI_ROTOR_UNKNOWN, MULTI_ROTOR_TRI_Y, MULTI_ROTOR_QUAD_X, MULTI_ROTOR_QUAD_PLUS, enum VEHICLE_SUB_TYPE {MULTI_ROTOR_UNKNOWN, MULTI_ROTOR_TRI_Y, MULTI_ROTOR_QUAD_X, MULTI_ROTOR_QUAD_PLUS,
MULTI_ROTOR_HEXA, MULTI_ROTOR_HEXA_H, MULTI_ROTOR_HEXA_COAX_Y, MULTI_ROTOR_OCTO, MULTI_ROTOR_HEXA, MULTI_ROTOR_HEXA_H, MULTI_ROTOR_HEXA_COAX_Y, MULTI_ROTOR_OCTO,
MULTI_ROTOR_OCTO_V, MULTI_ROTOR_OCTO_COAX_X, MULTI_ROTOR_OCTO_COAX_PLUS}; MULTI_ROTOR_OCTO_V, MULTI_ROTOR_OCTO_COAX_X, MULTI_ROTOR_OCTO_COAX_PLUS, FIXED_WING_AILERON,
FIXED_WING_VTAIL, HELI_CCPM};
enum ESC_TYPE {ESC_DEFAULT, ESC_RAPID, ESC_UNKNOWN}; enum ESC_TYPE {ESC_DEFAULT, ESC_RAPID, ESC_UNKNOWN};
enum INPUT_TYPE {INPUT_PWM, INPUT_PPM, INPUT_SBUS, INPUT_DSM, INPUT_UNKNOWN}; enum INPUT_TYPE {INPUT_PWM, INPUT_PPM, INPUT_SBUS, INPUT_DSM, INPUT_UNKNOWN};
@ -58,6 +61,9 @@ public:
void setVehicleType(SetupWizard::VEHICLE_TYPE type) { m_vehicleType = type; } void setVehicleType(SetupWizard::VEHICLE_TYPE type) { m_vehicleType = type; }
SetupWizard::VEHICLE_TYPE getVehicleType() const { return m_vehicleType; } SetupWizard::VEHICLE_TYPE getVehicleType() const { return m_vehicleType; }
void setVehicleSubType(SetupWizard::VEHICLE_SUB_TYPE type) { m_vehicleSubType = type; }
SetupWizard::VEHICLE_SUB_TYPE getVehicleSubType() const { return m_vehicleSubType; }
void setInputType(SetupWizard::INPUT_TYPE type) { m_inputType = type; } void setInputType(SetupWizard::INPUT_TYPE type) { m_inputType = type; }
SetupWizard::INPUT_TYPE getInputType() const { return m_inputType; } SetupWizard::INPUT_TYPE getInputType() const { return m_inputType; }
@ -78,8 +84,14 @@ public:
} }
return m_connectionManager; return m_connectionManager;
} }
public slots:
void exportConfiguration();
void writeConfiguration();
private: private:
static const qint16 DEFAULT_ESC_FREQUENCE = 50;
static const qint16 RAPID_ESC_FREQUENCE = 50;
enum {PAGE_START, PAGE_CONTROLLER, PAGE_VEHICLES, PAGE_MULTI, PAGE_FIXEDWING, enum {PAGE_START, PAGE_CONTROLLER, PAGE_VEHICLES, PAGE_MULTI, PAGE_FIXEDWING,
PAGE_HELI, PAGE_SURFACE, PAGE_INPUT, PAGE_OUTPUT, PAGE_LEVELLING, PAGE_HELI, PAGE_SURFACE, PAGE_INPUT, PAGE_OUTPUT, PAGE_LEVELLING,
PAGE_FLASH, PAGE_SUMMARY, PAGE_NOTYETIMPLEMENTED, PAGE_END}; PAGE_FLASH, PAGE_SUMMARY, PAGE_NOTYETIMPLEMENTED, PAGE_END};
@ -88,6 +100,7 @@ private:
CONTROLLER_SELECTION_MODE m_controllerSelectionMode; CONTROLLER_SELECTION_MODE m_controllerSelectionMode;
CONTROLLER_TYPE m_controllerType; CONTROLLER_TYPE m_controllerType;
VEHICLE_TYPE m_vehicleType; VEHICLE_TYPE m_vehicleType;
VEHICLE_SUB_TYPE m_vehicleSubType;
INPUT_TYPE m_inputType; INPUT_TYPE m_inputType;
ESC_TYPE m_escType; ESC_TYPE m_escType;
bool m_levellingPerformed; bool m_levellingPerformed;
@ -95,6 +108,18 @@ private:
Core::ConnectionManager *m_connectionManager; Core::ConnectionManager *m_connectionManager;
UAVObjectManager *getUAVObjectManager();
void applyConfiguration();
void applyHardwareConfiguration(UAVObjectManager *uavoMgr);
void applyVehicleConfiguration(UAVObjectManager *uavoMgr);
void applyOutputConfiguration(UAVObjectManager *uavoMgr);
void applyLevellingConfiguration(UAVObjectManager *uavoMgr);
void setupTriCopter(UAVObjectManager *uavoMgr);
void setupQuadCopter(UAVObjectManager *uavoMgr);
void setupHexaCopter(UAVObjectManager *uavoMgr);
void setupOctoCopter(UAVObjectManager *uavoMgr);
}; };
#endif // SETUPWIZARD_H #endif // SETUPWIZARD_H