Google Maps API 调用实例
本实例介绍如何调用Google Maps API,并实现用鼠标标注地图,保存进数据库,以及二次加载显示等。
1.需要新建一个自定义控件(如:Map.ascx),用于显示Google地图:
<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="Map.ascx.cs" Inherits="StarSoft.UI.Customer.UserControl.Map" %>
<div id="map" style="width: 100%; height: 360px;">
</div>
<table style="display: none">
<tr>
<td width="60px">
<span>
纬度</span>
</td>
<td>
<asp:TextBox ID="txtY" runat="server" CssClass="txtbase" onfocus="this.className='txtfocus';"
onblur="this.className='txtbase';" onpropertychange="javascript:CheckInputFloat(this);"></asp:TextBox>
</td>
<td>
<span>
经度</span>
</td>
<td>
<asp:TextBox ID="txtX" runat="server" CssClass="txtbase" onfocus="this.className='txtfocus';"
onblur="this.className='txtbase';" onpropertychange="javascript:CheckInputFloat(this);"></asp:TextBox>
</td>
</tr>
<tr>
<td colspan="4">
<script src=" http://ditu.google.com/maps?file=api&v=2&sensor=false&key=<%=System.Configuration.ConfigurationSettings.AppSettings["googlemapkey"].Trim() %>"
type="text/javascript"></script>
<script language="javascript" type="text/javascript">
function CheckInputFloat(oInput) {
if ('' != oInput.value.replace(/\d{1,}\.{0,1}\d{0,}/, '')) {
oInput.value = oInput.value.match(/\d{1,}\.{0,1}\d{0,}/) == null ? '' : oInput.value.match(/\d{1,}\.{0,1}\d{0,}/);
}
} //<![CDATA[
var x;
var geocoder;
var marker;
if (GBrowserIsCompatible()) {
var map = new GMap2(document.getElementById("map"));
var LatValue = document.getElementById("<%=txtX.ClientID%>").value;
var LngValue = document.getElementById("<%=txtY.ClientID%>").value;
if ((LatValue == "") || (LngValue == "")) {
map.setCenter(new GLatLng(30.25372, 120.13343), 13);
}
else {
map.setCenter(new GLatLng(LatValue, LngValue), 13);
var curpoint = new GLatLng(LatValue, LngValue);
marker = new GMarker(curpoint, this.ico);
map.addOverlay(marker);
}
geocoder = new GClientGeocoder();
}
function createMarker(point, title, html) {
var marker = new GMarker(point);
//GEvent.addListener(marker, "click", function(){marker.openInfoWindowHtml(html,{maxContent: html,maxTitle: title});});
return marker;
}
function showAddress(address) {
if (geocoder) {
geocoder.getLatLng(
'中国' + address,
function (point) {
if (!point) {
// alert(address + " 未找到");
}
else {
if (marker)//移除上一個點
{
map.removeOverlay(marker);
}
map.setCenter(point, 13);
var title = "地址";
marker = createMarker(point, title, address);
map.addOverlay(marker);
//marker.openInfoWindowHtml(address,{ maxContent: address, maxTitle: title});
}
}
);
}
}
GEvent.addListener(map, 'click', function (overlay, point) {
if (point) {
map.clearOverlays();
var marker = new GMarker(point, { draggable: true });
map.addOverlay(marker); GEvent.addListener(marker, "dragstart", function () {
});
GEvent.addListener(marker, "dragend", function () {
point = marker.getLatLng();
document.getElementById("<%=txtY.ClientID%>").value = point.x;
document.getElementById("<%=txtX.ClientID%>").value = point.y;
});
document.getElementById("<%=txtY.ClientID%>").value = point.x;
document.getElementById("<%=txtX.ClientID%>").value = point.y;
}
});
map.enableScrollWheelZoom();
map.addControl(new GSmallZoomControl());
map.addControl(new GMapTypeControl()); //]]>
</script>
</td>
</tr>
</table>
Map.ascx
using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq; namespace StarSoft.UI.Customer.UserControl
{
public partial class Map : System.Web.UI.UserControl
{
/// <summary>
/// 纬度
/// </summary>
public string Latitude
{
get { return this.txtX.Text; }
set { this.txtX.Text = value; }
}
/// <summary>
/// 经度
/// </summary>
public string Longitude
{
get { return this.txtY.Text; }
set { this.txtY.Text = value; }
} protected void Page_Load(object sender, EventArgs e)
{ }
}
}
Map.ascx.cs
2.页面中调用这个自定义控件:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="AreaLocation.aspx.cs" Inherits="StarSoft.UI.Customer.AreaLocation" %> <%@ Register src="UserControl/Map.ascx" tagname="Map" tagprefix="uc1" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>无标题页</title>
<webcontrol:Style ID="Style" runat="server" />
<script language="javascript" type="text/javascript">
function ChooseLoaction()
{
var txtX=document.getElementById('<%=Map1.FindControl("txtX").ClientID %>').value;
var txtY= document.getElementById('<%=Map1.FindControl("txtY").ClientID %>').value;
if(txtX=="")
{
alert('请选择经纬度!');
}
else
{
window.returnVal = txtX+"|"+ txtY;
window.parent.hidePopWin(true);
}
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div class="popForm" >
<div class="mainForm">
<uc1:Map ID="Map1" runat="server" />
</div></div> <div class="operArea">
<div class="btnArea" >
<input type="button" id="BtnQuery" class="btnSubmit" runat="server" onclick="javascript:ChooseLoaction();"/>
<input type="button" id="close" class="btnReturn" onclick="javascript:parent.hidePopWin(false);" runat="server"/>
</div>
</div>
</form>
</body>
</html>
AreaLocation。aspx
using System;
using System.Collections;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq; namespace StarSoft.UI.Customer
{
public partial class AreaLocation : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!string.IsNullOrEmpty(StrLoactID) && StrLoactID != "null")
{
Map1.Latitude = StrLoactID.Split(',')[];
Map1.Longitude = StrLoactID.Split(',')[];
} if (!IsPostBack)
{
BtnQuery.Value = StarSoft.Common.ResourceManager.Field("Query");
close.Value = StarSoft.Common.ResourceManager.Field("CancelBtn");
if (Ty != "")
{
close.Value = StarSoft.Common.ResourceManager.Field("CloseBtn");
BtnQuery.Style["display"] = "none";
}
}
} /// <summary>
/// 经纬度信息
/// </summary>
public string StrLoactID
{
get
{
try
{
return Request.Params["LoactID"].ToString();
}
catch
{
return "";
}
}
} /// <summary>
/// 经纬度信息
/// </summary>
public string Ty
{
get
{
try
{
return Request.Params["Ty"].ToString();
}
catch
{
return "";
}
}
}
}
}
AreaLocation。aspx.cs
3.web.config文件中配置Google Map访问秘钥:
<add key="googlemapkey" value="ABQIAAAAFLEnBlXXNVEsCX6NrllENxRtJCFYwXExx0HqCDFUHyWjOHbgXhTNZ_AeqPjv3EmRwdeButm3wRXAuw"/>
运行效果图:

Google Maps API 调用实例的更多相关文章
- Google maps API开发(二)(转)
这一篇主要实现怎么调用Google maps API中的地址解析核心类GClientGeocoder: 主要功能包括地址解析.反向解析.本地搜索.周边搜索等, 我这里主要有两个实例: 实例一.当你搜索 ...
- Google Maps API Web Services
原文:Google Maps API Web Services 摘自:https://developers.google.com/maps/documentation/webservices/ Goo ...
- Google maps API开发
原文:Google maps API开发 Google maps API开发(一) 最近做一个小东西用到google map,突击了一下,收获不小,把自己学习的一些小例子记录下来吧 一.加载Googl ...
- Google Maps API V3 之绘图库 信息窗口
Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...
- Google Maps API V3 之 图层
Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...
- Google Maps API V3 之 路线服务
Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...
- Google maps API开发(一)(转)
一.加载Google maps API <script type="text/javascript" src="http://ditu.google.com/map ...
- Google Maps API的使用
之前在学习了简单的API调用后,查看了几个知名网站的API调用方法,发现Google的API调用还是相对比较简单的.下面就从API key的获取.googlemaps的安装,再到实际使用做一下说明. ...
- Android Google Maps API 网络服务用于网络定位、计算路线、获取经纬度、获取详细地址等
extends:http://blog.csdn.net/h7870181/article/details/12505883 Google Maps API 网络服务 官网地址 : https://d ...
- google maps api申请的问题
现在已经改由统一的GOOGLE API控制台进行所有GOOGLE API的管理了. 方法是使用Google帐号登入 https://code.google.com/apis/console. 然后在所 ...
随机推荐
- [Raobin] Ext.net 页面由于CMB的store和对图像同时执行,所以不会触发非空验证 所以会在后台直接调Js去验证
X.Call("valid", vm.ID_EDIT_FORM); x.Call("前台的js的方法名称"," 参数为集合");
- JZ2440开发笔记(8)——FCLK、HCLK和PCLK
S3C2440中有三种时钟,分别是FCLK,HCLK和PCLK.这三种时钟的功能各不相同,其中FCLK主要是为ARM920T的内核提供工作频率,如图: HCLK主要是为S3C2440 AHB总线(Ad ...
- cocos2d-x ios8 输入框显示bug
https://github.com/cocos2d/cocos2d-x/pull/8149
- Linux SCP 命令: 利用SSH传输文件
在linux下一般用scp这个命令来通过ssh传输文件. 1.从服务器上下载文件scp username@servername:/path/filename /var/www/local_dir(本地 ...
- 从源码剖析一个Spark WordCount Job执行的全过程
原文地址:http://mzorro.me/post/55c85d06e40daa9d022f3cbd WordCount可以说是分布式数据处理框架的”Hello World”,我们可以以它为 ...
- Windows Service installutil 部署时,出错的解决办法-原创
出错信息如下: ---------------------------------------------------------- ~~~~~... The Rollback phase compl ...
- IT应聘者的简历应该是怎么样的?
从去年到现在看了几百份简历,包括产品运营和产品设计师的职位.我不是 HR,只是想直接看到求职者的状况,看看是不是要换更准确的渠道去招聘对的人.我看简历的目的也很简单:找到没有什么问题且可能合适的人,然 ...
- Linux的五个查找命令:find,locate,whereis,which,type
使用电脑的时候,经常需要查找文件. 在Linux中,有很多方法可以做到这一点.国外网站LinuxHaxor总结了五条命令,你可以看看自己知道几条.大多数程序员,可能经常使用其中的2到3条,对这5条命令 ...
- java 泛型中 T、E ... 和 问号(通配符)的区别
一.泛型中T.E ... 是泛型类.泛型方法定义时候用的. 1.泛型类定义在类后面 紧跟类名后面 public class TestClassDefine<T>{} 2.泛型方法定义在方 ...
- 【Android - 基础】之Animator属性动画
1 概述 在3.0系统之前,Android给我们提供了逐帧动画Frame Animation和补间动画Tween Animation两种动画: 1) 逐帧动画的原理很简单,就是 ...