uni-app实现leaflet地图图标旋转

之前在 uni-app 上已经实现了 leaflet 的离线地图,详细可以参考上文 # uni-app使用瓦片实现离线地图的两种方案

最近新增了一个定位的功能,其实就是常见的地图上的手机朝向哪儿,箭头就往哪儿指这个功能。

但是因为地图是基于 leaflet 做的,在 Trae 上进行了一番询问,Trae推荐采用简单实现方案,就是在 leaflet 上增加一个图标,然后通过图标旋转变换箭头朝向。

虽然我对 leaflet 不是非常熟悉,但是 Trae 作为程序员的"外挂"解答这个是没问题的,给出了两个实现方案。

方案1: 使用CSS调整

在创建图标的时候给图标增加一个 className ,然后通过修改这个 class 的 transform: rotate(45deg) 进行旋转。

js 复制代码
createLocationIcon() {
    const icon = L.icon({
        iconUrl: 'static/icon/location.png',
        iconSize: [60, 60],
        iconAnchor: [30, 30],
        popupAnchor: [1, -20],
        className: 'test-location'
    });
    this.locationIcon = L.marker([lat, lon], {
        icon: icon
    }).addTo(map);
},
updateLocation() {
    // 计算角度
    const bearing = this.calculateBearing(
        that.location.latitude,
        that.location.longitude,
        that.testPosition.latitude,
        that.testPosition.longitude
    );
    const icon = this.locationIcon.getElementsByClassName("test-location");
    icon.style.transform += `rotate(${bearing}deg)`;
}
css 复制代码
.test-location {
    transform: rotate(20deg);
}

这种方案其实是比较简单的,通过确定旋转角度直接操作DOM的形式进行旋转,并且还可以增加一定的动画延迟效果。

方案2: 使用leaflet.rotatedMarker.js

使用 leaflet.rotatedMarker.js 也是比较方便的一种方法。

首先在 static/leaflet 文件夹下插入 leaflet.rotatedMarker.js 文件。

然后在代码中导入 import rotated from "@/static/leaflet/leaflet.rotatedMarker.js";

最后在创建图标的位置增加 rotationAngle 属性。

js 复制代码
createLocationIcon() {
    const icon = L.icon({
        iconUrl: 'static/icon/location.png',
        iconSize: [60, 60],
        iconAnchor: [30, 30],
        popupAnchor: [1, -20],
        rotationAngle: 0
    });
    this.locationIcon = L.marker([lat, lon], {
        icon: icon
    }).addTo(map);
},
updateLocation() {
    // 计算角度
    const bearing = this.calculateBearing(
        that.location.latitude,
        that.location.longitude,
        that.testPosition.latitude,
        that.testPosition.longitude
    );
    // 设置旋转角度
    this.locationIcon.setRotationAngle(bearing);
}

上述两种方法均可以实现图标的旋转,不过我更推荐第二种实现方案。

简单方便,而且不需要操作DOM,减少性能开销。

相关推荐
有诺千金13 分钟前
VUE3入门很简单(4)---组件通信(props)
前端·javascript·vue.js
2501_9447114314 分钟前
Vue-路由懒加载与组件懒加载
前端·javascript·vue.js
雨季66639 分钟前
Flutter 三端应用实战:OpenHarmony “心流之泉”——在碎片洪流中,为你筑一眼专注的清泉
开发语言·前端·flutter·交互
换日线°43 分钟前
前端3D炫酷展开效果
前端·3d
广州华水科技1 小时前
大坝变形监测的单北斗GNSS技术应用与发展分析
前端
Dontla1 小时前
浏览器localStorage共享机制介绍(持久化客户端存储方案)本地存储冲突、iframe、XSS漏洞、命名空间隔离
前端·网络·xss
霍理迪1 小时前
JS其他常用内置对象
开发语言·前端·javascript
tao3556671 小时前
HTML-03-HTML 语义化标签
前端·html
小马_xiaoen1 小时前
IndexedDB 从入门到实战:前端本地大容量存储解决方案。
前端
jiayong231 小时前
Vue2 与 Vue3 常见面试题精选 - 综合宝典
前端·vue.js·面试