【移动端】Flutter 自定义高德地图比例尺

背景

因为高德地图本身的比例尺是默认只能在左下角展示,且样式不能调整,所以在实际开发中会有自定义比例尺的需求

通过阅读源码和开发文档会发现,针对Flutter ,高德地图并未开放自定义比例尺的接口

分析

通过阅读源码和AMap Android SDK源发现,在AMap类中存在getScalePerPixel方法可以获取比例尺数据,所以现在需要解决的是获取AMap类的实例,获取方法可以参考上篇文章:

【移动端】Flutter 获取Android AMap实例

获取后的问题的来了,就是计算比例尺数据,终端设备屏幕的像素一般分为物理像素和逻辑像素,阅读源码会发现getScalePerPixel获取的实际是逻辑像素,所以下面需要计算逻辑像素

比如计算1cm下设备对应的逻辑像素值:

  1. 获取像素比也就是PDI

PDI:表示1逻辑像素对应多少物理像素

dart 复制代码
double pixelRatio = View.of(context).devicePixelRatio;
  1. 获取物理像素值:
dart 复制代码
Size physicalSize = View.of(context).physicalSize;
  1. 计算1cm对应的逻辑像素值:

2.54 : 代表1英寸,1英寸等于2.54厘米

所以这里需要计算1cm的物理像素值,然后再除于PDI就等于1cm下的逻辑像素值

dart 复制代码
double pixelsPerCentimeter =
        physicalSize.width / 2.54 / pixelRatio * centimeters;

注意

  1. getScalePerPixel`` 获取的单位是m/px`,像素是逻辑像素
相关推荐
恋猫de小郭1 天前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
恋猫de小郭1 天前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
程序员老刘4 天前
跨平台开发地图 | 2026年6月
flutter·ai编程·客户端
悟空瞎说5 天前
Flutter 架构详解:新手必懂底层原理
flutter
SoaringHeart5 天前
Flutter最佳实践:IM聊天文字链接自动识别跳转
前端·flutter
恋猫de小郭5 天前
KMP / CMP 鸿蒙版本 Beta 发布,他有什么特别之处?
android·前端·flutter
风华圆舞6 天前
Flutter + 鸿蒙 Intents Kit:页面直达能力的完整接入方案
flutter·ui·华为·harmonyos
韩曙亮6 天前
【Flutter】Flutter 组件 ④ ( 组件渲染 的 三棵树理论 | Widget 树 → Element 树 → RenderObject 树 )
flutter·element·widget·renderobject
恋猫de小郭6 天前
Android 17 正式版发布,全新 AI 和各种破坏性更新
android·前端·flutter
kingbal6 天前
Windows:flutter环境搭建
windows·flutter