Better support for OLC (Open Location Code) #457
Labels
No labels
Accessibility
Accessibility
Address
Address
Android
Android
Android Auto
Android Auto
Android Automotive (AAOS)
Android Automotive (AAOS)
API
API
AppGallery
AppGallery
AppStore
AppStore
Battery and Performance
Battery and Performance
Blocker
Blocker
Bookmarks and Tracks
Bookmarks and Tracks
Borders
Borders
Bug
Bug
Build
Build
CarPlay
CarPlay
Classificator
Classificator
Community
Community
Core
Core
CrashReports
CrashReports
Cycling
Cycling
Desktop
Desktop
DevEx
DevEx
DevOps
DevOps
dev_sandbox
dev_sandbox
Directions
Directions
Documentation
Documentation
Downloader
Downloader
Drape
Drape
Driving
Driving
Duplicate
Duplicate
Editor
Editor
Elevation
Elevation
Enhancement
Enhancement
Epic
Epic
External Map Datasets
External Map Datasets
F-Droid
F-Droid
Fonts
Fonts
Frequently User Reported
Frequently User Reported
Fund
Fund
Generator
Generator
Good first issue
Good first issue
Google Play
Google Play
GPS
GPS
GSoC
GSoC
iCloud
iCloud
Icons
Icons
iOS
iOS
Legal
Legal
Linux Desktop
Linux Desktop
Linux packaging
Linux packaging
Linux Phone
Linux Phone
Mac OS
Mac OS
Map Data
Map Data
Metro
Metro
Navigation
Navigation
Need Feedback
Need Feedback
Night Mode
Night Mode
NLnet 2024-06-281
NLnet 2024-06-281
No Feature Parity
No Feature Parity
Opening Hours
Opening Hours
Outdoors
Outdoors
POI Info
POI Info
Privacy
Privacy
Public Transport
Public Transport
Raw Idea
Raw Idea
Refactoring
Refactoring
Regional
Regional
Regression
Regression
Releases
Releases
RoboTest
RoboTest
Route Planning
Route Planning
Routing
Routing
Ruler
Ruler
Search
Search
Security
Security
Styles
Styles
Tests
Tests
Track Recording
Track Recording
Translations
Translations
TTS
TTS
UI
UI
UX
UX
Walk Navigation
Walk Navigation
Watches
Watches
Web
Web
Wikipedia
Wikipedia
Windows
Windows
Won't fix
Won't fix
World Map
World Map
No milestone
No project
No assignees
4 participants
Due date
No due date set.
Dependencies
No dependencies set.
Reference: organicmaps/organicmaps-tmp#457
Loading…
Add table
Reference in a new issue
No description provided.
Delete branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
I like the app a lot, but it would be interesting to show in the coordinates part also the OLC of the point, since the app already works with OLC

Thanks!
Upvote & Fund
That shouldn't be hard: add a third coordinates option on a click.
I have never heard about Open Location Code. It seems to be some Google stuff nobody else uses. Could you please explain why we should support this format?
It's an open format that essentially maps WGS84 latitude/longitude coordinates to short alphanumeric strings.
It has a couple of nice properties like not requiring language-specific word lists (unlike a somewhat popular proprietary alternative), being easy to copy/paste, avoiding localization issues (for example "N" and "E" are not as universal as +/-, yet often WGS84 is given in the former, as well as the ambiguity between "." and "," as the decimal separator) and possibly others.
Given that it's free/open and this repository apparently already includes a support library for it, it would be nice to be able to use these "plus codes" in addition to the existing decimal and DMS WGS84 options.
There are 2 ways OLC code could be generated:
796RWF8Q+WF
WF8Q+WF, Praia
To build short code there should be some reference point (
Praia
in example). Usually city is picked as a reference point. See Guidance for shortening codes. Is there any API in OrganicMaps to get nearest city for <lat, lon> pair?Check what is in 3party/open-location-code (it may need to be updated).
Search by short OLC works incorrectly in ver. 2021.09.14-4-Google. OrganicMaps thinks that
V75V+8R
is valid short code. But correct short OLC isV75V+8R Paris, France
.How to reproduce:
V75V+8R
into search field.V75V+8R
into search field againExpected behaviour:
V75V+8R
in search field nothing should happen.V75V+8R Paris, France
OrganicMaps should decode coordinates.The problem is in code search/processor.cpp.
See https://plus.codes/map for expected behaviour of coordinates <-> short OLC convertion.
@vng there should be some sample in the code. It is easy to fetch all cities and towns in the area with the nearest distance filter.
В двух словах, короткий OLC не работает без указания города. Например
V75V+8R Paris, France
- это точка в Париже. И во всех примерах при декодировании короткого OLC нужно дополнительно указывать Reference Location. См openlocationcode_example.cc. Если пользователь в строке поиска явно указал город, нужно использовать центр города для декодирования короткого OLC. Если пользователь не добавил город, то, наверное, можно найти ближайший и использовать его (но не уверен насколько это правильное поведение).Request to add support for plus codes urls (ex https://plus.codes/8FW4V7FW+G2) as per https://t.me/organicmaps/10160
Also short codes without locality are valid (according to https://github.com/google/open-location-code/wiki/Supporting-plus-codes-in-your-app#supporting-plus-codes-for-search) so that's one less problem. Knowing which locality could be found using geolocation, map focus, offline maps, bookmarks and/or something else.
To be valid without locality, short codes should be provided with place hints. Opening them from an URL will not help much. The hope is that only global codes are shared via links.
Because this is the only format that one can conveniently copy out of google, paste in a map that supports it and have it working. That is important(!) because you would frequently get exactly those codes, and you need a quick conversion function.
Can somebody please clarify what information do we need to provide to remove the label
Need Feedback
and accept it into organicmaps timeline?// I've only recently found out that OrganicMaps exists, being a fan of the old pre-fork version before (mapsme). Already donated a bit and would love to do more.
@vn971 Someone needs to test the current implementation (at least in Android where it was implemented) and make a full list of issues (also mentioned in this thread). So any developer can read and implement it as the next step )
As I see, to fully support OLC codes, OM should (according to this document mentioned before):
796RWF8Q+WF
WF8Q+WF Praia, Cabo Verde
WF8Q+WF Praia, Cabo Verde
The original poster was focused on (1).
As for me, (2) seems more important, since Google Maps sharing always produces local codes with a locality in the format
V75V+8R Paris
. When I paste them to OM, it is not recognised at all. Then I have to manually deleteParis
part, and after that OM decodesV75V+8R
to some coordinates, presumably relevant to my current position, which seems to be the best guess — but not always correct one.From a developer point of view (2) and (3) may require more advanced geocoding than (1). Anyway, completing all three would result in a full support of OLC.
As an intermediary, if OM can't easily geolocate the "Praia, Cabo Verde" part, then simply ignoring everything after the shortcode would be preferable so that at least a result is returned (usually the correct one, if you're near the target city.)
Then, later, geolocating the city name can be a further improvement.