最近学习了一下高德地图web版的使用,总结了一下高德基础控件的应用,高德地图是开源可编辑的,方法不是很难,有兴趣的朋友可以试一试自己编辑一下.

之前想自己做一个旅游导航的项目,在网上一搜发现了高德地图开放平台,发现原来高德可以很简单的就应用到自己的项目里面,当即我就申请了一个key来学一学,仔细研究了一下,感觉还挺难的,网上找了找案例什么的,经过这几天,小编把高德的一些基础控件差不多弄了一下,效果图如下图所示:

下面是js代码:

var mapObj;

var scale;

var mapType;

var toolBar;

var overView;

var circleEditor;

var circle;

var polygonEditor;

var polygon;

var homeControl;

var controlUI;

var ruler;

var mousetool;

//刷新页面

function reload(){

location.reload();

}

function mapInit(){

mapObj = new AMap.Map("iCenter",{

center:new AMap.LngLat(116.397728,39.90423), //地图中心点

level:13, //地图显示的比例尺级别

});

mapObj.plugin(["AMap.ToolBar"],function(){ //在地图中添加ToolBar插件

toolBar = new AMap.ToolBar();

mapObj.addControl(toolBar);

});

mapObj.plugin(["AMap.Scale"],function(){ //加载比例尺插件

scale = new AMap.Scale();

mapObj.addControl(scale);

scale.show();

});

mapObj.plugin(["AMap.OverView"],function(){ //在地图中添加鹰眼插件

//加载鹰眼

overView = new AMap.OverView({

visible:true //初始化显示鹰眼

});

mapObj.addControl(overView);

overView.open(); //展开鹰眼

});

mapObj.plugin(["AMap.RangingTool"],function(){

ruler = new AMap.RangingTool(mapObj);

AMap.event.addListener(ruler,"end",function(e){

ruler.turnOff();

});

});

mapObj.plugin(["AMap.MouseTool"],function(){ //鼠标工具插件

mousetool = new AMap.MouseTool(mapObj);

});

}

function Coordinate(){

AMap.event.addListener(mapObj,'click',getLnglat); //点击事件

}

function toolBarShow(){

toolBar.show();

toolBar.showRuler();

toolBar.showDirection();

}

function toolBarDirection(){

toolBar.show();

toolBar.showDirection();

toolBar.hideRuler();

}

function toolBarLong(){

toolBar.show();

toolBar.hideDirection();

toolBar.showRuler();

}

function toolBarShot(){

toolBar.show();

toolBar.hideRuler();

toolBar.hideDirection();

}

function iMapType(){

mapObj.plugin(["AMap.MapType"],function(){ //添加地图类型切换插件

//地图类型切换

mapType= new AMap.MapType({defaultType:1,showRoad:true});

mapObj.addControl(mapType);

});

}

function removeMapType(){

mapObj.removeControl(mapType);

}

function iCircleEditor(){ //圆形编辑器

circle = new AMap.Circle({ //圆形编辑器的样式

map: mapObj,

center:new AMap.LngLat("116.40332221984863","39.90025505675715"),

radius:1000,

strokeColor: "#F33",

strokeOpacity: 1,

strokeWeight: 3,

fillColor: "ee2200",

fillOpacity: 0.35

});

mapObj.plugin(["AMap.CircleEditor"],function(){

circleEditor = new AMap.CircleEditor(mapObj,circle); //创建圆形编辑器对象

circleEditor.open(); //打开圆形编辑器

});

}

function removeCicleEditor(){ //关闭圆形编辑器,隐藏圆形

circleEditor.close();

circle.hide();

}

function iPloygonEditor(){ //编辑多边形

var arr=new Array();//经纬度坐标数组

arr.push(new AMap.LngLat("116.403322","39.920255"));

arr.push(new AMap.LngLat("116.410703","39.897555"));

arr.push(new AMap.LngLat("116.402292","39.892353"));

arr.push(new AMap.LngLat("116.389846","39.891365"));

polygon = new AMap.Polygon({

path:arr, //设置多边形轮廓的节点数组

strokeColor:"#0000ff",

strokeOpacity:0.2,

strokeWeight:3,

fillColor: "#f5deb3",

fillOpacity: 0.35

});

//地图上添加多边形

mapObj.addOverlays(polygon);

//构造多边形编辑对象,并开启多边形的编辑状态

mapObj.plugin(["AMap.PolyEditor"],function(){

polygonEditor = new AMap.PolyEditor(mapObj,polygon);

polygonEditor.open();

});

}

function removePloygonEditor(){

polygonEditor.close();

polygon.hide();

}

AMap.homeControlp = function(){}

AMap.homeControlp.prototype = {

addTo: function(map, dom){

dom.appendChild(this._getHtmlDom(map));

},

_getHtmlDom:function(map){

this.map=map;

// 创建一个能承载控件的

容器

controlUI = document.createElement("p");

controlUI.style.width='80px'; //设置控件容器的宽度

controlUI.style.height='20px'; //设置控件容器的高度

controlUI.style.backgroundColor='white';

controlUI.style.borderStyle='solid';

controlUI.style.borderWidth='2px';

controlUI.style.cursor='pointer';

controlUI.style.textAlign='center';

// 设置控件的位置

controlUI.style.position='absolute';

controlUI.style.left='120px'; //设置控件离地图的左边界的偏移量

controlUI.style.top='5px'; //设置控件离地图上边界的偏移量

controlUI.style.zIndex='300'; //设置控件在地图上显示

// 设置控件字体样式

controlUI.style.fontFamily='Arial,sens-serif';

controlUI.style.fontSize='12px';

controlUI.style.paddingLeft='4px';

controlUI.style.paddingRight='4px';

controlUI.innerHTML="换中心点";

// 设置控件响应点击onclick事件

controlUI.onclick = function(){

map.setCenter(new AMap.LngLat(116.234404, 39.12915));

}

return controlUI;

}

}

AMap.event.trigger(homeControlp,"hide");

AMap.event.addListener(homeControlp,"hide",function(){

controlUI.style.display = 'none';

})

function myControl(){

homeControl = new AMap.homeControlp(mapObj); //新建自定义插件对象

mapObj.addControl(homeControl); //地图上添加插件

}

function removeMyControl(){

homeControl.hide();

//controlUI.style.display='none';

}

function iRangingTool(){

ruler.turnOn();

}

function removeRangingTool(){

ruler.turnOff();

mapObj.clearMap();

//ruler.hide();

//ruler.setMap(null);

//mapObj.removeControl(ruler);

}

function iMarker(){

mousetool.marker(); //使用鼠标工具,在地图上画标记点

}

function iMeasureArea(){

mousetool.measureArea();

}

function iRectZoomIn(){

mousetool.rectZoomIn();

}

function iRectZoomOut(){

mousetool.rectZoomOut();

}

function iPolyline(){

mousetool.polyline();

}

function iPolygon(){

mousetool.polygon();

}

function iCircle(){

mousetool.circle();

}

function iRectangle(){

mousetool.rectangle();

}

function iRule(){

mousetool.rule();

}

function removeMouseTool(){

mousetool.close(true);

}

function geocoder() {

var MGeocoder;

//加载地理编码插件

mapObj.plugin(["AMap.Geocoder"], function() {

MGeocoder = new AMap.Geocoder({

radius: 1000,

extensions: "all"

});

//返回地理编码结果

AMap.event.addListener(MGeocoder, "complete", geocoder_CallBack);

//逆地理编码

MGeocoder.getAddress(lnglatXY);

});

//加点

var marker = new AMap.Marker({

map:mapObj,

icon: new AMap.Icon({

image: "http://api.amap.com/Public/images/js/mark.png",

size:new AMap.Size(58,30),

imageOffset: new AMap.Pixel(-32, -0)

}),

position: lnglatXY,

offset: new AMap.Pixel(-5,-30)

});

// mapObj.setFitView();

}

//回调函数

function geocoder_CallBack(data) {

var address;

//返回地址描述

address = data.regeocode.formattedAddress;

//返回结果拼接输出

document.getElementById("iAddress").innerHTML = address;

}

//鼠标点击,获取经纬度坐标

function getLnglat(e){

mapObj.clearMap();

var x = e.lnglat.getLng();

var y = e.lnglat.getLat();

document.getElementById("lnglat").innerHTML = x + "," + y;

lnglatXY = new AMap.LngLat(x,y);

geocoder();

}

下面是HTML代码:

  • 显示完整鱼骨隐藏鱼骨方向盘长标尺短标尺
  • 显示比例尺隐藏比例尺
  • 显示鹰眼隐藏鹰眼
  • 添加地图类型切换移除地图类型切换
  • 添加圆形编辑器删除圆形编辑器
  • 添加多边形编辑器删除多边形编辑器
  • 鼠标打点工具清除
  • 鼠标画折线工具清除
  • 鼠标画多边形工具清除
  • 鼠标画圆形工具清除
  • 鼠标画矩形工具清除
  • 鼠标测距工具清除
  • 鼠标测面积移除
  • 鼠标框选缩小鼠标框选放大关闭鼠标放大缩小
  • 测距插件隐藏测距
  • 添加自定义控件移除自定义控件
  • 坐标拾取控件取消坐标拾取

总结:以上就是本篇文的全部内容,希望能对大家的学习有所帮助。

相关推荐:

高德 php,高德地图WEB版的使用相关推荐

  1. 百度地图web版导航

    一.首先引入所申请的ak密钥 <script type="text/javascript" src="http://wx.58haha.cn/baidu/jquer ...

  2. 百度地图Web版,根据自定义的坐标点来制作路书(行车轨迹功能)

    第一步,导入百度地图基础JS文件: <script src="http://api.map.baidu.com/api?v=2.0&ak=您的密钥"></ ...

  3. 高德地图 web android,Android 调用第三方地图类App (高德 百度 百度网页版)

    Screenshot_20170509-152819.png 前言 最近项目中需要用到地图的功能,但是应用本身不是地图类应用,而且用地图只是为了分享和展示一个地点而已,所以完全没有必要去集成厚重的sd ...

  4. vue项目H5调起高德或百度地图手机应用,或调起高德百度网页版实现导航功能(已实现)

    需求说明:H5实现唤起高德和百度地图导航到目标景点的功能 分析:用户通过点击选择使用百度还是高德地图,点击后调用guide方法,判断设备上是否有高德或者百度APP,有就直接调用APP,如果没有就调用网 ...

  5. 百度高德位置定位服务器,调用百度、高德地图App,百度地图网页版,App定位

    1.首先判断是否安装了目标地图App //判断是否安装目标应用 public static boolean isInstallByread(String packageName) { return n ...

  6. 高德地图联手中国气象局,积水地图 AI 版实时预测道路积水

    5月31日消息,高德地图今日宣布与中国气象局公共气象服务中心达成战略合作,双方将在气象预警.大数据共享等诸多方面展开深度合作.在接入了中国气象局权威和精细化的气象数据之后,高德地图可为用户提供基于位置 ...

  7. 高德地图PC版国内首发室内地图

    近日,高德地图PC版上线了室内地图功能,以往商场.交通枢纽等在地图上仅显示轮廓的地点,现在也能显示详细的室内信息了.使用此功能,用户不仅能够清晰地看到商场内的平面地图,快速找到各商铺或候车室.登机口的 ...

  8. corodva中使用高德地图web js api

    高德地图web js api有一个其他的地图插件都没有的功能,就是地图俯角可以达到80°,而其他的地图api(百度45°,mapbox60°),包括高德地图的Android sdk都无法达到这样的大角 ...

  9. 前端系列——vue2+高德地图web端开发(poi搜索两种方式)

    前端系列--vue2+高德地图web端开发(poi搜索) 前言 基础 什么是poi搜索 1. 输入提示结合poi搜索 官方代码 步骤 1.进行plugins插件注册 2.data中编写placeSea ...

最新文章

  1. 别再SOTA了,那叫“微调”!Science发文炮轰论文灌水
  2. html中绝对定位的父级,父元素相对定位,子元素绝对定位
  3. 如安装flashplayer旧版本
  4. c++用二叉树表示代数表达式_C语言:数据结构-二叉树的定义和基本术语和二叉树的性质...
  5. 04 | 负载均衡:Ribbon 如何保证微服务的高可用
  6. 2013 QConf上海软件开发大会总结
  7. 如何在 GPU 上加速数据科学
  8. jzoj3237-间谍派遣【最小生成树,并查集】
  9. 基于PHP采集数据入库程序(二)
  10. 初入C++(一) c++中的一些基础和与c的一些区别
  11. CSS三大特性的利用注意事项
  12. 基于Zephyr在微型MCU上使用Tensor Flow Lite Micro做图像分类
  13. [GRE] GRE协议介绍
  14. STL 容器迭代器失效总结(超级详细)
  15. Hadoop MapReduce篇
  16. 算法高级(22)-BCrypt加密算法,号称目前最安全的算法之一
  17. java 排队实现_Java实现排队论的原理
  18. Linux自学之MPD
  19. Game Master(思维 + 贪心)
  20. JSP页面只显示源代码不显示网页内容

热门文章

  1. java 从控制台输入一个正整数_编程输出该正整数各位数字之和_C语言 从键盘上输入一个正整数,计算并输出该数的各位数字之和...
  2. Swagger 配置多个接口文档实现 和 实现多包扫描的配置方式
  3. 使用OpenCV和Python进行人脸识别
  4. 折腾nock给jsonp进行单元测试
  5. 秃如其来第一步之安装JDK
  6. windows10 1050ti vs2015 openc3.2 cuda8.0配置自己的darknetyolov3
  7. 一文了解同态加密(Homomorphic Encryption, HE)
  8. C语言文件英文,c语言文件操作(国外英文资料).doc
  9. 【BZOJ1135】【POI2009】Lyz
  10. mac下vscode代码格式化及其他常用快捷键