Google Maps Control for ASP.Net - Part 2
Free Open source Control
Introduction
This is second part in two part series of my article Google Maps User Control for ASP.Net. In first part Google Maps Control for ASP.Net - Part 1 I have explained how to use this control in your ASP.Net application. In this part I am going to explain source code of this user control so that you can modify it for your own use.Diagram
ASPX page with Google Map User Control
- As I mentioned in part 1, we need to initialize few properties of this user control to make it work. These properties are initialized in Page_Load() event of ASPX page.
- When you initialize these properties, they gets stored in GOOGLE_MAP_OBJECT session variable. Later on this session variable is accessed by GService.asmx web service to draw google map.
- Go to source of GoogleMapForASPNet.aspx.cs file. Check Page_Load() method.
As you can see, I am storing GoogleMapObject property in a session variable if this is a first time load of page. If this is a post back then I use existing session variable value and assign it to GoogleMapObject property.
User Control (GoogleMapForASPNet.ascx)
- GoogleMapForASPNet.ascx file contains a <DIV> element with ID=GoogleMap_Div. Google map is drawn on this <DIV> element
- GoogleMapForASPNet.ascx is responsible for calling DrawGoogleMap()
javascript function on page load. If you see source of
GoogleMapForASPNet.ascx.cs file, it contains following lines in
Page_Load() event.
This causes DrawGoogleMap() function to get fired.
GoogleMapAPIWrapper.js
- This javascript acts as a wrapper between ASP.Net calls and Google Maps Core API functions.
- When DrawGoogleMap() function is called, it calls web service method GService.GetGoogleObject() to get session variable values.
- Once different parameters are retrieved from session variable, it will start calling Google Maps core API functions to draw a map.
Web Service (GService.asmx)
- As I have mentioned before, GService.GetGoogleObject() and GService.GetGoogleObjectOptimized() are functions defined in GService.asmx file.
- These functions retrieves Google Map parameters from session variable.
How to define a Web Service Method
- This control uses Web Service Methods to get values from a session variable. These methods are defined in Gservice.cs(GService.asmx code behind) file.
- Go to source of GService.cs file. Observe how GetGoogleObject() web method is defined.
Return value type from this method is GoogleObject.
How to call ASP.Net function (Web service method) from Javascript using a Web Service
- If you go to HTML source of GoogleMapForASPNet.ascx file, you will see that I am using <ScriptManagerProxy> control. When <ServiceReference> is used with <ScriptManagerProxy> or <ScriptManager> controls, it allows you to use web service methods defined in code behind.
- Go to source of GoogleMapAPIWrapper.js file. Observe how I am calling a web service method in DrawGoogleMap() function.
GService.GetGoogleObject() is a web service method. fGetGoogleObject() is a javascript function that should be called once web service method returns.
result is return value from web service method GService.GetGoogleObject(). Thus result is of type GoogleObject. You can access properties of result in javascript to get map parameters.
Difference between GetGoogleObject() and GetGoogleObjectOptimized()
- Both of these methods work in similar fashion. GetGoogleObject() is called when page loads for first time. It returns all of the GoogleObject properties to javascript function. While GetGoogleObjectOptimized is called on postback. It does not return all of the properties. Instead it returns minimum properties required to make a change in existing map.
- If you view source of GoogleMapAPIWrapper.js file, there are two functions defined in it as below,
These function causes GService.GetOptimizedGoogleObject() to get fired when an AJAX call finishes. For example let's say you have a button in an UpdatePanel. When you click it, it postbacks the page. When this postback completes, above function will get fire.
Functions defined in GoogleMapAPIWrapper.js
- To make this article short, I don't want to explain each and every function defined in this file. Instead I will explain important functions only. If you want more details for any code that's not explained here, you can post your questions in Comments section..
-
This function creates a marker on Google Map. As you can see, I am adding two events with each marker. First one is click(). When a user clicks on marker, a balloon (info window) pops up. This is a javascript event. Second one is dragend(). If a user wants he can drag a pushpin to a new location. This will cause a web method GService.SetLatLon() to get executed. This method sets new latitude and longitude values in Session Variable. As you can see this function also calls RaiseEvent() function which causes an AJAX postback.
When postback finishes, new latitude and longitude values will be picked up from Session Variable. -
This function causes Recentering of map. It finds all visible markers on map and decides center point and zoom level based on these markers. -
This function creates polylines between given points. See Polylines property in GoogleObject class. -
This function creates polygons between given points. See Polygons property in GoogleObject class.
How to define Icons for google map
- If you see implementation of fGetGoogleObject() and fGetGoogleObjectOptimized() javascript functions, you can see that I am creating custom icons for google map. This is how they are defined.
- There are various properties that you can set for a custom icon.
Following article explains you each of these properties in detail.
Making your own custom markers
No comments:
Post a Comment