Realtime Location Tracking

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 4

Realtime Location Tracking Google Maps: HTML5

Advertisement:

8 Replies In this video tutorial, we show you how we can keep track of the visitor and locate him/her on Google Maps using geolocation API of HTML5. This video tutorial is a continuation of previous videos, so please make sure to watch them before this: HTML5 Getting Started Guide Geolocation API Success Handler: HTML5 Geolocation API Error Handle: HTML5 Google Maps Integration: HTML5 Adding Pin/Marker To Google Map: HTML5 Add Popup message To Google Map Pin: HTML5 JavaScript file mySript.js
if( navigator.geolocation ) 1 { 2 var optn = { 3 enableHighAccuracy: true, 4 timeout: Infinity, 5 maximumAge: 0 6 }; 7 var watchID = 8 navigator.geolocation.watchPosition(success, fail, optn); 9 } 10 11 else 12 $("p").html("HTML5 Not Supported"); 13 14 $("button").click(function(){ 15 16 if(watchID) 17 navigator.geolocation.clearWatch(watchID); 18 19 watchID = null; 20 return false; 21 });

Here we are setting the 3rd parameter of watchPosition() method. Were enabling HighAccuracy, setting timeout to Infinity i.e., itll keep looking for the location information for ever or until it gets it. We can set this to some numerical value and itll check till then before itll show a Timed out message to the user. maximumAge is set to 0, so that it fetches new location each time its asked for. If we set it to Infinity, itll forever show the cached data and will never fetch or update the new location information.

watchPosition() is a geolocation method, which keeps watching/fetching new user location data. This would be helpful for tracking users location information in realtime. HTML file index.html
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 < !doctype html> <html> <head> <title>Geolocation API: Technotip.com</title> <meta charset="utf-8"/> <link href="css/myStyle.css" rel="stylesheet"/> <script src="js/jquery-1.10.1.min.js"></script> <script src="http://maps.google.com/maps/api/js?sensor=true"></script> <script src="js/myScript.js"></script> </head> <body> <p id="map"></p> <button>Stop</button> </body> </html>

We also have a stop button added to our index.html page, once the user clicks on that button, we call clearWatch() method of geolocation API and ask watchPosition() method to stop tracking the users location. Realtime Location Tracking Google Maps: HTML5

YouTube Link: http://www.youtube.com/watch?v=qYFkPFtfgdI [Watch the Video In Full Screen.]

By combining all the things you have learnt in this Google MAPs and geolocation API video tutorial series, you can build real time location tracking applications, which returns users location on a map, pin points it. Combining this, you could store users initial and final location, store it in database, pin point both locations on Google MAP and show them the distance or route etc. Full JavaScript file mySript.js
1 var watchID = null; 2 $(document).ready(function(){ 3 var optn = { 4 enableHighAccuracy: true, 5 timeout: Infinity, 6 maximumAge: 0 7 }; 8 if( navigator.geolocation )

9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69

navigator.geolocation.watchPosition(success, fail, optn); else $("p").html("HTML5 Not Supported"); $("button").click(function(){ if(watchID) navigator.geolocation.clearWatch(watchID); watchID = null; return false; }); }); function success(position) { var googleLatLng = new google.maps.LatLng(position.coords.latitude, position.coords.longitude); var mapOtn={ zoom:10, center:googleLatLng, mapTypeId:google.maps.MapTypeId.ROAD }; var Pmap=document.getElementById("map"); var map=new google.maps.Map(Pmap, mapOtn); addMarker(map, googleLatLng, "Technotip.com", "SATISH B<br /><b>About Me:</b>http://technotip.com/about/"); } function addMarker(map, googleLatLng, title, content){ var markerOptn={ position:googleLatLng, map:map, title:title, animation:google.maps.Animation.DROP }; var marker=new google.maps.Marker(markerOptn); var infoWindow=new google.maps.InfoWindow({ content: content, position: googleLatLng}); google.maps.event.addListener(marker, "click", function(){ infoWindow.open(map); }); } function fail(error) { var errorType={ 0:"Unknown Error", 1:"Permission denied by the user", 2:"Position of the user not available", 3:"Request timed out" };

70 71 72 73

var errMsg = errorType[error.code]; if(error.code == 0 || error.code == 2){ errMsg = errMsg+" - "+error.message; } $("p").html(errMsg); }

You can integrate MAPs feature into your existing application and release this module to your users and impress them by telling their location or you can show other users nearby to their location, this would amaze some, as to how you could know about the person living nearby Remember the position.coords.accuracy property, which returns the accuracy value in meters? Using this value, show all the users present around a users location with that accuracy(position.coords.accuracy). Happy learning!

You might also like