operlayers-初始化地图-天地图初始化地图

news2024/9/22 9:32:00

今天分享一篇初始化operlayers的文章,算上一篇笔记吧,以后再有项目时直接看笔记回省好多事,也帮网上的兄弟们避避雷。

前言

这个项目是vue3+operlayers开发的一个有关地名地址的小插件,具体服务就不展示了。

之所以用天地图来加载地图呢,主要是因为天地图加载的方式比较简单,不过也不算简单吧,一开始去天地图的官网上搞了半天,后来就用到官网上申请的AppKey,哈哈

本来我想使用wmts来加载影像地图的,但是这种方式比较麻烦,而且我在网上找的好多方式都没有加载成功,为此我还在csdn上求助来着,有两个大佬回复了我,用的是阿里的影像服务,很是感谢,但是也不好使。所以,我在想是不是想使用wmts的服务就必须下载下来,在本地跑服务,希望有看到这篇文章的大佬回复一下,十分感谢、感谢!!!

实现过程

1、因为operlayers所需要的依赖文件;

operlayers其实支持用npm引入依赖的,但是因为一开始是使用内网开发,所以就使用手动引入的方式,直接下载ol.jsol.js.map文件,直接放在public文件下,然后在index.html文件中用script标签引入即可:

<script src="/ol.js"></script>
<script src="/ol.js.map"></script>

2、首先准备好相关的影像地址,具体如下:

window.OperlayerConfig = {
    worldUnderlay: 'http://t4.tianditu.com/DataServer?T=cva_w&tk=key&x={x}&y={y}&l={z}',     // 天地图的底图服务
    worldName: 'http://t4.tianditu.com/DataServer?T=vec_w&tk=key&x={x}&y={y}&l={z}',     // 天地图的地名影像
}

以上服务地址是我在网上找的,将里面的key值更换为自己天地图账号申请的key值即可。

3、使用服务,利用operlayers的API将服务添加到operlayers的对象中。

/**
 * 设置底图的投影方式
 * @description EPSG:3857 使用墨卡托投影
 * @description EPSG:4326 使用经纬度方式投影
 */
const projection = ol.proj.get('EPSG:3857');

// 底图影像服务
var worldUnderlaylayer = new ol.layer.Tile({
  source: new ol.source.XYZ({
    url: window.OperlayerConfig.worldUnderlay,
    projection: projection,    // 设置底图的投影方式
    crossOrigin: 'anonymous',
  }),
})

// 地名地址
var worldNamelayer = new ol.layer.Tile({
  source: new ol.source.XYZ({
    url: window.OperlayerConfig.worldName,
    projection: projection,  // 设置底图的投影方式
    crossOrigin: 'anonymous',
  })
})

4、创建一个矢量图层,我们工作中绘制的图形都放在这个矢量图层中

/**
 * 矢量图层
 */
var targetManger = new ol.layer.Vector({
  //数据源
  source: new ol.source.Vector({
    wrapX: false,
  }),
})

5、上面把图层啥的都定义好了,下面开始初始化地图

// 地图对象
var mapManger: any = null

mapManger = new ol.Map({
  target: 'mapContainer',   // mapContainer
  layers: [worldUnderlaylayer,worldNamelayer, targetManger],
  view: new ol.View({
    center: [123, 46],
    zoom: 4,
    minZoom: 2,
    projection: 'EPSG:4326',
  }),
})

target:是装地图的容器盒子,id值

layers:初始化时放已经创建好的图层,因为图层是安装层级覆盖的,下面的会被上面的图层覆盖掉。所以我们将底图放在最下面,地名服务放在中间,因为管理我们绘制图像的图层需要始终可见。因此要放在最上方,也就是最后一个加载的。所以请记住,上面加载图层的位置不能乱。

view.center:地图的中心位置

view.zoom:初次加载的层级

view.projection:投影的方式,这里选择经纬度投影

6、地图对象卸载

一般情况下,我们都会将初始化地图模块封装成一个组件,在项目中有使用的时候直接引入组件即可。但是这样一个组件在多出被使用容易出现大大小小的问题,最常见的就是两处业务用到同一处组件导致组件污染。一般在vue的组件卸载之前的钩子函数中调用。

// 地图卸载事件
const destroyMap = () => {
  if (mapManger == null) return
  mapManger.setTarget(null)
  // 销毁组件
  mapManger.dispose()
  mapManger = null
  document.getElementById('mapContainer') == null
    ? ''
    : (document.getElementById('mapContainer').innerHTML = '')
}

7、实现效果

彩蛋

天地图的官网:天地图注册key

在天地图官网上注册好自己账号后进入【开发】-【应用管理】,或者点击上面的链接,不过需要先在天地图官网上登录好自己的账号,不然你还是会跳转到账号登录界面。

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

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

相关文章

CMake构建学习笔记3-libpng库的构建

libpng是一个用于读取、写入 PNG (Portable Network Graphics) 文件格式的开源软件库&#xff0c;有了上一篇笔记作为基础&#xff0c;构建起来也非常简单。还是在源代码的根目录中创建一个build文件夹&#xff0c;执行如下关键指令&#xff1a; # 配置CMake cmake .. -G &q…

86.游戏改造-UI修正暴力分析

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a;易道云信息技术研究院 上一个内容&#xff1a;85.游戏改造-修改UI分辨率&#xff0c;面向对象方式 85.游戏改造-修改UI分辨率&#xff…

【Material-UI】深入了解Radio Group中的useRadioGroup Hook

文章目录 一、什么是useRadioGroup&#xff1f;1.1 Hook的返回值 二、useRadioGroup的基本用法2.1 代码示例2.2 代码解析 三、useRadioGroup的应用场景3.1 动态样式调整3.2 高级交互逻辑 四、使用useRadioGroup的最佳实践4.1 保持代码简洁4.2 结合主题定制4.3 注意无障碍设计 五…

通过Python绘制不同数据类型适合的可视化图表

在数据可视化中&#xff0c;对于描述数值变量与数值变量之间的关系常见的有散点图和热力图&#xff0c;以及描述数值变量与分类变量之间的关系常见的有条形图&#xff0c;饼图和折线图&#xff0c;可以通过使用Python的matplotlib和seaborn库来绘制图表进行可视化表达&#xff…

基于R语言进行AMMI分析2

接续上文【基于R语言进行AMMI分析1】 1、AMMI()函数的结果解读 # 加载agricolae包 library(agricolae) # 加载数据 data(plrv) # 查看数据 head(plrv) model<-with(plrv,AMMI(Locality,Genotype,Rep,Yield,PCTRUE)) # 查看方差分析结果 model$ANOVA # 查看主成分的方差分析…

AIGC综合应用-黑神话悟空cos写真制作方法(案例拆解)

​ 想要体验一下穿越到黑神话悟空的世界中&#xff0c;亲自上阵来一场cos写真拍摄&#xff1f; 其实&#xff0c;通过AI&#xff0c;这个愿望轻松实现&#xff01; 不需要复杂的设备和高超的技术&#xff0c;只要两步就能搞定&#xff1a;生成底图和换脸。 以下就带你一步步…

Redis计数器:数字的秘密

文章目录 Redis计数器incr 指令用户计数统计用户统计信息查询缓存一致性 小结 技术派项目源码地址 : Gitee :技术派 - https://gitee.com/itwanger/paicodingGithub :技术派 - https://github.com/itwanger/paicoding 用户的相关统计信息 文章数&#xff0c;文章总阅读数&am…

网络互联基础

1. 集线器 与集线器相连的所有主机组成一个简单局域网LAN&#xff0c;都属于同一个冲突域&#xff0c;且属于同一个广播域。 2. 交换机 交换机连接的每个网段都是独立的冲突域&#xff0c;即交换机每个端口都是独立的冲突域。默认情况下&#xff0c;交换机对冲突域进行分割。…

一道xss题目--intigriti-0422-XSS-Challenge-Write-up

目录 进入挑战 js代码 代码分析 构造payload ​编辑 结果 进入挑战 Intigriti April Challenge题目地址 打开题目后&#xff0c;找到对应页面的js代码&#xff0c;寻找一下我们用户可控的点 js代码 <!DOCTYPE html> <html lang"en"><head> …

阵列信号处理2_阵列信号最优处理常用准则(CSDN_20240825)

目录 最小均方误差&#xff08;Minimum Square Error&#xff0c;MSE&#xff09;准则 最大信噪比&#xff08;Maximum Signal Noise Ratio&#xff0c;MSNR&#xff09;准则 极大似然&#xff08;Maximum Likehood, ML&#xff09;准则 最小方差无损响应&#xff08;Minim…

移动应用平台,企业移动门户就选WorkPlus

随着移动设备的普及和移动办公的兴起&#xff0c;企业需要一个高效可靠的移动应用平台来加强内部沟通、协作和信息管理。在众多的移动应用平台中&#xff0c;WorkPlus作为一款专为企业打造的移动门户&#xff0c;凭借其稳定性、功能丰富和易用性成为了企业移动门户的首选。 一、…

【LVGL-下拉列表部件 lv_dropdown】

LVGL-下拉列表部件 lv_dropdown ■ LVGL-下拉列表部件 lv_dropdown■ 下拉列表部件的组成■ 添加选项■ 获取当前选中的选项■ 设置列表展开方向■ 设置下拉列表图标■ 设置列表常显文本■ 打开、开闭下拉列表■ 下拉列表部件的 API 函数 ■ LVGL-下拉列表部件 lv_dropdown ■ …

STM32学习记录-05 -3-TIM输入捕获

1 输入捕获简介 IC&#xff08;Input Capture&#xff09;输入捕获 输入捕获模式下&#xff0c;当通道输入引脚出现指定电平跳变时&#xff0c;当前CNT的值将被锁存到CCR中&#xff0c;可用于测量PWM波形的频率、占空比、脉冲间隔、电平持续时间等参数 每个高级定时器和通用…

FME批处理:WorkspaceRunner转换器

1、创建一个待处理工程 注意&#xff1a; Reader设置&#xff1a; Writer设置&#xff1a; 2、创建另外一个**批处理工程**&#xff0c;加入workspaceRunner并设置参数 workspaceRunner设置 directory and file pathnames设置

认知杂谈23

今天分享 有人说的一段争议性的话 I I 《忙碌不停&#xff0c;成长迷失》 现代生活啊&#xff0c;就跟一场一直转个不停的旋转木马似的。你每天都被各种小事儿缠得死死的&#xff0c;从大清早一睁开眼&#xff0c;一直到晚上要睡觉了&#xff0c;几乎就找不到一点能停下来喘…

BC156 牛牛的数组匹配(c语言)

1./描述 //牛牛刚学会数组不久&#xff0c;他拿到两个数组 a 和 b&#xff0c;询问 b 的哪一段连续子数组之和与数组 a 之和最接近。 //如果有多个子数组之和同样接近&#xff0c;输出起始点最靠左的数组。 //输入描述&#xff1a; //第一行输入两个正整数 n 和 m &#xff0c;…

NLP从零开始------12. 关于前十一章补充(英文分词)

相较于基础篇章&#xff0c;这一部分相较于基础篇减少了很多算法推导&#xff0c;多了很多代码实现。 1.英文词规范化 英文词规范化一般分为标准化缩写,大小写相互转化&#xff0c;动词目态转化等。 1.1 大小写折叠 大小写折叠( casefolding) 是将所有的英文大写字母转化成小…

开发高质量PDF应用的不二选择:PdfiumViewer库详细解析

1. PdfiumViewer库简介 PdfiumViewer是一款基于谷歌开源PDF渲染引擎PDFium的.NET库&#xff0c;主要用于在Windows应用程序中显示和处理PDF文档。PdfiumViewer提供了多种API和控件&#xff0c;使得开发者可以轻松地将PDF文档嵌入到其应用程序中。同时&#xff0c;PdfiumViewer…

利用 OCR 和强大的 GPT-4o 迷你模型对收据进行信息提取

在本文中&#xff0c;我将向您展示如何从收据中提取信息&#xff0c;并提供收据的简单图像。首先&#xff0c;我们将利用 OCR 从收据中提取信息。然后&#xff0c;此信息将发送到 GPT-4o 迷你模型进行信息提取。我在这个项目中的目标是开发一个应用程序&#xff0c;只需拍摄收据…

【排序算法】八大排序(下)(c语言实现)(附源码)

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;算法 目录 前言 测试数据和交换函数 五、堆排序 六、快速排序 1.hoare版本 2.挖坑法 3.lomoto版本 4.快速排序的非递归实现 5.快速排序性能总结 七、归…