Vue+Openlayers 坐标转换

前篇提到openlayers帮我们提供的投影坐标系projection参数只有两个 EPSG:4326、EPSG:3857。

对于这两个坐标系转换,可以直接转换,下面从4326转为3857

引入transform方法

import {transform} from 'ol/proj'
let center=transform([118,35],'EPSG:4326','EPSG:3857')

但是对于openlayers没有帮我们定义的坐标系我们必须先注册,然后才能转如:EPSG:4527转EPSG:4490

引入方法。提示:proj4要下载 npm i proj4

import proj4 from 'proj4'
import {register} from 'ol/proj/proj4';
import {transform,Projection} from 'ol/proj'
proj4.defs('EPSG:4490', '+proj=longlat +ellps=GRS80 +no_defs');
proj4.defs('EPSG:4527','+proj=tmerc +lat_0=0 +lon_0=117 +k=1 +x_0=39500000 +y_0=0 +ellps=GRS80 +units=m +no_defs')
register(proj4);
let center=transform([39500000.00,4012173.36],new Projection({code:'EPSG:4527'}),new Projection({code:'EPSG:4490'}))

关于defs方法注册后面的参数,我上一篇有介绍。

你可能感兴趣的:(vue+ol,vue.js,css,css3)