MapQuest API key via env variable
dizcza opened this issue · 11 comments
Hi and thanks for a unix-friendly UI to parse ublox data. I was looking for a non-Windows solution and found yours.
I have lots of files in a home directory, and typically the keys are set via environment variables. Could you add such an option to parse the MQAPIKEY
env var, if set, as an alternative to the mqapikey
file?
Also, is there a way to show the data in Google Maps? The current map is non-interactive: I need to wait a minute before a new zoom is applied to the map...
Thanks.
Also, I don't understand what the track
and speed
are in UI parsed data. Other tags are self-explanatory. Could you perhaps add some explanation for these two variables in the readme? For example, I get N/A for the track
most of the time and I don't know how bad it is.
Hi @dizcza ,
Thanks for your interest in PyGPSClient - glad you're finding it useful.
To answer your questions in order:
- There are no current plans to enable MQAPIKEY via an environment variable - this can require elevated privileges on some platforms which makes it more fiddly to implement on a consistent cross-platform basis. Hopefully the key file option can work for you.
- Simple answer is no - I'm using the MapQuest API because it's free (for non-commercial use up to 15,000 transactions a month) and relatively easy to implement. Out of interest, do you see any particular advantage in using Google Maps rather than MapQuest? The maps are equally reliable in my experience. If it's the refresh rate that troubles you, you can alter that by changing the
MAP_UPDATE_INTERVAL
constant inglobals.py
, but please appreciate that the map is only provided for quick visual reference purposes. It's not intended to be a full interactive navigation or geolocation aid. - Can you clarify which particular UBX or NMEA message type(s) you're referring to containing the
track
andspeed
attributes? Without knowing which device you're using or how/where it's configured, I can't speak for the particular readings you're getting, but if you tell me which message type you're getting it from I can at least advise on its interpretation.
I'm using a Neo-6M. NMEA protocol.
ok that's a fairly old device. which specific NMEA message type are you getting speed
and track
from?
do you see any particular advantage in using Google Maps rather than MapQuest?
I can freely navigate in a google map.
this can require elevated privileges on some platforms which makes it more fiddly to implement on a consistent cross-platform basis.
Why? The os
built-in module is cross-platform, isn't it?
import os
key = os.environ.get("MQAPIKEY")
Then I can launch the app with MQAPIKEY=... pygpsclient
. Linux folks will appreciate this.
OK so the log you've provided contains a variety of NMEA messages - the message type is bit after <NMEA(,
so for example GPRMC
, GPVTG
, GPGLL
etc. (CAUTION - the coordinates in this log are now visible in the public domain)
The spd
attribute in the GPRMC message, for example, represents the speed over ground in knots; likewise the sogn
attribute in GPVTG. The sogk
attribute in GPVTG represents speed over ground in km/h. I would refer you to the data sheet for your particular device for further information, or post a general question in the u-blox support forum https://portal.u-blox.com/s/.
do you see any particular advantage in using Google Maps rather than MapQuest?
I can freely navigate in a google map.
But, as I say, the map in PyGPSClient is not intended for navigation purposes - it's purely to provide a quick visual reference of the location and horizontal accuracy (where available) provided by the device. There are plenty of other apps available if you want to use a connected GNSS device for real-time navigation.
CAUTION - the coordinates in this log are now visible in the public domain
True. I'll delete the log.
You're right about sticking to simplicity. Your app is cool anyway and perhaps it got working from the start just because it's simple, meant to have a quick look, and lacks features that otherwise would turn your project into a gigantic dependencies list (which would make me feel to search for a simpler solution).
All right. Thanks for your help.
All right. Thanks for your help.
More than happy to consider feature requests. I will as I say look into provisioning map keys as ENV variables, but I may not get round to it for a while. In the meantime, if there's any functionality you think PyGPSClient
could usefully provide within the context of a (relatively) simple Python/tkinter diagnostic and configuration tool, by all means raise the suggestion. Cheers.