uniapp地图手动控制地图scale

前言

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

代码

  • 要定义一个地图map,还有要绑定scale
html 复制代码
<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 对象。
js 复制代码
mounted() {
	this._mapContext = uni.createMapContext("map", this);
}
  • 定义方法来控制手动控制scale
js 复制代码
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了
  • 好,就这事,散会
相关推荐
liu_bees8 分钟前
微信小程序Canvas生成图片失败:canvas is empty问题解析
微信小程序·小程序·uni-app·vue
共享家952716 分钟前
基于 Coze 工作流搭建历史主题图片生成器
前端·人工智能·js
zhaoyin199417 分钟前
fiddler抓包工具使用
前端·测试工具·fiddler
微祎_19 分钟前
Flutter for OpenHarmony:构建一个 Flutter 单词拼图游戏,深入解析状态驱动 UI、交互式字母操作与教育类应用设计
javascript·flutter·ui
摘星编程30 分钟前
用React Native开发OpenHarmony应用:ProgressBar缓冲进度显示
javascript·react native·react.js
人机与认知实验室32 分钟前
<span class=“js_title_inner“>如何看待特斯拉第三代Optimus机器人?</span>
开发语言·javascript·机器人·ecmascript·unix
Doris89335 分钟前
【 Vue】 Vue3全面讲解文档
前端·javascript·vue.js
换日线°36 分钟前
vue 实现Element Plus的炫酷主题切换
javascript·vue.js
linweidong42 分钟前
大厂工程化实践:如何构建可运维、高稳定性的 Flutter 混合体系
javascript·flutter
木子啊44 分钟前
Uni-app性能优化:分包与长列表实战
性能优化·uni-app