vue中使用openlayers开发离线地图

本文介绍如何在Vue项目中利用OpenLayers库开发离线地图,详细阐述了marker点位标记及点击图标弹窗功能的实现过程,提供完整的代码示例,并提及了使用太乐下载器获取瓦片地图的参考。
摘要由CSDN通过智能技术生成

最近在使用openlayers开发离线地图,但是全英文的文档属实有点难顶,本文代码主要就是实现marker点位标记以及点击图标会显示弹窗,参考博客写的非常的详细也是我找到比较好的。
文中用到的瓦片地图是使用太乐下载器下载的,仅供参考
完整代码

在这里插入代码片
<template>
  <div>
    <div ref="olMap" id="map" class="ol-map"/>
    <div id="popup" class="ol-popup">
      <a href="#" id="popup-closer" class="ol-popup-closer"></a>
      <div id="popup-content" class="popup-content"></div>
    </div>

  </div>
</template>
<script>
import 'ol/ol.css'
import TileLayer from 'ol/layer/Tile'
import VectorLayer from 'ol/layer/Vector'
import VectorSource from 'ol/source/Vector'
import XYZ from 'ol/source/XYZ'
import {Map, View, Feature} from 'ol'
import Overlay from 'ol/Overlay'
import {
  Style,
  Stroke,
  Fill,
  Icon,
  Text
} from 'ol/style'
import {Point} from 'ol/geom'
import {Cluster} from 'ol/source'
import {fromLonLat} from 'ol/proj'
// import {toStringHDMS} from 'ol/coordinate'

export default {
  name: 'defineMap',
  data () {
    return {
      imgUrl: require('../../src/assets/pointer.png'),
      map: null,
      pointLayer: null,
      diffLayer: null,
      overlay: null,
      clusterData:null,
    }
  },
  mounted () {
    this.init()
    this.diffLayer = new Vec
为了在Vue3使用OpenLayers显示离线地图,您需要执行以下步骤: 1. 首先,您需要安装OpenLayers和proj4js依赖项。您可以使用以下命令进行安装: ```shell npm install ol proj4 --save ``` 2. 接下来,您需要下载离线地图瓦片。您可以使用QGIS等工具创建自己的离线地图瓦片,或者从第三方提供商下载现成的瓦片。将下载的瓦片放在您的项目的public文件夹。 3. 在Vue组件,您需要导入OpenLayers和proj4js库,并创建一个地图实例。您需要使用proj4js库来设置地图的投影方式。以下是一个示例组件: ```vue <template> <div id="map" class="map"></div> </template> <script> import 'ol/ol.css'; import { Map, View } from 'ol'; import TileLayer from 'ol/layer/Tile'; import OSM from 'ol/source/OSM'; import XYZ from 'ol/source/XYZ'; import proj4 from 'proj4'; export default { name: 'MapComponent', mounted() { // 设置投影方式 proj4.defs('EPSG:3857', '+proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +wktext +no_defs'); // 创建地图实例 const map = new Map({ target: 'map', layers: [ new TileLayer({ source: new XYZ({ url: '/tiles/{z}/{x}/{y}.png', // 离线瓦片路径 }), }), ], view: new View({ center: [0, 0], zoom: 2, projection: 'EPSG:3857', }), }); }, }; </script> <style> .map { height: 500px; } </style> ``` 在上面的示例,我们使用XYZ源加载离线瓦片,并将其添加到地图图层。我们还设置了地图的投影方式为EPSG:3857。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值