项目中提出在地图上绘制面并获取面积,如何实现?
在天地图官网的JavaScript API 中,链接如下:
能看到Polygon并没有提供测量面的工具,这里需要使用polygonTool类。
一、初始化地图
map = new T.Map('mapDiv',);
// var lnglat = new T.LngLat(jshjData[0].lng,jshjData[0].lat)
var lnglat = new T.LngLat(115.79251,28.93511)
// var lnglat = new T.LngLat(80.41150304634095,80.44935513895808)
map.centerAndZoom(lnglat,17);
//隐藏天地图Logo
document.getElementsByClassName("tdt-control-copyright tdt-control")[0].style.display = 'none';
二、创建polygonTool
//开始绘制
function startDraw(isToolArea) {
if (handler){
handler.close();
}
if (isToolArea){
var config = {
showLabel: true,
color: "blue", weight: 3, opacity: 0.5, fillColor: "#FFFFFF", fillOpacity: 0.5
};
//创建标注工具对象
handler = new T.PolygonTool(map, config);
}else {
handler = new T.PolygonTool(map);
}
handler.open();
//长按结束事件
handler.addEventListener('draw', ()=>{
dataList = handler.getPolygons()[0].ht[0];
//绘制完成后获取绘制面的坐标点
console.log(dataList);
//获取绘制面的面积
console.log(handler.getArea(dataList))
});
}
运行结果:
双击结束,控制台打印面积:
三、多边形获取面积
polygonTool是用鼠标绘制的多边形,用handler.getArea(arrays) ,其中arrays是多边形每个点的经纬度组成的数组,就可以获取到已知经纬度的面积。代码如下:
function addPolygonGetAreaFn(){
//polyon不能直接测量面积,需要初始化标注工具。
var config = {
showLabel: true,
color: "blue", weight: 3, opacity: 0.5, fillColor: "#FFFFFF", fillOpacity: 0.5
};
//创建标注工具对象
handler = new T.PolygonTool(map, config);
//添加面
let array = [
{lat: 28.93556, lng: 115.79179},
{lat: 28.93445, lng: 115.79303},
{lat: 28.93401, lng: 115.79102}
];
var points = [];
array.forEach((v,k)=>{
points.push(new T.LngLat(v.lng,v.lat));
})
//创建面对象
polygon = new T.Polygon(points,{
color: "blue", weight: 3, opacity: 0.5, fillColor: "#FFFFFF", fillOpacity: 0.5
});
//向地图上添加面
map.addOverLay(polygon);
//获取面积
console.log(handler.getArea(polygon.getLngLats()[0]))
}
四、完整代码(包括添加点、添加面、编辑面、获取面积)
其中jquery.min.js需要引用本地或者线上,如
其二,密钥需要在天地图官网进行申请。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script type="text/javascript" src="../../js/jquery.min.js"></script>
<script type="text/javascript" src="https://api.tianditu.gov.cn/api?v=4.0&tk=您的密钥"></script>
<style>
.page{
width: 100%;
height: 100vh;
display: flex;
}
.page #mapDiv{
width: 70%;
height: 70%;
}
.page .buttonCon{
margin-left: 50px;
}
.page .buttonCon .button{
font-size: 18px;
padding: 7px 15px;
border: 1px solid #4bacee;
border-radius: 10px;
margin-bottom: 30px;
cursor: pointer;
}
</style>
</head>
<body>
<div class="page">
<div id="mapDiv"></div>
<div class="buttonCon">
<div class="button" onclick="addPolygonGetAreaFn()">添加面</div>
<div class="button" onclick="startDraw(false)">绘制面(不带面积)</div>
<div class="button" onclick="startDraw(true)">绘制面(带面积)</div>
<div class="button editButton" onclick="editPolygonFn()">编辑绘制面</div>
<div class="button" onclick="getPolygonFn()">获取面的坐标点</div>
<div class="button addButton" onclick="addMarker()">增加点</div>
<div class="button editButton" onclick="editMarker()" style="display: none">修改点</div>
</div>
</div>
<script>
var map;
var polygon;
var handler;
//绘制面的坐标点集合
var dataList;
getMap()
//地图
function getMap(){
// map=new T.Map('mapDiv');
var lay;
//初始化地图对象
map = new T.Map('mapDiv');
// var lnglat = new T.LngLat(jshjData[0].lng,jshjData[0].lat)
var lnglat = new T.LngLat(115.79251,28.93511)
// var lnglat = new T.LngLat(80.41150304634095,80.44935513895808)
map.centerAndZoom(lnglat,17);
document.getElementsByClassName("tdt-control-copyright tdt-control")[0].style.display = 'none';
}
//地图点击事件
map.addEventListener("click",function (e){
// console.log(e)
});
//添加面
function addPolygonFn(pointsArr){
// var points = [];
// pointsArr.forEach((v,k)=>{
// points.push(new T.LngLat(v.lng,v.lat));
//
// })
// //创建面对象
// plygon = new T.Polygon(points,{
// color: "blue", weight: 3, opacity: 0.5, fillColor: "#FFFFFF", fillOpacity: 0.5
// });
//
// //向地图上添加面
// map.addOverLay(polygon);
var points = [];
// points.push(new T.LngLat(116.41136, 39.97569));
// points.push(new T.LngLat(116.411794, 39.9068));
// points.push(new T.LngLat(116.32969, 39.92940));
**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**
**深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**
**因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。**
![img](https://img-blog.csdnimg.cn/img_convert/4a340a363834717161d0c48c15aa2570.jpeg)
![img](https://img-blog.csdnimg.cn/img_convert/3ea261bf54b721cc9503c4c97be27b75.png)
![img](https://img-blog.csdnimg.cn/img_convert/8a8b80f95fde53258bff629abd275418.png)
![img](https://img-blog.csdnimg.cn/img_convert/dff3d5aa1d1a14a9311c13b3105775f9.png)
![img](https://img-blog.csdnimg.cn/img_convert/c504099777f2e5bab49be987a3876dc3.png)
![img](https://img-blog.csdnimg.cn/img_convert/7747f2e612659a422e38d6a074cd5537.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!**
**由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新**
**如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)**
![img](https://img-blog.csdnimg.cn/img_convert/db714bb75455a849e0d21fb405341f6b.png)
### 最后
基础知识是前端一面必问的,如果你在基础知识这一块翻车了,就算你框架玩的再6,webpack、git、node学习的再好也无济于事,因为对方就不会再给你展示的机会,千万不要因为基础错过了自己心怡的公司。前端的基础知识杂且多,并不是理解就ok了,有些是真的要去记。当然了我们是牛x的前端工程师,每天像背英语单词一样去背知识点就没必要了,只要平时工作中多注意总结,面试前端刷下题目就可以了。
**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
![img](https://img-blog.csdnimg.cn/img_convert/1f2d3a65f899f34aa0cad6a9cecec3c9.png)
于事,因为对方就不会再给你展示的机会,千万不要因为基础错过了自己心怡的公司。前端的基础知识杂且多,并不是理解就ok了,有些是真的要去记。当然了我们是牛x的前端工程师,每天像背英语单词一样去背知识点就没必要了,只要平时工作中多注意总结,面试前端刷下题目就可以了。
**一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**
[外链图片转存中...(img-2mmqDXoI-1712947812229)]