使用高德地图绘制多边形区域

最近遇到一个需求,在网页上面编辑多边形的区域,并且需要能够判断一个点是否在这个多边形区域里面。

看了一下高德地图的jsapi,简单的做了一个demo。

1.你需要一个高德地图的账号,注册地址点击这里

2.登陆进去创建一个应用,这个时候就会给你一个对应的Key

3.查看高德地图的的demo,进入示例中心

4.学习一下左侧分类里面的 点标记 的示例,点标记里有涉及到高德地图事件,以及基础的类。

5.看完上面的,接下来我们接着学习折线,多边形,圆,这里我们就可以接触到AMap.Polygon这个类,以及高德地图提供编辑多边形的类AMap.PolyEditor

6.下面我们就要开始将上面的功能组合起来,进行高德地图多边形的编辑了

6.1 首先,我先用点标记在地图上选中3个点,组成一个最基本的多边形(三角形)

 

//用来存储3个基本点的数组 第一个存点坐标 第二个存Marker(点标记)对象
var beginPoints;
var beginMarks ;
//地图上面的click事件对象
var clickListener ;
//当前绘制的点个数,用来控制前面3个点
var beginNum;
//初始化
function init(){
        beginPoints = [];
        beginMarks = [];
        beginNum = 0;
        clickListener = AMap.event.addListener(map, "click", mapOnClick);
    }
init();
//地图上面绑定的点击事件
function mapOnClick(e) {
        // document.getElementById("lnglat").value = e.lnglat.getLng() + ‘,‘ + e.lnglat.getLat()
        beginMarks.push(addMarker(e.lnglat));
        beginPoints.push(e.lnglat);
        beginNum++;
        if(beginNum == 3){
            //处理有了3个点以后,转化为多边形的逻辑
        }
    };

// 实例化点标记
function addMarker(lnglat) {

        var marker = new AMap.Marker({
            icon: "http://webapi.amap.com/theme/v1.3/markers/n/mark_b.png",
            position: lnglat
        });
        marker.setMap(map);
        return marker;
    }

       在上面的代码里需要说一点的是,高德地图的事件绑定跟java的事件绑定有些类似 clickListener = AMap.event.addListener(map, "click", mapOnClick);

其中第一个参数是要绑定事件的对象,第二个参数是事件类型,第三个参数是对应是事件函数。取消绑定事件的方法AMap.event.removeListener(clickListener);

6.2 绘制好3个点之后,构建多边形对象,绑定对应的多边形编辑对象

//在上面的留空处,处理有了3个点以后的逻辑,继续开始
AMap.event.removeListener(clickListener);
var polygon = createPolygon(beginPoints);
polygonEditor = createEditor(polygon);
clearMarks();
//处理结束

//上面用到的几个函数
//创建一个多边形对象
function createPolygon(arr){
        var polygon = new AMap.Polygon({
            map: map,
            path: arr,
            strokeColor: "#0000ff",
            strokeOpacity: 1,
            strokeWeight: 3,
            fillColor: "#f5deb3",
            fillOpacity: 0.35
        });
        return polygon;
    }
//创建一个多边形对象的编辑类对象
function createEditor(polygon){
        var polygonEditor = new AMap.PolyEditor(map, polygon);
        polygonEditor.open();
        AMap.event.addListener(polygonEditor,‘end‘,polygonEnd);
        return polygonEditor;
    }
//编辑结束事件
function polygonEnd(res){
        resPolygon.push(res.target);
        alert(resPolygon[resNum].contains([116.386328, 39.913818]));
        appendHideHtml(resNum,res.target.getPath());

        resNum++;
        init();
    }
//将多边形路径保存到html隐藏域里
function appendHideHtml(index,arr){
        var strify = JSON.stringify(arr);
        var html = ‘<input type="hidden" id="index‘+index+‘" name="paths[]" value="‘+strify+‘">‘;
        $(‘body‘).append(html);
        console.log(html);
    }

//清除前面的3个点标记
function clearMarks(){
        map.remove(beginMarks);
}

上面的代码里需要主要的主要是 1.高德地图清除点标记,支持清除一组,按照数组清除。2.PolyEditor这个多边形编辑对象,主要使用到了open()和close()两个函数,以及end事件(当调用了close函数后触发)3.我按照多边形的次序,将他们append到html的隐藏域中,并且将id使用了index+次序的方式生成。

然后可以选择将隐藏域中的内容提交到服务器,或者做其他的处理。

下面给出一个完整的demo,希望能够给大家一点帮助~

下载点击这里

目前在做外卖领域的项目,有想合作的扫一扫吧~~~~~~~~~~

时间: 2024-10-05 04:41:02

使用高德地图绘制多边形区域的相关文章

iOS高德地图让指定区域或者点显示在屏幕中间

对于高德地图也是一个新手,很多功能看文档,问技术 或者高德群里讨论  群号:204668425 在我们需求中绘制的有 圆 折线 不规则图形 方式,打开地图指定的绘制图形置于屏幕中间 1.首先创建一个数组--  arraySpace 圆: 需要根据圆的半径 中心点计算 垂直的四个 //加入所有圆的点 //设置位置的点 CLLocationCoordinate2D destinationCoordinated =CLLocationCoordinate2DMake(latitude,longitud

如何在vue项目中使用echarts和高德地图绘制折线和热力图

1.先下载相关的依赖,这里echarts和高德地图放到一起.(高德地图需要先去申请一个key) // The Vue build version to load with the `import` command // (runtime-only or standalone) has been set in webpack.base.conf with an alias. import Vue from 'vue' import App from './App' import router fr

android高德地图绘制线 渐变处理

这个是为了实现淘宝物流轨迹的那种样式,轨迹路线是渐变色. 先说下物流轨迹实现流程. 1.高德地图3d.导航.搜索三个sdk的支持 2.通过导航获取一条路径,这个路径包含的点相当多,可能有上万个. 3.利用路径中的点划线,划线的点和导航提供的点是用的格式不一样,需要简单转换一下. 4.使用android自带的api “ArgbEvaluator”来计算每个点的颜色值. 5.把所有的颜色值放进一个数组,然后使用.colorValues(colorList).useGradient(true)这两个设

高德地图判断点的位置是否在浏览器可视区域内

业务场景如下: 1.在地图上点击企业位置mark时,地图不做缩放和移动操作(能点击mark,说明该位置肯定在可视区域内). 2.点击右侧企业列表的企业时,如果企业的位置不在当前可视区域内,就需要将地图平滑的移动到该企业位置,并且需要缩小地图,先查看到该企业位于哪个区域,再将地图放大到之前缩放的级别. 实现思路: 高德地图有几个关系判断的API:判断点是否在线上.点是否在多边形内.面与面的几何关系,可看下方链接示例 https://lbs.amap.com/api/javascript-api/e

【高德地图API】从零开始学高德JS API(三)覆盖物——标注|折线|多边形|信息窗口|聚合marker|麻点图|图片覆盖物

覆盖物,是一张地图的灵魂.有覆盖物的地图,才是完整的地图.在一张地图上,除了底层的底图(瓦片图,矢量图),控件(有功能可操作的工具),最重要最不可缺少的就是覆盖物了.覆盖物有多种,包括,标注.折线.多边形.信息窗口.聚合marker.麻点图和图片覆盖物.本文会详细介绍每一种覆盖物的概念,添加方法,修改方法,移除方法等.最后会提供示例和源代码下载. 示例demo:http://zhaoziang.com/amap/zero_3_1.html ----------------------------

百度地图实现鼠标绘制多边形并获取所有点坐标

百度地图开放平台http://lbsyun.baidu.com/ 这里使用的是Javascript API http://lbsyun.baidu.com/index.php?title=jspopular 实现鼠标绘制多边形主要用到百度地图JavaScript开源库鼠标绘制工具条库(http://lbsyun.baidu.com/index.php?title=open/library),提供鼠标绘制点.线.面.多边形(矩形.圆)的编辑工具条的开源代码库.且用户可使用JavaScript AP

MFC 用gdi绘制填充多边形区域

MFC 用gdi绘制填充多边形区域 这里的代码是实现一个三角形的绘制,并用刷子填充颜色 在OnPaint()函数里面 运用的是给定的三角形的三个点,很多个点可以绘制多边形 [cpp] view plaincopy CBrush br(RGB(40,130,170)); CRgn rgn; CPoint arrpt[3]; arrpt[0].x = m_rcAT.right-8; arrpt[0].y = m_rcAT.top+m_rcAT.Height()*2/5; arrpt[1].x = a

高德地图获取道路接口、并将道路绘制

目标 :需要通过路的名字,将道路在地图中绘制出. 查找路的信息 通过路名搜索路 http://restapi.amap.com/v3/road/roadname?key=yourkey&keywords=靖江路&city=022 参数名称 参数含义 key 高德API 申请的key keywords 路名称 city 城市citycode 下载地址见参考文献 通过路id搜索路 http://restapi.amap.com/v3/road/roadid?city=020&key=y

【高德地图API】从零开始学高德JS API(四)搜索服务

摘要:地图服务,大家能想到哪些?POI搜素,输入提示,地址解析,公交导航,驾车导航,步行导航,道路查询(交叉口),行政区划等等.如果说覆盖物Marker是地图的骨骼,那么服务,就是地图的气血.有个各种各样的地图服务,我们的地图应用才能变得有血有肉,活灵活现.第四篇拆成了几个要点,本篇主要讲搜索服务.包括周边搜索,关键词搜索,范围搜索,搜索提示(自动完成,输入提示),行政区域,交叉路口,检索自有数据(云图). demo:http://zhaoziang.com/amap/zero_4_1.html