Skip to content

Commit

Permalink
Cleanup GPS fix status handling, remove duplicate code
Browse files Browse the repository at this point in the history
  • Loading branch information
nyalldawson committed Nov 4, 2022
1 parent a9a57a6 commit 06ef6e1
Show file tree
Hide file tree
Showing 3 changed files with 4 additions and 12 deletions.
3 changes: 3 additions & 0 deletions src/app/gps/qgsappgpsconnection.h
Expand Up @@ -136,11 +136,14 @@ class APP_EXPORT QgsAppGpsConnection : public QObject

void onConnected( QgsGpsConnection *conn );

void onDeviceStateChanged( const QgsGpsInformation &info );

private:

void showStatusBarMessage( const QString &msg );

QgsGpsConnection *mConnection = nullptr;
Qgis::GpsFixStatus mLastFixStatus = Qgis::GpsFixStatus::NoData;
};


Expand Down
12 changes: 1 addition & 11 deletions src/app/gps/qgsgpsinformationwidget.cpp
Expand Up @@ -358,6 +358,7 @@ QgsGpsInformationWidget::QgsGpsInformationWidget( QgsAppGpsConnection *connectio
connect( mConnection, &QgsAppGpsConnection::connected, this, &QgsGpsInformationWidget::gpsConnected );
connect( mConnection, &QgsAppGpsConnection::disconnected, this, &QgsGpsInformationWidget::gpsDisconnected );
connect( mConnection, &QgsAppGpsConnection::stateChanged, this, &QgsGpsInformationWidget::displayGPSInformation );
connect( mConnection, &QgsAppGpsConnection::fixStatusChanged, this, &QgsGpsInformationWidget::setStatusIndicator );

connect( mConnection, &QgsAppGpsConnection::statusChanged, this, [ = ]( Qgis::GpsConnectionStatus status )
{
Expand Down Expand Up @@ -664,8 +665,6 @@ void QgsGpsInformationWidget::gpsDisconnected()
mMapBearingItem = nullptr;
}
mGPSPlainTextEdit->appendPlainText( tr( "Disconnected…" ) );

setStatusIndicator( Qgis::GpsFixStatus::NoData );
}

void QgsGpsInformationWidget::displayGPSInformation( const QgsGpsInformation &info )
Expand All @@ -675,14 +674,6 @@ void QgsGpsInformationWidget::displayGPSInformation( const QgsGpsInformation &in

QVector<QPointF> data;

// set visual status indicator -- do only on change of state
Qgis::GnssConstellation constellation = Qgis::GnssConstellation::Unknown;
const Qgis::GpsFixStatus fixStatus = info.bestFixStatus( constellation );
if ( fixStatus != mLastFixStatus )
{
setStatusIndicator( fixStatus );
}

if ( mStackedWidget->currentIndex() == 1 && info.satInfoComplete ) //signal
{
mPlot->setAxisScale( QwtPlot::xBottom, 0, info.satellitesInView.size() );
Expand Down Expand Up @@ -1369,7 +1360,6 @@ void QgsGpsInformationWidget::layerEditStateChanged()

void QgsGpsInformationWidget::setStatusIndicator( Qgis::GpsFixStatus statusValue )
{
mLastFixStatus = statusValue;
// the pixmap will be expanded to the size of the label
QPixmap status( 4, 4 );
switch ( statusValue )
Expand Down
1 change: 0 additions & 1 deletion src/app/gps/qgsgpsinformationwidget.h
Expand Up @@ -142,7 +142,6 @@ class APP_EXPORT QgsGpsInformationWidget: public QgsPanelWidget, public QgsMapCa
QgsPointXY mSecondLastGpsPosition;
QVector<QgsPoint> mCaptureList;
double mLastElevation = 0.0;
Qgis::GpsFixStatus mLastFixStatus = Qgis::GpsFixStatus::NoData;
QString mDateTimeFormat; // user specified format string in registry (no UI presented)
QPointer< QgsVectorLayer > mLastLayer;
QFile *mLogFile = nullptr;
Expand Down

0 comments on commit 06ef6e1

Please sign in to comment.