天地图如何获取多边形面积(3),最新阿里Web前端高级面试题及答案

一、初始化地图

二、创建polygonTool

三、多边形获取面积

​四、完整代码(包括添加点、添加面、编辑面、获取面积)


项目中提出在地图上绘制面并获取面积,如何实现?

在天地图官网的JavaScript API 中,链接如下:

天地图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)]

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值