高德地图点聚合及点击放大

1、使用setZoomAndCenter方法即可实现此功能,将方法放置到对应位置内。

map.setZoomAndCenter(17, XY)
image.png

2、多个高德坐标列表,求最佳放大倍数zoom及中心点
首先一些地图知识,在地图瓦片系统中,每个瓦片的尺寸通常是256x256像素。这意味着地图在水平和垂直方向上被划分为256个像素的瓦片。 在计算最佳放大级别时,我们使用WORLD_DIM来表示地球的宽度和高度。通过将地图的宽度和高度转换为地球上的度数,然后与WORLD_DIM相除,可以得到地图上每个像素对应的地球上的度数。 因此,WORLD_DIM的值为256是根据地图瓦片系统的标准尺寸而来,用于在计算中将像素值转换为地球上的度数。高德、腾讯等都使用Google的瓦片地图规范,其定义略有不同,坐标原点为东经180°、北纬85.05°,x轴向右,y轴向下,zoom level最小为0、最大为21。瓦片相关内容参考瓦片地图服务与地图瓦片原理;

在计算最佳放大级别时,将地图的宽度和高度乘以360是为了将地图的像素值转换为地球上的度数。 地球的经度范围是-180度到+180度,纬度范围是-90度到+90度。而地图的宽度和高度是以像素为单位的。 通过乘以360,我们将地图的像素值映射到地球上的度数范围。这样可以将地图的尺寸与地球上的度数进行比较,以计算最佳放大级别和中心点。 例如,如果地图的宽度是800像素,乘以360后得到288000,表示地图在水平方向上覆盖了288000度的经度范围。这样就可以将地图的尺寸与地球上的度数进行比较,从而计算出最佳放大级别和中心点。

中心点获取最大最小经纬度取平均值即可

代码如下

export const getBounds = (coordinates: [number, number][]): [number[], number[]] => {
    let minLat = Number.MAX_VALUE;
    let maxLat = Number.MIN_VALUE;
    let minLng = Number.MAX_VALUE;
    let maxLng = Number.MIN_VALUE;
 
    for (const coordinate of coordinates) {
        const lat = coordinate[0];
        const lng = coordinate[1];
        minLat = Math.min(minLat, lat);
        maxLat = Math.max(maxLat, lat);
        minLng = Math.min(minLng, lng);
        maxLng = Math.max(maxLng, lng);
    }
 
    return [[maxLat, maxLng], [minLat, minLng]];
}
 
export const getZoomLevel = (bounds: [number[], number[]], mapDim: [number, number]): number => {
    const WORLD_DIM = 256;
    const ZOOM_MAX = 21;
 
    const ne = bounds[0];
    const sw = bounds[1];
 
    const latDiff = ne[0] - sw[0];
    const lngDiff = ne[1] - sw[1];
 
    const latZoom = Math.log(mapDim[0] * 360 / latDiff / WORLD_DIM) / Math.log(2);
    const lngZoom = Math.log(mapDim[1] * 180 / lngDiff / WORLD_DIM) / Math.log(2);
    return Math.min(Math.min(latZoom, lngZoom), ZOOM_MAX);
}
 
export const getCenterPoint = (bounds: [number[], number[]]): [number, number] =>{
    const ne = bounds[0];
    const sw = bounds[1];
 
    const lat = (ne[0] + sw[0]) / 2;
    const lng = (ne[1] + sw[1]) / 2;
 
    return [lat, lng];
}
 
 
 // 示例用法
const coordinates = [
  [30.123, 120.456],
  [31.789, 121.789],
  [32.456, 122.123],
  // 添加更多坐标点
];
const bounds = getBounds(coordinates);
const mapDim = [800, 600];
const zoomLevel = getZoomLevel(bounds, mapDim);
const centerPoint = getCenterPoint(bounds);

3、点聚合示例地址
https://gitcode.com/KyleBing/map/blob/master/src/page/pointer/PointerViewer.vue?utm_source=csdn_github_accelerator&isLogin=1

csdn介绍:https://blog.csdn.net/KimBing/article/details/135507505

uniapp文档


image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342