Load one or more features <template> <div id="map" style="width: 100vw; height: 100vh"></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, ol } from "ol"; import { Style, Stroke, Fill } from "ol/style"; import { Polygon, MultiPolygon } from "ol/geom"; import areaGeo from "@/assets/chengdu.json"; export default { data() { return { map: {}, areaLayer: {}, }; }, mounted() { this.initMap(); //Initialize the map method this.addArea(areaGeo); //Add area layer method this.pointMove(); this.getFeatureByClick(); }, methods: { pointMove() { // Set the style of the mouse over the vector element this.map.on("pointermove", (e) => { const isHover = this.map.hasFeatureAtPixel(e.pixel); this.map.getTargetElement().style.cursor = isHover ? "pointer" : ""; }); }, getFeatureByClick() { this.map.on("click", (e) => { let features = this.map.getFeaturesAtPixel(e.pixel); this.map.getView().fit(features[0].getGeometry(), { duration: 1500, padding: [100, 100, 100, 100], }); }); }, /** * Set area */ addArea(geo = {}) { if (Object.keys(geo).length == 0 && geo.features.length == 0) return; // Set the layer this.areaLayer = new VectorLayer({ source: new VectorSource({ features: [], }), }); //Add layer this.map.addLayer(this.areaLayer); let features = geo.features; for (let i in features) { let areaFeature = {}; if (features[i].geometry.type == "MultiPolygon") { areaFeature = new Feature({ geometry: new MultiPolygon(features[i].geometry.coordinates), }); } else if (features[i].geometry.type == "Polygon") { areaFeature = new Feature({ geometry: new Polygon(features[i].geometry.coordinates), }); } areaFeature.setStyle( new Style({ fill: new Fill({ color: "#4e98f444" }), stroke: new Stroke({ width: 3, color: [71, 137, 227, 1], }), }) ); areaFeature.setProperties(features[i].properties); this.areaLayer.getSource().addFeature(areaFeature); } }, /** * Initialize the map */ initMap() { this.map = new Map({ target: "map", layers: new TileLayer({ source: new XYZ({ url: "http://map.geoq.cn/ArcGIS/rest/services/ChinaOnlineStreetPurplishBlue/MapServer/tile/{z}/{y}/{x}", }), }), ], view: new View({ projection: "EPSG:4326", center: [103, 31], zoom: 7, }), }); }, }, }; </script> This is the end of this article about Vue+Openlayer dynamically loading geojson. For more relevant Vue Openlayer loading geojson content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: Detailed explanation of non-primary key column overflow monitoring in MySQL tables
>>: How to start a Java program in docker
1. One-stop solution 1. Problem analysis and loca...
Currently, almost all large websites and applicat...
Preface: position:sticky is a new attribute of CS...
This article example shares the specific code of ...
This article uses examples to illustrate the usag...
By default, Docker runs over a non-networked UNIX...
Table of contents What is VUE Core plugins in Vue...
The <canvas> element is designed for client...
A jQuery plugin every day - jQuery plugin to impl...
If you don’t understand what I wrote, there may b...
Table of contents Preface 1. Configure gzip compr...
Two cases: 1. With index 2. Without index Prerequ...
The pop-up has nothing to do with whether your cur...
Solve the problem of Chinese garbled characters i...
1. Configure local yum source 1. Mount the ISO im...