这篇文章主要介绍了关于高德地图WEB版基础控件的展示,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

最近学习了一下高德地图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代码:

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

在js第一行引入高德地图API中,key值是我自己在高德地图里面创建的也可以用,你们也可以上高德开放平台自行申请key值试一试。

高德开放平台:developer.amap.com/

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

高德地图完整功能的html,关于高德地图WEB版基础控件的展示相关推荐

  1. 高德地图完整功能的html,揭秘高德地图八大不为人知的强大功能

    高德地图作为国内车主使用最多的手机地图,在日常扮演着为用户搜索地点.规划线路.躲避拥堵等等"出行服务小帮手"的重要角色.其实,作为国内领先的数字地图内容.导航和位置服务提供商高德的 ...

  2. 高德地图基础控件使用 搜索定位等

    首先使用高德地图api需要去官网申请 key ,跟着官网过流程就好,不多赘述 直接引入,使用申请好的key <script type="text/javascript" sr ...

  3. 文件的上传下载功能的实现(包括进度条)[telerik控件]

    文件的上传下载功能的实现(包括进度条) 1.准备工作 首先我们需要Telerik控件,数据库,上传文件文件夹. Telerik控件: RadUpload.RadProgressManager.RadP ...

  4. 04 在地图上添加主页、定位、鹰眼图和比例尺控件

    在上一篇文章中我们学习了如何创建一个简单的地图,那接下来,我们学习如何给创建好的地图上添加一些基本的空间,最终效果如下图所示: 由上图可以看出,我们在地图上添加了主页.定位.鹰眼图以及比例尺控件,下面 ...

  5. vue 高德地图搜索功能_VUE中使用高德地图做轨迹添加功能,帮助轨迹展示

    准备工作 使用前准备 : 高德地图key 使用插件: vue-amap 1.npm安装vue-amap npm install vue-amap --save import AMap from 'vu ...

  6. ECharts 绘制全国地图完整示例,类似全国疫情地图

    先来看下效果图 下面开始代码,其实很简单,引入地图js,然后模拟数据,加载数据.完整的代码,我放到文末了,大家按需下下载哈 1.首先导入echarts.min.js ,然后导入china.js < ...

  7. java中图的封装,模拟java 中地图的功能封装一个有序的地图

    map模型: /** * Project Name:psim * File Name:MapModel.java * Package Name:com.psim.bean * Date:2014年5月 ...

  8. 【高德地图API】从零开始学高德JS API(二)地图控件与插件——测距、圆形编辑器、鼠标工具、地图类型切换、鹰眼鱼骨

    无论是控件还是插件,都是在一级API接口的基础上,进行二次开发,封装的一系列更加便于开发者使用,减少开发者工作量的二级API接口.除了官方通用的鱼骨.鹰眼控件,还有大量官方开发的地图插件,类似谷歌的l ...

  9. 高德 php,高德地图WEB版的使用

    最近学习了一下高德地图web版的使用,总结了一下高德基础控件的应用,高德地图是开源可编辑的,方法不是很难,有兴趣的朋友可以试一试自己编辑一下. 之前想自己做一个旅游导航的项目,在网上一搜发现了高德地图 ...

  10. 调用百度地图api实现地图查询功能

    百度地图api功能强大,进入百度地图api平台之后首先需要注册申请一个ak码(其实就是权限码),通过审核之后就可以参考api提供的例子进行自定义的地图开发功能了. 在这里提供两个本人写好的地图查询功能 ...

最新文章

  1. Lesson 021 —— python 循环语句
  2. python numpy:array、asarray、asanyarray的区别
  3. iOS开发之检查更新
  4. 文献记录(part1)--NP-hardness of Euclidean sum-of-squares clustering
  5. springboot ---- sts如何启动两个实例
  6. 8种方法解决vue创建项目报错:command failed: npm install --loglevel error
  7. python 商城api编写_Python实现简单的API接口
  8. python修改word_Python自动化修改word实例
  9. 在Vue中使用Echarts可视化库的完整步骤记录
  10. linux中文语音合成,Linux系统下高质量(微软)中、英文语音合成TTS的安装
  11. PHP后台数据处理及与web端进行数据交互
  12. war包的解压和打包为原来的war包的方法
  13. 省市区随机获取 java_随机获取省市区-Groovy
  14. Java分别获取指定日期的年月日
  15. 用centos搭建一个简单的求生之路2服务器(用于好友联机降低延迟,不包含插件)
  16. 一个故事,让你一生不再生气
  17. 新一代PHP MYSQL DREAMWEAVER网站建设典型案例pdf
  18. 阿里云轻量级服务器搭建博客网站教程(入门级别搭建)
  19. cs七龙珠怎么添加机器人_七龙珠CS怎么调机器人的难度,如题```!!
  20. java抽奖random,java抽奖概率,java抽奖

热门文章

  1. 360随身wifi无线网卡linux,360随身wifi2代驱动,当usb无线网卡使用
  2. MySql 操作时间
  3. 上海内推 | 微软亚洲研究院上海人工智能组招聘深度学习研究实习生
  4. decode,encode的用法
  5. 计算机病毒模块测试题,计算机病毒分类测试题集
  6. 致敬达叔 -- 80、90的童年观影记忆
  7. 通过Python获取维基百科中概念词条的维基信息
  8. 国内资深安全专家详谈网页***
  9. 树莓派2B使用360随身WiFi2代连接WiFi
  10. 百度指数 自助采集 爬取 抓取 导出 提取 下载 查询