Lat-lon position support
This commit is contained in:
parent
adedf7af65
commit
2b18479859
3 changed files with 61 additions and 12 deletions
|
@ -37,6 +37,7 @@
|
|||
#include <Navaids/navrecord.hxx>
|
||||
#include <Main/options.hxx>
|
||||
#include <Main/fg_init.hxx>
|
||||
#include <Main/fg_props.hxx> // for fgSetDouble
|
||||
|
||||
const int MAX_RECENT_AIRPORTS = 32;
|
||||
|
||||
|
@ -106,6 +107,25 @@ QString formatGeodAsString(const SGGeod& geod)
|
|||
QString::number(fabs(geod.getLatitudeDeg()), 'f',2 ) + ns;
|
||||
}
|
||||
|
||||
bool parseStringAsGeod(const QString& s, SGGeod& result)
|
||||
{
|
||||
int commaPos = s.indexOf(QChar(','));
|
||||
if (commaPos < 0)
|
||||
return false;
|
||||
|
||||
bool ok;
|
||||
double lon = s.leftRef(commaPos).toDouble(&ok);
|
||||
if (!ok)
|
||||
return false;
|
||||
|
||||
double lat = s.midRef(commaPos+1).toDouble(&ok);
|
||||
if (!ok)
|
||||
return false;
|
||||
|
||||
result = SGGeod::fromDeg(lon, lat);
|
||||
return true;
|
||||
}
|
||||
|
||||
class IdentSearchFilter : public FGPositioned::TypeFilter
|
||||
{
|
||||
public:
|
||||
|
@ -354,6 +374,16 @@ void LocationWidget::setLocationOptions()
|
|||
{
|
||||
flightgear::Options* opt = flightgear::Options::sharedInstance();
|
||||
|
||||
if (m_locationIsLatLon) {
|
||||
// bypass the options mechanism because converting to deg:min:sec notation
|
||||
// just to parse back again is nasty.
|
||||
fgSetDouble("/sim/presets/latitude-deg", m_geodLocation.getLatitudeDeg());
|
||||
fgSetDouble("/position/latitude-deg", m_geodLocation.getLatitudeDeg());
|
||||
fgSetDouble("/sim/presets/longitude-deg", m_geodLocation.getLongitudeDeg());
|
||||
fgSetDouble("/position/longitude-deg", m_geodLocation.getLongitudeDeg());
|
||||
return;
|
||||
}
|
||||
|
||||
if (!m_location) {
|
||||
return;
|
||||
}
|
||||
|
@ -401,6 +431,17 @@ void LocationWidget::setLocationOptions()
|
|||
void LocationWidget::onSearch()
|
||||
{
|
||||
QString search = m_ui->locationSearchEdit->text();
|
||||
|
||||
m_locationIsLatLon = parseStringAsGeod(search, m_geodLocation);
|
||||
if (m_locationIsLatLon) {
|
||||
m_ui->searchIcon->setVisible(false);
|
||||
m_ui->searchStatusText->setText(QString("Position '%1'").arg(formatGeodAsString(m_geodLocation)));
|
||||
m_location.clear();
|
||||
onLocationChanged();
|
||||
updateDescription();
|
||||
return;
|
||||
}
|
||||
|
||||
m_searchModel->setSearch(search);
|
||||
|
||||
if (m_searchModel->isSearchActive()) {
|
||||
|
@ -468,8 +509,10 @@ void LocationWidget::onLocationChanged()
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
} else {// of location is airport
|
||||
} else if (m_locationIsLatLon) {
|
||||
m_ui->stack->setCurrentIndex(1);
|
||||
m_ui->navaidDiagram->setGeod(m_geodLocation);
|
||||
} else {
|
||||
// navaid
|
||||
m_ui->stack->setCurrentIndex(1);
|
||||
m_ui->navaidDiagram->setNavaid(m_location);
|
||||
|
@ -478,7 +521,7 @@ void LocationWidget::onLocationChanged()
|
|||
|
||||
void LocationWidget::onOffsetEnabledToggled(bool on)
|
||||
{
|
||||
m_ui->offsetDistanceLabel->setEnabled(on);
|
||||
m_ui->navaidDiagram->setOffsetEnabled(on);
|
||||
}
|
||||
|
||||
void LocationWidget::onAirportDiagramClicked(FGRunwayRef rwy)
|
||||
|
@ -495,8 +538,13 @@ void LocationWidget::onAirportDiagramClicked(FGRunwayRef rwy)
|
|||
|
||||
QString LocationWidget::locationDescription() const
|
||||
{
|
||||
if (!m_location)
|
||||
if (!m_location) {
|
||||
if (m_locationIsLatLon) {
|
||||
return QString("at position %1").arg(formatGeodAsString(m_geodLocation));
|
||||
}
|
||||
|
||||
return QString("No location selected");
|
||||
}
|
||||
|
||||
bool locIsAirport = FGAirport::isAirportType(m_location.ptr());
|
||||
QString ident = QString::fromStdString(m_location->ident()),
|
||||
|
@ -505,7 +553,7 @@ QString LocationWidget::locationDescription() const
|
|||
name = fixNavaidName(name);
|
||||
|
||||
if (locIsAirport) {
|
||||
FGAirport* apt = static_cast<FGAirport*>(m_location.ptr());
|
||||
//FGAirport* apt = static_cast<FGAirport*>(m_location.ptr());
|
||||
QString locationOnAirport;
|
||||
|
||||
if (m_ui->runwayRadio->isChecked()) {
|
||||
|
@ -543,7 +591,7 @@ QString LocationWidget::locationDescription() const
|
|||
return QString("at %1 %2 (%3)").arg(navaidType).arg(ident).arg(name);
|
||||
}
|
||||
|
||||
return QString("Implement Me");
|
||||
return QString("No location selected");
|
||||
}
|
||||
|
||||
|
||||
|
@ -589,7 +637,6 @@ void LocationWidget::updateDescription()
|
|||
|
||||
void LocationWidget::onSearchResultSelected(const QModelIndex& index)
|
||||
{
|
||||
qDebug() << "selected result:" << index.data();
|
||||
setBaseLocation(m_searchModel->itemAtRow(index.row()));
|
||||
}
|
||||
|
||||
|
@ -656,7 +703,9 @@ void LocationWidget::setBaseLocation(FGPositionedRef ref)
|
|||
|
||||
void LocationWidget::onOffsetDataChanged()
|
||||
{
|
||||
qDebug() << "implement me";
|
||||
m_ui->navaidDiagram->setOffsetEnabled(m_ui->offsetGroup->isChecked());
|
||||
m_ui->navaidDiagram->setOffsetBearingDeg(m_ui->offsetBearingSpinbox->value());
|
||||
m_ui->navaidDiagram->setOffsetDistanceNm(m_ui->offsetNmSpinbox->value());
|
||||
}
|
||||
|
||||
void LocationWidget::onBackToSearch()
|
||||
|
|
|
@ -79,6 +79,9 @@ private:
|
|||
NavSearchModel* m_searchModel;
|
||||
|
||||
FGPositionedRef m_location;
|
||||
bool m_locationIsLatLon;
|
||||
SGGeod m_geodLocation;
|
||||
|
||||
QVector<PositionedID> m_recentAirports;
|
||||
|
||||
QToolButton* m_backButton;
|
||||
|
|
|
@ -231,9 +231,6 @@
|
|||
</property>
|
||||
<item>
|
||||
<widget class="QLabel" name="offsetBearingLabel">
|
||||
<property name="enabled">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
<property name="text">
|
||||
<string>Bearing:</string>
|
||||
</property>
|
||||
|
|
Loading…
Add table
Reference in a new issue