OpenLayers 拖动旋转和缩放

前言

在 OpenLayers 框架中已经封装了很多便利的交互控件,可以做到开箱即用,非常方便。像拖动缩放、绘制、选择等交互控件可以供开发者直接使用。本篇给大家介绍拖动旋转交互控件

1. 旋转控件简介

此控件通过按住shift键结合鼠标左键或右键进行使用。在按住键盘 shift 键的同时,鼠标点击地图进行拖动可以实现地图的旋转和缩放操作。但是此交互仅支持鼠标设备

在使用旋转交互控件的时候,除了通过 map.addInteraction()的方式添加交互控件以外,还可以通过 Map 属性interactions以默认交互控件的形式进行添加。此时需要使用ol.interaction.defaults对象的defaults方法添加旋转控件实例。

// 地图交互控件
interactions: ol.interaction.defaults.defaults().extend([new ol.interaction.DragRotateAndZoom()])

2. 结合 View 对象实现地图旋转

通过 View 对象的adjustRotation方法可以实现地图相对旋转。该方法接受两个参数

  • delta:地图缩放和旋转的相对值,以弧度为单位。
  • anchor:旋转中心,即旋转的描点。可设置为地图中心点

根据 PI = 180º1º = PI/180,然后设置地图绕中心点旋转 90º,正值为顺时针旋转,负值为逆时针。

// 绕中心点旋转
const center = map.getView().getCenter()
document.getElementById("rotate-center-p").addEventListener("click", evt => {// 顺时针旋转map.getView().adjustRotation(Math.PI / 2, center)
})
document.getElementById("rotate-center-n").addEventListener("click", evt => {// 逆时针旋转map.getView().adjustRotation(-Math.PI / 2, center)
})

3. 复位操作

在地图旋转或平移缩放操作之后,想回到初始的地图界面可以使用地图复位操作。通过 View 对象调用setRotation方法即可实现复位操作。该方法接收一个参数,即地图旋转值,以弧度为单位。当值为 0 的时候表示正北方向。

// 复位操作
document.getElementById("reset-view").addEventListener("click", evt => {// 调整视图为正北方向map.getView().setRotation(0)
})

4. 完整代码

其中libs文件夹下的包需要更换为自己下载的本地包或者引用在线资源。

<!DOCTYPE html>
<html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>OpenLayers 拖拽缩放和旋转</title><meta charset="utf-8" /><link rel="stylesheet" href="../../libs/css/ol9.2.4.css"><script src="../../js/config.js"></script><script src="../../libs/js/ol9.2.4.js"></script><style>* {padding: 0;margin: 0;font-size: 14px;font-family: '微软雅黑';}html,body {width: 100%;height: 100%;}#map {position: absolute;top: 50px;bottom: 0;width: 100%;}#top-content {position: absolute;width: 100%;height: 50px;line-height: 50px;background: linear-gradient(135deg, #ff00cc, #ffcc00, #00ffcc, #ff0066);color: #fff;text-align: center;font-size: 32px;}#top-content span {font-size: 32px;}.view-rotate {position: absolute;right: 50px;top: 80px;padding: 20px 10px;color: #fff;border-radius: 5px;border: 1px solid #50505040;background: linear-gradient(135deg, #c850c0, #4158d0);}.rotate-btn {border-radius: 5px;border: 1px solid #50505040;padding: 5px 20px;color: #fff;margin: 0 10px;background: #4646466e;transition: background-color 10s ease-in-out 10s;}.rotate-btn:hover {cursor: pointer;filter: brightness(120%);background: linear-gradient(135deg, #c850c0, #4158d0);}</style>
</head><body><div id="top-content"><span>OpenLayers 拖拽缩放和旋转</span></div><div id="map" title="地图显示"></div><div class="view-rotate"><span id="rotate-center-p" class="rotate-btn">绕中心点旋转(顺时针)</span><span id="rotate-center-n" class="rotate-btn">绕中心点旋转(逆时针)</span><span id="reset-view" class="rotate-btn">复位</span></div>
</body></html><script>//地图投影坐标系const projection = ol.proj.get('EPSG:3857');//==============================================================================////============================天地图服务参数简单介绍==============================////================================vec:矢量图层==================================////================================img:影像图层==================================////================================cva:注记图层==================================////======================其中:_c表示经纬度投影,_w表示球面墨卡托投影================////==============================================================================//const TDTImgLayer = new ol.layer.Tile({title: "天地图影像图层",source: new ol.source.XYZ({url: "http://t0.tianditu.com/DataServer?T=img_w&x={x}&y={y}&l={z}&tk=" + TDTTOKEN,attibutions: "天地图影像描述",crossOrigin: "anoymous",wrapX: false})})const TDTImgCvaLayer = new ol.layer.Tile({title: "天地图影像注记图层",source: new ol.source.XYZ({url: "http://t0.tianditu.com/DataServer?T=cia_w&x={x}&y={y}&l={z}&tk=" + TDTTOKEN,attibutions: "天地图注记描述",crossOrigin: "anoymous",wrapX: false})})const map = new ol.Map({target: "map",loadTilesWhileInteracting: true,view: new ol.View({center: [102.845864, 25.421639],zoom: 6.5,worldsWrap: false,minZoom: 1,maxZoom: 20,projection: 'EPSG:4326',}),layers: [TDTImgLayer],// 地图默认控件controls: ol.control.defaults.defaults({zoom: false,attribution: false,rotate: false}),// 地图交互控件interactions: ol.interaction.defaults.defaults().extend([new ol.interaction.DragRotateAndZoom()])})map.on('click', evt => {console.log("获取地图坐标:", evt.coordinate)})// 复位操作document.getElementById("reset-view").addEventListener("click", evt => {// 调整视图为正北方向map.getView().setRotation(0)})// 绕中心点旋转const center = map.getView().getCenter()document.getElementById("rotate-center-p").addEventListener("click", evt => {map.getView().adjustRotation(Math.PI / 2, center)})document.getElementById("rotate-center-n").addEventListener("click", evt => {map.getView().adjustRotation(-Math.PI / 2, center)})
</script>

OpenLayers示例数据下载,请回复关键字:ol数据

全国信息化工程师-GIS 应用水平考试资料,请回复关键字:GIS考试

【GIS之路】 已经接入了智能助手,欢迎关注,欢迎提问。

欢迎访问我的博客网站-长谈GIShttp://shanhaitalk.com

都看到这了,不要忘记点赞、收藏 + 关注

本号不定时更新有关 GIS开发 相关内容,欢迎关注 !

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/86460.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/86460.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

element ui Cascader 级联选择器 处理未全选时去除父节点值,选中父节点时去除子节点值

目前我这边的需求时&#xff1a;当用户的选择&#xff0c;只保留最顶层的选中节点 如果选中了父节点&#xff0c;则移除其所有子孙节点以及它的祖先节点&#xff08;因为选中父节点代表选中整个分支&#xff0c;所以不需要再显示子节点&#xff1b;同时&#xff0c;如果存在祖…

uniapp实现远程图片下载到手机相册功能

在 UniApp 中实现点击下载图片到相册的功能&#xff0c;需要以下几个步骤&#xff1a; 1. 下载图片到本地&#xff08;uni.downloadFile&#xff09; 2. 将图片保存到相册&#xff08;uni.saveImageToPhotosAlbum&#xff09; 完整代码示例&#xff1a; <template>&l…

【世纪龙科技】吉利博瑞汽车车身诊断与校正仿真教学软件

在汽车产业蓬勃发展的当下&#xff0c;汽车车身诊断与校正技术人才的需求与日俱增。然而&#xff0c;职业院校在汽车车身教学实践中&#xff0c;却面临着学生实训机会稀缺、教学互动匮乏、过程评价缺失、学生技能提升缓慢等诸多难题。江苏世纪龙科技凭借其卓越的技术实力与行业…

极速二刷leetcode hot100

简单题 1.移动0 283. 移动零 - 力扣&#xff08;LeetCode&#xff09; 刚开始没看到非零子串的顺序不变&#xff1a; // if(nums.size() 1){// return;// }// //所有 0 移动到数组的末尾//同时保持非零元素的相对顺序。// int n nums.size();// int notZero n-1;////…

技术博客:如何用针孔相机模型理解图像

引言 大家好&#xff01;今天我们来聊聊一个非常有趣的话题——针孔相机模型。这个模型可以帮助我们理解相机是如何捕捉图像的。我们会用一些简单的数学公式来解释这个过程&#xff0c;不用担心&#xff0c;我会尽量让这些内容简单易懂。 什么是针孔相机模型&#xff1f; 针…

Nanonets-OCR:Qwen2.5VL-3B的微调模型 更强大的文档解析能力|附效果实测

一 Nanonets-OCR 简介 Nanonets-OCR不再满足于单纯提取文本&#xff0c;它能智能解析图像中的公式、表格、水印、签名、图表、复选框等复杂结构&#xff0c;并输出格式清晰的 Markdown。 核心功能 ● LaTeX 公式识别&#xff1a;自动将文中数学公式转为标准 LaTeX 格式 ●…

Git下载与使用完全指南:从安装到基础操作详解,附上git的学习网站(很直观)(可以模拟git的全过程)

一、Git简介与下载安装 1.1 Git是什么&#xff1f; Git是目前世界上最先进的分布式版本控制系统&#xff0c;由Linus Torvalds&#xff08;Linux之父&#xff09;开发。它可以高效地处理从小型到大型项目的版本管理&#xff0c;具有以下特点&#xff1a; 分布式架构&#xff…

论分布式设计

20250419-作 题目 分布式是指将一个系统或任务分解成多个子部分&#xff0c;并在多个计算机或服务器之间进行协同工作的方式。每个子部分都可以在不同的计算机节点上运行&#xff0c;彼此之间通过网络进行通信和协调。分布式技术在当今互联网应用中起着重要作用&#xff0c;例…

Vue样式绑定与条件渲染详

一、Vue样式绑定 在Vue中&#xff0c;我们可以通过多种方式动态地绑定样式&#xff0c;让界面根据数据状态变化而自动更新样式。 1. class样式绑定 (1) 字符串写法 适用场景&#xff1a;样式的类名不确定&#xff0c;需要动态指定 <template><div><!-- 绑定…

固态电池火热-美国固态电池企业QuantumScape宣布,产能规模化迈出了重要一步

美国固态电池企业QuantumScape宣布&#xff0c;其先进的Cobra隔膜工艺已成功集成到基线电池生产中&#xff0c;标志着公司生产能力规模化迈出了重要一步。 添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 600478 科力远 业绩固态电池 | 1.科力远发布20…

Python 商务数据分析—— NumPy 学习笔记Ⅰ

一、NumPy 简介 1.1 NumPy 特性 高性能科学计算库&#xff1a;专为处理多维数组设计&#xff0c;底层用 C 语言实现&#xff0c;运算速度远超 Python 原生列表。 矢量运算&#xff1a;支持批量数据操作&#xff0c;避免显式循环&#xff0c;代码更简洁高效。 广播机制&…

中州养老:搭建环境(第二节)

目录 项目初始工程搭建: 不同项目需要的前后端环境也不同 前端项目搭建: 熟悉模块的方式 代码阅读 如何开发一个接口 Swagger(接口文档) Api注解的说明 ​​​​​​​项目初始工程搭建: 公司项目分两种,新立项目(0-1)和已有项目开发(1-2) 熟悉项目结构,每个模块对应的…

[1-01-01].第78节:Java8新特性 - Lambda表达式

java基础语法大纲 一、Lambda 表达式 1.1.概述&#xff1a; 1.Lambda 是一个匿名函数&#xff0c;我们可以把 Lambda 表达式理解为是一段可以传递的代码&#xff08;将代码像数据一样进行传递&#xff09;2.使用Lambda 表达式可以写出更简洁、更灵活的代码。作为一种更紧凑的…

【2025.6.27 校内 NOI 模拟赛】总结(贪心, 容斥、组合计数, dsu on tree、 虚树)

文章目录 时间安排反思题解[六省联考 2017] 期末考试&#xff08;贪心&#xff0c; 枚举&#xff09;[JSOI2019] 神经网络&#xff08;容斥&#xff0c; 组合计数&#xff0c; 树背包&#xff09;[ZJOI2019] 语言&#xff08;dsu on tree&#xff0c; 虚树&#xff0c; 结论&am…

实际前端开发中,常用指令的封装

实际前端开发中&#xff0c;常用指令的封装 全局指令处理步骤main.ts指令目录结构src/directives/index.ts 一、输入框空格禁止指令1、指令文件clearSpace.ts2、指令使用 全局指令处理步骤 main.ts import { createApp } from "vue"; import App from "./App.…

鸿蒙OH南向开发 轻量系统内核(LiteOS-M)【异常调测】

基本概念 OpenHarmony LiteOS-M提供异常接管调测手段&#xff0c;帮助开发者定位分析问题。异常接管是操作系统对运行期间发生的异常情况进行处理的一系列动作&#xff0c;例如打印异常发生时异常类型、发生异常时的系统状态、当前函数的调用栈信息、CPU现场信息、任务调用堆栈…

算法-堆排序

文章目录 整体架构流程技术细节小结 整体架构流程 大顶推&#xff1a;是构建一个完整的二叉树 大顶推&#xff1a;即父节点的值大于左右子树的值。 循环构建大顶推 在给定的数组&#xff0c;既可以明确树的高度。 在循环的时候&#xff0c;构建树的高度从lgn至0。即从堆低往堆…

【鸿蒙HarmonyOS Next App实战开发】二维码生成技术实现与解析

随着移动应用开发中对便捷交互体验的需求日益增长&#xff0c;二维码作为信息传递的重要载体&#xff0c;其生成与使用变得越来越普遍。本文将基于鸿蒙HarmonyOS应用开发框架&#xff0c;详细介绍如何实现一个功能完备的二维码生成器&#xff0c;并附上完整代码解析。 注意该实…

1 Studying《Is Parallel Programming Hard》6-9

目录 Chapter 6 Partitioning and Synchronization Design 6.1 分区练习 6.2 设计准则 6.3 同步粒度 6.4 并行快速路径 6.5 超越党派分歧 6.6 分区、并行和优化 Chapter 7 Locking 7.1 活命 7.2 锁的类型 7.3 锁定实施问题 7.4 基于锁的存在性保证 7.5 锁定&a…

Java练习题精选16-20

Java练习题精选16-20 一、第十六题二、第十七题三、第十八题四、第十九题五、第二十题一、第十六题 现有一个存放学生成绩的数组{66, 77, 88, 99},要求将该数组正序输出每个下标所对应的元素。 public class Test {public static void main(String[] args) {int<