Please note that as of October 24, 2014, the Nokia Developer Wiki will no longer be accepting user contributions, including new entries, edits and comments, as we begin transitioning to our new home, in the Windows Phone Development Wiki. We plan to move over the majority of the existing entries over the next few weeks. Thanks for all your past and future contributions.

Revision as of 15:51, 27 January 2012 by mahbub_s60 (Talk | contribs)

(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

Reverse Geocoding in QML

From Wiki
Jump to: navigation, search

Delete instructional text in italic

This article explains how to ... Replace the abstract text with a short paragraph (or sentence) describing what the topic covers.

Enter article metadata as described below. Note that this template can be placed anywhere in the article. Do not remove parameters that you do not use

Article Metadata
Created: ()
Last edited: mahbub_s60 (27 Jan 2012)


Geocoding is the process of finding associated geographic coordinates (often expressed as latitude and longitude) from other geographic data, such as street addresses, or zip codes (postal codes). With geographic coordinates the features can be mapped and entered into Geographic Information Systems, or the coordinates can be embedded into media such as digital photographs via geotagging. Reverse geocoding is the opposite: finding an associated textual location such as a street address, from geographic coordinates. In this article and code snippet, we explain how we can get address of a place by reverse geocoding with Nokia map.

How to get address from coordinate

We call reverseGeocode() method of QGeoSearchManager and pass the coordinate of the place that we are looking for. If we are interested to a place near by then we can use our device’s positioning system to get the current location and that can be passed to reverseGeocode() method as shown in the following snippet. geocodeFinished slot will be called when it has found the address.

    QGeoSearchReply *reply = m_searchManager->reverseGeocode(m_geoCoordinate);    QObject::connect(reply, SIGNAL(finished()), this,SLOT(geocodeFinished()));
QObject::connect(reply,SIGNAL(error(QGeoSearchReply::Error, QString)), this,SLOT(resultsError(QGeoSearchReply::Error, QString)));

geocodeFinished has been implemented in the following code.

void CLocationSource::geocodeFinished()
QGeoSearchReply* reply = static_cast<QGeoSearchReply *>(sender());
if (reply->error() != QGeoSearchReply::NoError) {
// Errors are handled in a different slot (resultsError)
QList<QGeoPlace> places = reply->places();
if (places.length() == 0)
// do something here
QGeoAddress address = places[0].address();
QString message = + ", " +;
disconnect(reply, SIGNAL(finished()), this,SLOT(geocodeFinished()));
disconnect(reply,SIGNAL(error(QGeoSearchReply::Error, QString)), this,SLOT(resultsError(QGeoSearchReply::Error, QString)));

We need very thin QML code as most stuffs are done in Qt C++ side and that is brought to QML side by using qmlRegisterType() method.

        PositionSource {
id: apositionSource
updateInterval: 1000
active: false
// nmeaSource: "nmealog.txt"
id: positionSource
console.log(" onLonChanged in QML")
console.log(" onLatChanged in QML")
console.log(" Address has been changed")
id: mycordinate
longitude: positionSource.lon
id: map
plugin : Plugin { name : "nokia" }
anchors.fill: parent; size.width: parent.width; size.height: parent.height; zoomLevel: 12
center: mycordinate
Text {text: "Click on screen to swap positioningMethod: " }
Text {text: "<==== Position ====>"}
Text {text: "latitude: " + mycordinate.latitude}
Text {text: "longitude: " + mycordinate.longitude}
Text {text: "Address: " + positionSource.address}


Download the example for C7:

605 page views in the last 30 days.

Was this page helpful?

Your feedback about this content is important. Let us know what you think.


Thank you!

We appreciate your feedback.