当前位置: 首页 > article >正文

uniapp地图手动控制地图scale

前言

  • 首次使用uniapp开发地图过程中,发现uniapp地图居然没有提供手动控制地图scale的方法,这个也着实没有想到,查了半天资料,也终于找到一个方法能够比较好的控制scale,做个记录。

代码

  • 要定义一个地图map,还有要绑定scale
<template>
	<map id="map" :scale="mapScale" :longitude="longitude" :latitude="latitude"></map>
</template>

<script>
	export default {
		data() {
			return {
				mapScale: 16,
				longitude: '',
				latitude: '',
			}
		}
	}
</script>
  • 首先使用uni.createMapContext创建并返回 map 上下文 mapContext 对象。
mounted() {
	this._mapContext = uni.createMapContext("map", this);
}
  • 定义方法来控制手动控制scale
methods: {
	/**
	 * 
	 * @param {*} e - 坐标等信息
	 * @param {Number} val - scale级别
	 */
	async setMapScale(e, val) {
		let setScale = () => {
			return new Promise((resolve, reject) => {
				this._mapContext.getScale({
					success: r => {
						this.mapScale = r.scale;
						resolve()
					}
				})
			})
		};
		await setScale();
		this._mapContext.moveToLocation({
			longitude: e.projectLon,
			latitude: e.projectLat,
			success: (res) => {
				//这里加300ms的延时是为了防止和moveToLocation功能冲突,保留地图移动的动画
				const timer = setTimeout(() => {
					this.longitude = e.longitude;
					this.latitude = e.latitude;
					this.mapScale = val;
					clearTimeout(timer);
				}, 500);
			},
		})
	}
}
  • 然后就可以调用这个方式来实现手动控制地图scale了
  • 好,就这事,散会

http://www.kler.cn/a/131539.html

相关文章:

  • 自学ansible笔记
  • 视频一键转码:批量转换MP4视频的技巧
  • 02-2解析JsonPath
  • [Jenkins] 物理机 安装 Jenkins
  • 【Hello Go】初识Go语言
  • c语言-浅谈指针(2)
  • python爬虫 之 JavaScript 简单基础
  • OpenCV入门2——图像视频的加载与展示一些API
  • MySQL JDBC编程
  • 听GPT 讲Rust源代码--library/core/src(7)
  • 【MATLAB源码-第81期】基于matlab的polar码三种译码算法比较(SC,SCL,BP)。
  • 笔记本电脑没有声音?几招恢复声音流畅!
  • 微服务面试问题小结( 微服务、分布式、MQ、网关、zookeeper、nginx)
  • 【Vue原理解析】之虚拟DOM
  • rpmbuild 包名 version 操作系统信息部分来源 /etc/rpm/macros.dist
  • CLEARTEXT communication to XX not permitted by network security policy 报错
  • 计算机视觉:人脸识别与检测
  • GUN介绍
  • Linux(3):Linux 的文件权限与目录配置
  • Go语言常用库