refs #911, allow to set model dir relative to simulator directory

* utility functions in simulator info
* and fscommonutil
* and button in UI to set default
This commit is contained in:
Klaus Basan
2017-03-22 03:10:04 +01:00
committed by Mathew Sutcliffe
parent e8eb652cfd
commit b0fe4ce930
7 changed files with 102 additions and 41 deletions

View File

@@ -15,6 +15,7 @@
using namespace BlackMisc;
using namespace BlackMisc::Simulation;
using namespace BlackMisc::Simulation::FsCommon;
using namespace BlackConfig;
namespace BlackGui
@@ -35,6 +36,7 @@ namespace BlackGui
connect(ui->pb_Save, &QPushButton::clicked, this, &CSettingsSimulatorBasicsComponent::save);
connect(ui->pb_Reset, &QPushButton::clicked, this, &CSettingsSimulatorBasicsComponent::ps_reset);
connect(ui->pb_CopyDefaults, &QPushButton::clicked, this, &CSettingsSimulatorBasicsComponent::ps_copyDefaults);
connect(ui->pb_AdjustModelDirectory, &QPushButton::clicked, this, &CSettingsSimulatorBasicsComponent::ps_adjustModelDirectory);
connect(ui->le_SimulatorDirectory, &QLineEdit::returnPressed, this, &CSettingsSimulatorBasicsComponent::ps_simulatorDirectoryEntered);
connect(ui->comp_SimulatorSelector, &CSimulatorSelector::changed, this, &CSettingsSimulatorBasicsComponent::ps_simulatorChanged);
@@ -131,6 +133,25 @@ namespace BlackGui
this->displayExcludeDirectoryPatterns(excludes);
}
void CSettingsSimulatorBasicsComponent::ps_adjustModelDirectory()
{
const CSimulatorInfo simulator(ui->comp_SimulatorSelector->getValue());
QString simDir = this->getFileBrowserSimulatorDirectory();
if (simulator.isFsxFamily())
{
simDir = CFsCommonUtil::fsxSimObjectsDirFromSimDir(simDir);
}
else if (simulator.fs9())
{
simDir = CFsCommonUtil::fs9AircraftDirFromSimDir(simDir);
}
//! \todo counterpart function for XP
const QStringList newDirs = this->addDirectory(simDir, this->parseDirectories(ui->pte_ModelDirectories->toPlainText()));
this->displayModelDirectories(newDirs);
}
void CSettingsSimulatorBasicsComponent::ps_reset()
{
const CSimulatorInfo simulator(ui->comp_SimulatorSelector->getValue());
@@ -182,13 +203,19 @@ namespace BlackGui
void CSettingsSimulatorBasicsComponent::displayExcludeDirectoryPatterns(const QStringList &dirs)
{
const QString d = dirs.join("\n");
QStringList cleanedDirs(dirs);
cleanedDirs.removeDuplicates();
cleanedDirs.sort(this->m_fileCaseSensitivity);
const QString d = cleanedDirs.join("\n");
ui->pte_ExcludeDirectories->setPlainText(d);
}
void CSettingsSimulatorBasicsComponent::displayModelDirectories(const QStringList &dirs)
{
const QString d = dirs.join("\n");
QStringList cleanedDirs(dirs);
cleanedDirs.removeDuplicates();
cleanedDirs.sort(this->m_fileCaseSensitivity);
const QString d = cleanedDirs.join("\n");
ui->pte_ModelDirectories->setPlainText(d);
}

View File

@@ -13,6 +13,7 @@
#define BLACKGUI_COMPONENTS_SETTINGSSIMULATORBASICSCOMPONENT_H
#include "blackmisc/simulation/simulatorsettings.h"
#include "blackmisc/simulation/fscommon/fscommonutil.h"
#include <QFrame>
#include <QFileDialog>
@@ -51,6 +52,7 @@ namespace BlackGui
void ps_simulatorFileDialog();
void ps_simulatorDirectoryEntered();
void ps_copyDefaults();
void ps_adjustModelDirectory();
void ps_reset();
void ps_simulatorChanged();

View File

@@ -20,7 +20,14 @@
<enum>QFrame::Raised</enum>
</property>
<layout class="QGridLayout" name="gridLayout">
<item row="5" column="4">
<item row="1" column="4" alignment="Qt::AlignTop">
<widget class="QPushButton" name="pb_ModelFileDialog">
<property name="text">
<string>...</string>
</property>
</widget>
</item>
<item row="7" column="4">
<widget class="QPushButton" name="pb_CopyDefaults">
<property name="toolTip">
<string>copy (materialize) defaults</string>
@@ -37,10 +44,10 @@
</property>
</widget>
</item>
<item row="1" column="4" alignment="Qt::AlignTop">
<widget class="QPushButton" name="pb_ModelFileDialog">
<item row="0" column="0">
<widget class="QLabel" name="lbl_SimulatorDirectory">
<property name="text">
<string>...</string>
<string>Simulator directory:</string>
</property>
</widget>
</item>
@@ -51,35 +58,35 @@
</property>
</widget>
</item>
<item row="4" column="4">
<item row="6" column="4">
<widget class="QPushButton" name="pb_Reset">
<property name="text">
<string>reset</string>
</property>
</widget>
</item>
<item row="0" column="0">
<widget class="QLabel" name="lbl_SimulatorDirectory">
<property name="text">
<string>Simulator directory:</string>
<item row="0" column="2">
<widget class="QLineEdit" name="le_SimulatorDirectory">
<property name="placeholderText">
<string>Simulator directory path</string>
</property>
</widget>
</item>
<item row="6" column="4">
<widget class="QPushButton" name="pb_Save">
<property name="text">
<string>save</string>
</property>
</widget>
</item>
<item row="3" column="4" alignment="Qt::AlignTop">
<item row="5" column="4" alignment="Qt::AlignTop">
<widget class="QPushButton" name="pb_ExcludeFileDialog">
<property name="text">
<string>...</string>
</property>
</widget>
</item>
<item row="3" column="2" rowspan="4">
<item row="8" column="4">
<widget class="QPushButton" name="pb_Save">
<property name="text">
<string>save</string>
</property>
</widget>
</item>
<item row="5" column="2" rowspan="4">
<widget class="QPlainTextEdit" name="pte_ExcludeDirectories">
<property name="documentTitle">
<string>Excluded directory patterns</string>
@@ -92,21 +99,24 @@
</property>
</widget>
</item>
<item row="0" column="2">
<widget class="QLineEdit" name="le_SimulatorDirectory">
<property name="placeholderText">
<string>Simulator directory path</string>
<item row="5" column="0" rowspan="4" alignment="Qt::AlignTop">
<widget class="QLabel" name="lbl_ExcludeDirectories">
<property name="toolTip">
<string>Excluded from model loading</string>
</property>
<property name="text">
<string>Exclude directory patterns:</string>
</property>
</widget>
</item>
<item row="1" column="2">
<item row="1" column="2" rowspan="3">
<widget class="QPlainTextEdit" name="pte_ModelDirectories">
<property name="placeholderText">
<string>Model directories</string>
</property>
</widget>
</item>
<item row="7" column="0" colspan="4" alignment="Qt::AlignRight">
<item row="9" column="0" colspan="4" alignment="Qt::AlignRight">
<widget class="BlackGui::Components::CSimulatorSelector" name="comp_SimulatorSelector">
<property name="minimumSize">
<size>
@@ -119,13 +129,10 @@
</property>
</widget>
</item>
<item row="3" column="0" rowspan="4" alignment="Qt::AlignTop">
<widget class="QLabel" name="lbl_ExcludeDirectories">
<property name="toolTip">
<string>Excluded from model loading</string>
</property>
<item row="3" column="4">
<widget class="QPushButton" name="pb_AdjustModelDirectory">
<property name="text">
<string>Exclude directory patterns:</string>
<string>adjust</string>
</property>
</widget>
</item>