Google maps API开发

本文涉及的产品
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
简介: 原文:Google maps API开发 Google maps API开发(一) 最近做一个小东西用到google map,突击了一下,收获不小,把自己学习的一些小例子记录下来吧   一、加载Google maps API 您可以到http://code.
原文: Google maps API开发

Google maps API开发(一)

最近做一个小东西用到google map,突击了一下,收获不小,把自己学习的一些小例子记录下来吧

 

一、加载Google maps API

<script type="text/javascript"

       src="http://ditu.google.com/maps?file=api&amp;v=2&amp;key=ABQIAAAAzr2EBOXUKnm_jVnk0OJI7xSosDVG8KKPE1-m51RBrvYughuyMxQ-i1QfUnH94QxWIa6N4U6MouMmBA&hl=zh-CN"></script>

您可以到http://code.google.com/intl/zh-CN/apis/maps/signup.html注册申请自己的API

二、加载简单的Google地图

1、 加载Google地图

//声明一个GMap2全局变量

var map;

function load()

{

    //检查浏览器的兼容性.

    if (GBrowserIsCompatible())

    {

        map = new GMap2(document.getElementById("map")); //加载地图

        map.addControl(new GLargeMapControl()); //增加全功能控件

        map.addControl(new GMapTypeControl()); //设置地图类型

        map.enableScrollWheelZoom(); //设置地图支持滚轮

        map.setCenter(new GLatLng(39.990168, 116.295304), 10); //设置地图的中心坐标

        map.enableDoubleClickZoom(); //开启双击google map会自动放大.

        map.enableScrollWheelZoom(); //开启滚动鼠标自动放大和缩小.

          //

    }

}

2、 添加一个创建GMarker的方法

function createMarker(baseIcon, point, html)

{

    var icon = new GIcon(baseIcon);

    var marker = new GMarker(point, icon);

    GEvent.addListener(marker, "click", function() { marker.openInfoWindowHtml(html); });

    return marker;

}

3、 调用这个GMarker方法

var icon = new GIcon(G_DEFAULT_ICON);

var point = new GPoint(116.429114, 39.934322);

var html = '<div ><font color="blue">HelloWorld</font></div>';

var marker = createMarker(icon, point, html);

map.addOverlay(marker);

这样一个简单的HelloWorld就显示出来了

通过这个例子我们可以了解到GMap2GMarkerGIcon这几个核心类的基本应用

最后看看我截得图:

 

源文件下载

每天进步一点点...

Google maps API开发(二)

这一篇主要实现怎么调用Google maps API中的地址解析核心类GClientGeocoder

主要功能包括地址解析、反向解析、本地搜索、周边搜索等,

我这里主要有两个实例:

实例一、当你搜索一个地名的时候,解析它的经纬度信息,并在地图上描点

实例二、搜索你的中心点所在区域的学校、商店等信息,并在地图上描点

首先来讲讲实例一怎么实现:

1、 加载google api

<script

type="text/javascript"src="http://ditu.google.com/maps?file=api&amp;v=2&amp;key=ABQIAAAAzr2EBOXUKnm_jVnk0OJI7xSosDVG8KKPE1-m51RBrvYughuyMxQ-i1QfUnH94QxWIa6N4U6MouMmBA&hl=zh-CN"></script>

2、 定义通用的全局变量和公共方法

var map;//GMap2的核心对象

var geocoder = null;//用来解析的

var markers = new Array();//用来存放GMarker

//======在地图上描点的方法============

function createMarker(icon, point, html, index) {

    var letter = String.fromCharCode("A".charCodeAt(0) + index);

    icon.image = "http://ditu.google.com/mapfiles/marker" + letter + ".png";

    var marker = new GMarker(point, icon);

    GEvent.addListener(marker, "click", function() {

        marker.openInfoWindowHtml(html);

    });

    markers.push(marker);

    map.addOverlay(marker);

}

//查询点击事件

function showLocation() {

    map.clearOverlays();

    document.getElementById('divOutput').innerHTML = "搜索中...";

    var address = document.getElementById('txtAddress').value;

    geocoder.getLocations(address, cb_showLocation);//搜索的核心方法

}

//回调事件,主要在界面上描点和右侧产生列表信息

function cb_showLocation(result) {

    // 显示结果

    if (result.Status.code == G_GEO_SUCCESS)

    {

        document.getElementById("divOutput").innerHTML = "成功(" + result.Placemark.length + ")<br />";

        var icon = new GIcon(G_DEFAULT_ICON);

        var lat, lng, point, address, marker;

        for (var i = 0; i < result.Placemark.length; i++) {

            lat = result.Placemark[i].Point.coordinates[1]; // lat

            lng = result.Placemark[i].Point.coordinates[0]; // lng

            address = result.Placemark[i].address; // 地址

            point = new GLatLng(lat, lng);

            document.getElementById("divOutput").innerHTML += ((i + 1) + " " + address + " <small>" + point.toString() + "</small><br />");

            createMarker(icon, point, address, i);

        }

    }

    else {

        document.getElementById("divOutput").innerHTML = result.Status.code;

    }

}

3、 地图初始化

function init() {

    //检查浏览器的兼容性.

    if (GBrowserIsCompatible()) {

        map = new GMap2(document.getElementById("map_canvas"));

        //设置地图的中心坐标.

        var loc = new GLatLng(39.990168, 116.295304);

        map.setCenter(loc, 5);

        //创建带有可在四个方向平移、放大、缩小的按钮,以及缩放滑块的控件。

        map.addControl(new GLargeMapControl());

        //创建带有切换地图类型的按钮的控件。

        map.addControl(new GMapTypeControl());

        //设置地图支持滚轮

        map.enableScrollWheelZoom();

        //实例化一个地址解析

        geocoder = new GClientGeocoder();

    }

}

4、 定义页面加载事件和卸载事件

window.onload = init;

window.onunload = GUnload;

//========主界面==================

<!-- 地图画板 -->

<input type="text" id="txtAddress" name="txtAddress" size="40" /><input type="button" value="查询" onclick="showLocation();" />

<div id="map_canvas" style="width: 600px; height: 500px ;float:left;"></div>

<div id="divOutput" style="float:left;" ></div>

//==============================

主要第一个例子就完成了,效果如下

实例二

1加载google api,这里用到三个

              <script   type="text/javascript" src="http://ditu.google.com/maps?file=api&amp;v=2&amp;key=ABQIAAAAzr2EBOXUKnm_jVnk0OJI7xSosDVG8KKPE1-m51RBrvYughuyMxQ-i1QfUnH94QxWIa6N4U6MouMmBA&hl=zh-CN"></script>

              <script type="text/javascript" src="http://www.google.com/uds/api?file=uds.js&v=1.0&key=ABQIAAAAzr2EBOXUKnm_jVnk0OJI7xSosDVG8KKPE1-m51RBrvYughuyMxQ-i1QfUnH94QxWIa6N4U6MouMmBA&hl=zh-CN"></script>

              <script type="text/javascript" src="http://www.google.com/uds/solutions/localsearch/gmlocalsearch.js"></script>

2、通用核心类、全局变量和公共方法

var map;

var hasMarker = false;

var markers = new Array();

var KMapSearch = window.KMapSearch = function(map_, opts_)

{

    this.opts = { keyWord: opts_.keyWord || "", latlng: opts_.latlng || new GLatLng(31, 121), autoClear: opts_.autoClear || true, icon: opts_.icon || new GIcon(G_DEFAULT_ICON) };

    this.map = map_;

    this.gLocalSearch = new google.search.LocalSearch();

    this.gLocalSearch.setCenterPoint(this.opts.latlng);

    this.gLocalSearch.setResultSetSize(GSearch.LARGE_RESULTSET);

    this.gLocalSearch.setSearchCompleteCallback(this, myTips);

}

//请除所有查询结果

KMapSearch.prototype.clearAll = function() {

    for (var i = 0; i < markers.length; i++) { this.map.removeOverlay(markers[i]); }

    markers.length = 0;

}

//开始查询

KMapSearch.prototype.execute = function(latLng) {

    if (latLng) { this.gLocalSearch.setCenterPoint(latLng); }

    this.gLocalSearch.execute(this.opts.keyWord);

}

//取得查询结果,并以DIV的方式展示

KMapSearch.prototype.getResult = function(result, i) {

    var container = document.createElement("div");

    container.className = "list";

    var myRadom = (new Date()).getTime().toString() + Math.floor(Math.random() * 10000);

    container.id = myRadom;

    container.innerHTML = i + "" + result.title + "<br />地址:" + result.streetAddress;

    //this.createMarker(new GLatLng(result.lat, result.lng), result.html, myRadom);

    return container;

}

3、载入事件和辅助方法

//载入

function OnLoad() {

    if (GBrowserIsCompatible()) {

        map = new GMap2(document.getElementById("map_canvas"));

        map.addControl(new GLargeMapControl());

        map.addControl(new GMenuMapTypeControl());

        map.addControl(new GOverviewMapControl());

        map.enableScrollWheelZoom();

        map.setCenter(new GLatLng(39.990168, 116.295304), 10);

        //添加右键单击事件

        GEvent.addListener(map, "singlerightclick", function(point) {

            var initPt = map.fromContainerPixelToLatLng(point);

            map.clearOverlays();

            marker = new GMarker(initPt, { draggable: true });

            if (hasMarker) {

                marker.setLatLng(initPt);

                map.panTo(initPt);

            }

            else {

                //拖拽事件

                GEvent.addListener(marker, "dragend", function() {

                    initPt = marker.getLatLng();

                    map.panTo(initPt);

                    searchMap(initPt);

                });

                hasMarker = true;

            }

            map.addOverlay(marker);

            searchMap(initPt);

        });

    }

}

//点击提示信息

function myTips() {

    var content = "";

    var resultdiv = document.getElementById("map");

    for (j = 0; j < markers.length; j++) {

        map.removeOverlay(markers[j]);

    }

    markers.length = 0;

    var results = this.gLocalSearch.results;

    var icon = new GIcon(G_DEFAULT_ICON);

    var savedResults = document.getElementById("schollContainer");

    if (this.gLocalSearch.results)

    {

        if (this.opts.autoClear) {

            savedResults.innerHTML = "";

        }

        for (var i = 0; i < results.length; i++) {

            content = '<p>' + '名称:' + results[i].title + '<br />' + '地址:' + results[i].streetAddress + '<br />' + '坐标:' + results[i].lat + ',' + results[i].lng + '</p>';

            myCreateMarker(new GPoint(results[i].lng, results[i].lat), icon, content, i);

            savedResults.appendChild(this.getResult(this.gLocalSearch.results[i], i + 1));

        }

    }

}

//地图上标注

function myCreateMarker(point, icon, html, index) {

    var letter = String.fromCharCode("A".charCodeAt(0) + index);

    icon.image = "http://ditu.google.com/mapfiles/marker" + letter + ".png";

    var marker = new GMarker(point, icon);

    GEvent.addListener(marker, "click", function() { marker.openInfoWindowHtml(html); });

    markers.push(marker);

    map.addOverlay(marker);

}

//在给定的坐标附近搜索指定的关键字

function searchMap(initPt) {

    var myIcon = new GIcon(G_DEFAULT_ICON);

    var mapSearch = new KMapSearch(map, { latlng: initPt, icon: myIcon, keyWord: "驾校" });

    mapSearch.clearAll();

    mapSearch.execute();

}

5、 最后

window.onload = OnLoad;

window.onunload = GUnload;

//========主界面==================

<!-- 地图画板 --> 

<div id="map_canvas" style="width:640px; height:480px ;float:left;"></div>

<div style="width:4px; height:480px ;float:left;"></div>

<div id="searchResult">驾校:<div id="schollContainer"></div></div>

//==============================

搞定, 最后的效果如图:

 

 源码实例下载

每天进步一点点...

目录
相关文章
|
3天前
|
JSON 安全 API
如何使用Python开发API接口?
在现代软件开发中,API(应用程序编程接口)用于不同软件组件之间的通信和数据交换,实现系统互操作性。Python因其简单易用和强大功能,成为开发API的热门选择。本文详细介绍了Python开发API的基础知识、优势、实现方式(如Flask和Django框架)、实战示例及注意事项,帮助读者掌握高效、安全的API开发技巧。
21 3
如何使用Python开发API接口?
|
3天前
|
缓存 监控 Java
如何运用JAVA开发API接口?
本文详细介绍了如何使用Java开发API接口,涵盖创建、实现、测试和部署接口的关键步骤。同时,讨论了接口的安全性设计和设计原则,帮助开发者构建高效、安全、易于维护的API接口。
16 4
|
2天前
|
XML JSON API
【PHP开发专栏】PHP RESTful API设计与开发
随着互联网技术的发展,前后端分离成为Web开发的主流模式。本文介绍RESTful API的基本概念、设计原则及在PHP中的实现方法。RESTful API是一种轻量级、无状态的接口设计风格,通过HTTP方法(GET、POST、PUT、DELETE)操作资源,使用JSON或XML格式传输数据。在PHP中,通过定义路由、创建控制器、处理HTTP请求和响应等步骤实现RESTful API,并强调了安全性的重要性。
9 2
|
9天前
|
前端开发 关系型数据库 API
深入浅出后端开发——从零到一构建RESTful API
本文旨在为初学者提供一个关于后端开发的全面指南,特别是如何从零开始构建一个RESTful API。我们将探讨后端开发的基本概念、所需技术栈、以及通过实际案例展示如何设计和实现一个简单的RESTful API。无论你是完全的新手还是有一定编程基础的开发者,这篇文章都将为你提供实用的知识和技巧,帮助你在后端开发的道路上迈出坚实的一步。
|
10天前
|
缓存 负载均衡 安全
后端开发的艺术:构建高效、可扩展的API
在现代软件开发中,后端开发扮演着至关重要的角色。它不仅负责处理数据存储、业务逻辑和安全性,还需要提供高效、可扩展的API供前端和其他服务使用。本文将深入探讨后端开发的关键概念和技术,帮助读者了解如何构建高效、可扩展的API,并提供一些实用的建议和最佳实践。
|
10天前
|
缓存 负载均衡 测试技术
‌API开发的基础概念和作用‌
API(Application Programming Interface)是一组定义了软件组件之间交互规则的接口。它提供了一种标准化的方式,让不同的软件组件之间可以进行通信和交互。
|
10天前
|
缓存 API 网络架构
掌握现代API开发:GraphQL vs REST
【10月更文挑战第24天】本文深入探讨了现代API开发中两种主流技术——GraphQL和REST的设计理念、技术特点及实际开发中的对比分析。GraphQL通过声明式数据请求和强类型系统提供更高的灵活性和性能,而REST则以其无状态特性和成熟的生态系统见长。文章还讨论了两者在客户端-服务器交互、安全性和工具支持方面的优劣,帮助开发者根据项目需求做出明智选择。
|
17天前
|
Java 大数据 API
别死脑筋,赶紧学起来!Java之Steam() API 常用方法使用,让开发简单起来!
分享Java Stream API的常用方法,让开发更简单。涵盖filter、map、sorted等操作,提高代码效率与可读性。关注公众号,了解更多技术内容。
|
14天前
|
存储 XML API
探索后端开发中的RESTful API设计哲学
【10月更文挑战第21天】在数字化时代,后端开发是构建强大、可靠和可扩展应用程序的基石。本文将深入探讨RESTful API的设计原则,并展示如何通过这些原则来提升API的质量和性能。我们将从基础概念出发,逐步深入到实际案例分析,揭示高效API设计的秘诀。无论你是初学者还是有经验的开发者,这篇文章都将为你提供宝贵的见解和实用的技巧,帮助你在后端开发的道路上更进一步。
|
10天前
|
关系型数据库 测试技术 API
探索后端开发:构建高效API的艺术
【10月更文挑战第25天】在数字化时代,后端开发不仅仅是编写代码那么简单。它是连接用户与数据的桥梁,是实现业务逻辑的基石。本文将深入探讨如何构建高效的API,从理解RESTful原则到选择合适的框架,再到处理数据库交互,每一步骤都是精心策划的舞蹈。我们将通过实际案例,揭示如何在保证性能和安全性的同时,提供流畅的用户体验。让我们一起走进后端开发的世界,发现那些隐藏在代码背后的智慧和创造力。

热门文章

最新文章