小程序map地图点击makert放大效果和点击放大地图

WXML文件和JS文件代码在下方

1
2
3
4
5
6
7
8
9
10
<view class='map'>
  <map
  id="map"
  longitude="{{location.lng}}"
  latitude="{{location.lat}}"
  scale="{{scaleCount}}"
  markers="{{markers}}"
  bindmarkertap="markertap"
></map>
</view>
1
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
Page({
 
  /**
   * 页面的初始数据
   */
  data: {
    scaleCount:12,
    markers: [],
    location: "",
  },
 
 markertap: function (e) {
    var _this = this;
    var markerId = e.markerId;
    
    var model =  _this.data.mapData.filter( t=> t.pileMapId == markerId)[0];
    var markerIndex =  _this.data.markers.findIndex( t=> t.id == markerId);
 
    //这里本人设置了最大不能超过14的缩放
    if (_this.data.scaleCount >= 12 && _this.data.scaleCount < 14) {
      var location = {lat:model.latitude,lng:model.longitude};
      _this.setData({
        location:location
      }); //这里是设置点击makert的坐标,定到这里去
      _this.setData({
        scaleCount:_this.data.scaleCount+1 //每次缩放+1
      })
      return;//如果超过就return
    }
    //这里是设置点击makert点击图片变大突出效果
    var markersWidth= `markers[${markerIndex}].width`;
    var markersHeight= `markers[${markerIndex}].height`;
    _this.setData({
      [markersWidth]: 38,
      [markersHeight]: 38
    })
  
    // wx.showToast({title: '正在获取信息', icon: 'loading', duration: 10000});
    // wx.hideToast();
  },
 
})

 

这个是自己工作上的东西,做个记录,希望可以帮助有需要的人

posted @   Homegu  阅读(3009)  评论(1编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
你的浏览器不支持canvasr
点击右上角即可分享
微信分享提示