高德地图面积测量小工具

article/2025/9/20 15:55:37

 

由于项目的需要,需要用到高德地图的测量面积功能,其实高德地图官方已经提供了测量面积的工具,但是感觉有点不太方便,于是在原来的测量面积工具的基础上进行一点补充,由于时间的原因,写的比较粗糙,其实有很多值得改进的地方,不过不影响使用。

先来看看高德地图官方测量面积的实现效果:

使用AMap.MouseTool插件的measureArea方法来实现面积测量,测量结束后,如果想要关闭面积测量,需要使用 mouseTool.close()方法关闭。

我想要的效果是在地图上绘制的多边形区域上提供一个关闭按钮,点击关闭按钮结束面积测量,于是,在原来的测量面积的基础上加入了关闭按钮。下面来看效果:

 

点击关闭按钮,则关闭面积测量,多边形从地图上移除。

代码如下:

measureArea.html

<!doctype html>
<html lang="en">
<head><meta charset="utf-8"><meta http-equiv="X-UA-Compatible" content="chrome=1"><meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width"><link rel="stylesheet" href="https://a.amap.com/jsapi_demos/static/demo-center/css/demo-center.css" type="text/css"><style>html,body,#container{height: 100%}.btn{width: 6rem;margin: 0 1rem 0 4.5rem;}</style><title>鼠标工具-面积测量</title>
</head>
<body>
<div id='container'></div>
<div class="input-card" style='width: 12rem;'><input type="button" name='func' id="area" value='面积测量'>
</div>
<script src="https://webapi.amap.com/maps?v=1.4.10&key=您申请的key值&plugin=AMap.MouseTool"></script>
<script src="mathUtil.js"></script>
<script src="measureAreaUtil.js"></script><script type="text/javascript">var map = new AMap.Map('container',{zoom:15});var measureAreaTool = new MeasureAreaTool(map);var area = document.getElementById('area');area.onclick = function(e){measureAreaTool.measureArea();}
</script>
</body>
</html>

measureAreaUtil.js

//测面积工具
var MeasureAreaTool = function(map){var obj = new Object();obj.map = map;obj.areaOptions = {polygonOptions:{strokeColor:'#00ddff',fillColor:'#FFAA00',fillOpacity:0.3},textOptions:{offset:new AMap.Pixel(9,-9),zIndex:120},markerOptions:{icon:"https://webapi.amap.com/images/destroy.png",zIndex:120,title:"关闭面积测算",offset:new AMap.Pixel(-50,-16)}};obj.mouseTool = new AMap.MouseTool(obj.map);obj.mouseTool.measureAreaTool = obj;obj.mouseTool.on("draw",function(e){this.close(true)//关闭,并清除覆盖物var polygonPath = e.obj.getPath();if(polygonPath!=undefined&&polygonPath.length>0){var area = AMap.GeometryUtil.ringArea(polygonPath);area = BJMath.keepTwoDecimal(area/1000000);var tip = area + "平方公里";var polygon = new AMap.Polygon(this.measureAreaTool.areaOptions.polygonOptions);polygon.setPath(polygonPath);polygon.setMap(this.measureAreaTool.map);var point = polygonPath[0];//添加关闭按钮var marker = new AMap.Marker(this.measureAreaTool.areaOptions.markerOptions);marker.setPosition(point);marker.setMap(this.measureAreaTool.map);//添加文字标注var textObj = new AMap.Text(this.measureAreaTool.areaOptions.textOptions);textObj.setText(tip);textObj.setPosition(point);textObj.setStyle({"font-size":"12px"});textObj.setMap(this.measureAreaTool.map);marker.polygon = polygon;marker.textObj = textObj;marker.on("click",function (e) {var p = e.target.polygon;var t = e.target.textObj;marker.getMap().remove([p,t,e.target]);});}});obj.measureArea = function(){this.mouseTool.measureArea(this.areaOptions.polygonOptions);}return obj;
}

mathUtil.js

/*** 数学工具类* @type {{keepTwoDecimal: BJMath.keepTwoDecimal, keepTwoDecimalFull: BJMath.keepTwoDecimalFull}}*/
var BJMath = {keepTwoDecimal: //四舍五入保留2位小数(若第二位小数为0,则保留一位小数)function(num) {var result = parseFloat(num);if (isNaN(result)) {alert('传递参数错误,请检查!');return false;}result = Math.round(num * 100) / 100;return result;},keepTwoDecimalFull://四舍五入保留2位小数(不够位数,则用0替补)function(num) {var result = parseFloat(num);if (isNaN(result)) {alert('传递参数错误,请检查!');return false;}result = Math.round(num * 100) / 100;var s_x = result.toString();var pos_decimal = s_x.indexOf('.');if (pos_decimal < 0) {pos_decimal = s_x.length;s_x += '.';}while (s_x.length <= pos_decimal + 2) {s_x += '0';}return s_x;}
};

源码下载地址:

https://download.csdn.net/download/hgq0916/10688072

 

 


http://chatgpt.dhexx.cn/article/T8JbuROq.shtml

相关文章

国土面积测量问题

国土面积测量问题 如图所示一个国家的地图边界线&#xff0c;有关方面需确认国家的国土面积的数值。现在将地图放入平面直角坐标系中&#xff0c;以由西向东方向为 x 轴&#xff0c;由南向北方向为 y 轴&#xff0c;在边界上选取若干 点测出个点对应的坐标数据&#xff08;?,…

cesium面积测量

使用方法新建一个文件measureArea.js将下面代码贴上去 // DrawPolygon /* 绘制面(面积测量)*/class measureArea {constructor(arg) {this.objId Number(new Date().getTime() "" Number(Math.random() * 1000).toFixed(0));this.viewer arg.viewer;this.Cesium…

CAD快速测量面积与周长

这篇来教大家如何用CAD梦想画图快速测出规则图形与不规则图形的面积&#xff0c;首先这些图形都需要是封闭图形。 操作工具 操作系统&#xff1a;Windows10 CAD软件&#xff1a;CAD梦想画图 步骤 1.首先我们画一个规则的矩形与一个用多边形绘制的不规则封闭图形&#xff0…

openlayers测距和测面积

初次使用openlayers地图进行开发各种地图功能,测距和测面积使用的是官方例子并进行了一些简单的修改,官方示例在测量一次之后不能停止,修改后,每点击测量,只会测量一次。 而且需要注意的是,官方例子测距测面积使用的投影坐标系是3857。 js文件:measure.js import Draw…

手机测量面积的软件哪个好用?这些软件你值得收藏

相信大家在日常生活中总会遇到测量的问题&#xff0c;如果身边有测量工具还好&#xff0c;就怕恰好身边没有测量的工具&#xff0c;那就麻烦了。那有没有什么快捷的方法能够让我们迅速获得测量数据呢&#xff1f; 其实&#xff0c;现在市面上有很多面积测量软件&#xff0c;能…

cesium 实现测距离测面积 (划线画面 跟随鼠标位置 )

效果图 方法一&#xff1a;使用插件 cesium_measure.js 下载地址&#xff1a;https://github.com/zhangti0708/cesium-measure/blob/master/src/cesium-measure.js <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"&g…

平方面积怎么测量?教你快速学会这个方法

平方面积怎么测量&#xff1f;我们平常可能很少会需要测量平方面积的&#xff0c;但是当我们装修屋子的时候&#xff0c;不可避免地需要计算各种物品的面积。只有精准的计算&#xff0c;才能减少不必要的浪费。我们可以手工测量&#xff0c;然后进行计算。我们也可以借助手机上…

QML QtLocation地图应用学习-3:实现面积测量

1.实现思路 参照网上的测面积功能&#xff0c;界面效果和测距差不多&#xff0c;在点和线的基础上多了一个填充区域。 点和线参照上一篇博客&#xff1a;https://blog.csdn.net/gongjianbo1992/article/details/103674047 填充区域使用 MapPolygon &#xff0c;但是这个类接口…

手机怎么测量物品面积?测试原理是什么?

在我们的日常生活中&#xff0c;我们常常需要测量物品的面积&#xff0c;比如房间的面积、墙壁的面积、家具的面积等等。传统的测量方法需要使用量尺或计算公式&#xff0c;不仅繁琐而且容易出现误差。而现在&#xff0c;我们可以利用手机的功能来快速、准确地测量物品的面积。…

NMF(非负矩阵分解)

NMF 1.算法概述2. 损失函数python代码 1.算法概述 NMF(Non-negative matrix factorization)&#xff0c;即对于任意给定的一个非负矩阵V&#xff0c;其能够寻找到一个非负矩阵W和一个非负矩阵H&#xff0c;满足条件VW*H,从而将一个非负的矩阵分解为左右两个非负矩阵的乘积。 …

CAUCHY NMF FOR HYPERSPECTRAL UNMIXING

J. Peng, F. Jiang, W. Sun and Y. Zhou, "Cauchy NMF for Hyperspectral Unmixing," IGARSS 2020 - 2020 IEEE International Geoscience and Remote Sensing Symposium, 2020, pp. 2384-2387, doi: 10.1109/IGARSS39084.2020.9323950. 摘要&#xff1a; 非负矩阵…

【降维之NMF】NMF(非负矩阵分解)实例

数据介绍&#xff1a;NMF人脸数据特征提取目标&#xff1a;已知 Olivetti 人脸数据共400个&#xff0c;每个数据是 64*64 大小。由于NMF分解得到的 W 矩阵相当于从原始矩阵中提取的特征&#xff0c;那么就可以使用NMF对400个人脸数据进行特征提取。 NMF 非负矩阵分解是在矩阵中…

ADMM求解优化NMF

本文拟对文章&#xff1a;“An Alternating Direction Algorithm for Matrix Completion with Nonnegative Factors”中利用ADMM进行非负矩阵分解部分进行推导。 他的 augmented Lagrangian 可写成如下形式&#xff1a; (1) (1)优化W (2)优化H: &#xff08;3&#xff09;优化…

NMF降维算法与聚类模型的综合运用

NMF降维算法与聚类模型的综合运用 前言一&#xff1a;NMF算法二&#xff1a;NMF算法的使用三&#xff1a;NMF算法与层次聚类的综合使用四&#xff1a;总结 前言 这一章&#xff0c;我们讨论下另一个比较有效的降维手段&#xff1a;NMF&#xff08;非负矩阵分解&#xff09;。N…

NMF(非负矩阵分解)分子分型

<~生~信~交~流~与~合~作~请~关~注~公~众~号生信探索> Non-Negative Matrix Factorization (NMF). Find two non-negative matrices, i.e. matrices with all non-negative elements, (W, H) whose product approximates the non-negative matrix X. This factorization c…

LSA、pLSA、LDA、NMF、BERTopic、Top2Vec进行主题建模

在自然语言处理(NLP)中,主题建模是一种技术,用于从文本数据中发现隐藏的语义主题(或主题)。这是一个无监督机器学习问题,即在没有标签或标签的情况下学习模式。主题建模的应用非常广泛,可用于搜索引擎、情感分析、新闻聚类和摘要生成等许多任务。 在这里将探讨主题建模…

NMF通俗理解及python实现

一、通俗理解概念 NMF(Non-negative matrix factorization)&#xff0c;即对于任意给定的一个非负矩阵 V&#xff0c;其能够寻找到一个非负矩阵 W 和一个非负矩阵 H&#xff0c;满足条件 V W H VW \times H VWH&#xff0c;即将一个非负的矩阵分解为左右两个非负矩阵的乘积…

NMF-CC

题目&#xff1a;Multi-view clustering by non-negative matrix factorization with co-orthogonal constraints 一、创新点 和其他使用NMF的方法一样&#xff0c;这篇文章也是加约束&#xff0c;使创造出来的representation matrices更好。这篇文章加的约束叫做co-orthogon…

用python实现NMF降维

非负矩阵分解(Non-negative Matrix Factorization) NMF简介 NMF用于文本降维 NMF的可解释性 NMF用于归纳单篇文章主题 NMF用于推荐多篇相似文章 NMF简介 NMF也是一种降维方法&#xff0c;相比PCA具有以下特点&#xff1a; 1&#xff0c;可解释性 2&#xff0c;可以用于所…

nmf java_NMF pLSA

今天在围脖中看到自动化所刘康的围脖中给了一个关于NMF和pLSA对比分析的链接http://ezcodesample.com/plsaidiots/NMFPLSA.html&#xff0c;大体读了一下&#xff0c;下面用中文对文中的思想重新解释&#xff0c;版权归原作者Andrew Polar。 一、名词解释 (1)NMF, nonnegative …