之前想自己做一个旅游导航的项目,在网上一搜发现了高德地图开放平台,发现原来高德可以很简单的就应用到自己的项目里面,当即我就申请了一个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.homeControlDiv = function(){}

AMap.homeControlDiv.prototype = {

addTo: function(map, dom){

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

},

_getHtmlDom:function(map){

this.map=map;

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

容器

controlUI = document.createElement("DIV");

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(homeControlDiv,"hide");

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

controlUI.style.display = 'none';

})

function myControl(){

homeControl = new AMap.homeControlDiv(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值试一试。

这里是本效果图源码下载地址,感兴趣的朋友可以直接下载

html页面嵌入高德地图,高德地图WEB版基础控件展示相关推荐

  1. 百度地图JavaScript API 学习之添加控件

    创建地图之添加控件 官方demo示例和讲解--直戳这里 这个案例就比较简单了,只需要在地图展示的基础上,添加一些与地图控件相关的代码就行了. 说明: 1.可以使用Map.addControl()方法向 ...

  2. 百度地图 添加工具条、比例尺控件

    百度地图 添加工具条.比例尺控件 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-T ...

  3. asp.net控件页面交互_ASP.NET Web窗体用户控件的基本交互

    asp.net控件页面交互 I saw a recent question regarding .NET - Render User Control Logo on Postback and deci ...

  4. 自己开发基于Web的打印控件,真正免费不是共享

    1.1.0.121 版的控件,更新如下 SetPrintBackground 已被取消          SetMediaHeader        去掉了两个参数,见被划掉的文字部分 在做项目中发现 ...

  5. repeater控件 php,Web Forms - Repeater 控件

    Web Forms - Repeater 控件 Repeater 控件用于显示被绑定在该控件上的项目的重复列表. 绑定 DataSet 到 Repeater 控件 Repeater 控件用于显示被绑定 ...

  6. ATGrid WEB报表打印控件/MIS报表控件

    ATGrid WEB报表打印控件/MIS报表控件 ATGrid报表控件/WEB插件[专业版],对EtCell进行了进行了全面的改革, 将会彻彻底底的解决你的报表问题,让你开发达到从未有过的轻松和喜悦- ...

  7. 判断手机是否弹出键盘,改变了手机页面高度,对应inputStatus的状态改变相关控件的大小和位置

    inputResizeBodyHeight() {// 判断手机是否弹出键盘,改变了手机页面高度,对应inputStatus的状态改变相关控件的大小和位置var oldHeight =document ...

  8. Android:基础控件按键文本框输入框制作登录页面

    基础控件之Button,TextView,EditText,ImageView Button:按键 TextView:文本框 EditText:输入框 ImageView:图片 那我们新建一个工程研究 ...

  9. web元件库、axure元件库、元件库、web组件、控件、表单、框架、数据表单、导航栏、边框、图标、列表、日期时间选择器、评分组件、穿梭框、输入框、步骤条、图表组件、数据可视化、后台模板、时间轴

    web元件库.axure元件库.通用元件库.web组件.控件.表单.框架.数据表单.导航栏.边框.图标.列表.日期时间选择器.评分组件.穿梭框.输入框.步骤条.图表组件.数据可视化.后台模板.时间轴. ...

  10. 无法下载安装Project Web Access ActiveX 控件

    在访问Project Web Access 的时候,若访问项目中心,或者资源中心等,均需要下载相关ActiveX控件,由于IE配置的各不相同,有时可能导致ActiveX控件,无法下载安装.    通常 ...

最新文章

  1. 异常详细信息: System.Web.HttpException: 请求在此上下文中不可用
  2. 手动为 SAP Spartacus 添加 SSR 支持的步骤
  3. 计算机网络【三】物理层数据通信
  4. 国科大prml--SVM
  5. OpenMetric与时序数据库模型之主流TSDB分析
  6. 处理PHP字符串的10个简单方法
  7. 【吴恩达机器学习】学习笔记——1.3机器学习的定义
  8. 拜登重安全,白宫埋彩蛋:Coder,我们需要帮助!
  9. Django路由控制
  10. 《Python游戏编程快速上手》一第1章 安装Python
  11. malloc 初始化_C++核心准则NR.5:不要使用两阶段初始化
  12. elasticsearch 集群
  13. 2021年安全员-C证(安徽省)考试试卷及安全员-C证(安徽省)试题及解析
  14. js运算符优先级速查表
  15. PyTorch中文教程 | (1) PyTorch深度学习极速入门
  16. CAJ浏览器看论文如何设置背景为护眼色
  17. 一点感悟: 詹姆斯与全栈工程师
  18. 怎样将vob格式转换成avi高清视频格式
  19. thinkpad e450c蓝牙重新安装后不能搜索到手机解决方案--适用大部分笔记本
  20. 淘宝官方商品详情接口

热门文章

  1. IIS网站中下载.bat文件
  2. Python模块和包的导入
  3. Open3DCGAL DTM(数字地形模型)
  4. (第二版)零基础入门Python小甲鱼-笔记-第一章-p2
  5. 【计算机网络】物理层
  6. QQ连连看外挂源代码
  7. ArcGIS ERROR 999999: 执行函数时出错,未找到表。
  8. java excel 创建控件_Java 添加、删除Excel表单控件
  9. FPGA(3)--VHDL及原理图--4位全加器
  10. python获取图片长宽高,Python获取图片的大小/尺寸