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

从前端框架到GIS开发系列课程(26)在mapbox中实现地球自转效果,并添加点击事件增强地图交互性

地球自转效果实现

1. 使用ease to动画库实现地球自转效果

需求:点击地球,实现自转:

// 地球实现自转 easeTo()
function spinGlobe() {const center = map.getCenter();center.lng += 1;map.easeTo({center,duration: 2000,});
}spinGlobe();

此时的效果:

动图

我们发现,地球转一下就停了,是什么原因呢?

因为我们只执行了一次spinglobe,这时经度变化只变化一点。

如果要持续自转应该怎么做呢?

2. 通过改变地球的经度线来实现自转效果。

引入moveend事件:

map.on("moveend", () => {spinGlobe();
});

看下效果:

动图封面

这时大家可能发现,自转一顿一顿的,不连贯,那么我们可以通过调整动画曲线参数使自转效果更加平滑和连贯。

easing: (e) => e,

看下最后的效果:

动图封面

3.地图拖动功能

我们可以通过地球拖动功能进一步优化。

例如,假设有这样一个场景,我想看某一个区域的一些具体的内容,通过鼠标拖动地球,你会发现拖动后它还在转。我要往它往左边拖,但是它要往右边转。

动图封面

这个问题应该怎么解决?

我们需要在这里设置让拖拽的时候自转停止,引入dragstart事件。

map.on("dragstart", () => {console.log("dragstart");isSpinning = false;
});

如何再让它继续转起来?

这里继续绑定一个双击事件:

map.on("dblclick", () => {isSpinning = true;spinGlobe();
});

动图封面

点击事件

接下来在mapbox中绑定地图点击事件,并获取及修改图层样式。

通过set paint property方法,可以修改图层的绘制属性,如填充颜色。

此外,还介绍如何通过设置pitch和bearing实现地图的三维效果,包括仰角、俯角及旋转。

通过按钮绑定事件,可以动态调整这些参数,增强地图的交互性和视觉效果。

添加事件按钮:

<html lang="en">
<head>
</head>
<body><div id="map"></div><select id="select"><option value="standard">standard</option><option value="streets-v12">streets-v12</option><option value="dark-v11">dark-v11</option><option value="navigation-day-v1">navigation-day-v1</option></select><div class="btns"><button>pitch</button><button>bearing</button></div><script type="module" src="/main.js"></script>
</body>
</html>

给按钮添加属性:

map.on("click", function () {const layer = map.getStyle().layers[0];// map.setPaintProperty("my-tiles", "fill-color", "#faaee");// const style = map.getPaintProperty("my-tiles", "fill-color");// console.log(layer);
});const btns = document.querySelectorAll(".btns-button");
const btn1 = btns[0];
const btn2 = btns[1];btn1.onclick = function () {let pitch = map.getPitch();pitch += 5;map.setPitch(pitch);
};btn2.onclick = function () {let bearing = map.getBearing();bearing += 5;map.setBearing(bearing);
};

点击按钮可实现仰角和旋转切换

fly to飞行动画

// 点击后视图动画效果飞行到北京
btn3.onclick = function () {map.flyTo({// 北京经纬度center: [116.46, 39.92],zoom: 10,pitch: 30,// speed 0-1 值越大 速度越快speed: 0.5});
};

ease to过渡动画

添加按钮:

<html lang="en"><head></head><body><div id="map"></div><select id="select"><option value="standard">standard</option><option value="streets-v12">streets-v12</option><option value="dark-v11">dark-v11</option><option value="navigation-day-v1">navigation-day-v1</option></select><div class="btns"><button>pitch</button><button>bearing</button><button>飞行到北京</button><button>直接到北京</button></div><script type="module" src="/main.js"></script></body>
</html>

给按钮添加属性:

btn4.onclick = function () {map.easeTo({center: [116.46, 39.92],zoom: 10,duration: 2000,});
};

如有收获,点个赞吧!

持续更新webgis开发相关技术/面试/就业内容

关注我学习webgis开发不迷路👇👇👇

http://www.xdnf.cn/news/1304857.html

相关文章:

  • 物联网(IoT)系统中,通信协议如何选择
  • 20250815在荣品RD-RK3588-MID开发板的Android13下调通TP芯片FT8206
  • 智慧零碳园区——解读2025 零碳产业园区实施路径规划【附全文阅读】
  • MqSQL中的《快照读》和《当前读》
  • SQL182 连续两次作答试卷的最大时间窗
  • C++第二十课:快递运费计算器 / 黑白配+石头剪刀布小游戏
  • Linux入门(十九)定时备份数据库
  • 第1篇_Go语言初探_环境搭建与HelloWorld
  • 802.11 Wi-Fi 竞争机制深度分析:CSMA/CA 与 DCF
  • 机器学习之PCA降维
  • Scrapy + Django爬虫可视化项目实战(二) 详细版
  • 轴机械臂cad【7张】三维图+设计说明书
  • 25.Linux 聚合链路与软件网桥
  • XXL-TOOL v2.0.0 发布 | Java工具类库
  • AI创业公司分析:Paloma
  • 自定义数据集(pytorchhuggingface)
  • SaltStack 基础
  • 【机器人-基础知识】ROS常见功能架构
  • 考研复习-计算机组成原理-第七章-IO
  • OpenCV---morphologyEx形态学操作
  • Jenkins+Python自动化持续集成详细教程
  • 【JavaEE】多线程 -- 死锁问题
  • Unity输入系统:旧版Input_System
  • 链路聚合与软件网桥配置
  • Mac(一)常用的快捷键整理
  • JavaScript(JS)DOM(四)
  • 【数据分享】2022 年黑龙江省小麦、玉米和水稻幼苗影像数据集
  • Python基础(Flask①)
  • 基于机器学习的赌博网站识别系统设计与实现
  • 数据结构——顺序表单链表oj详解