angular使用openlayers6以及加载百度地图

angular中使用openlayers本来是没什么难度的,但是如果要加载百度地图还是有些问题的,在openlayers3中坐标是从原点右上递增,而openlayers6中是右下递增,这就导致使用百度地图作为底图时出现图层错乱的问题,同时还有偏移问题,相关的问题和解答网上的资料真的少,对于不是gis专业出身的人来说真的能搞死人,此外还有openlayers那文档,不是英文的原因,是真的难以看懂。
首先是安装,要注意的还是版本问题,openlayers6和之前版本的安装命令不一样。
两种不同的安装命令意味着有不同,事实确实是这样,有些包的路径已经改变或者某些方法或属性被删除了,使用的时候都是需要注意的。另外说的是ts的支持,GitHub的readme中有介绍对ts的支持,但是真的不怎么样,也提到第三方的类型支持@types/ol,看名字就知道了,是5之后的支持,也不是很完美,有些api还是没有智能提示。

// 这是4.6.5及前的安装命令
npm install openlayers
// 这是5.3.0及之后的安装命令
npm install ol

安装完之后引入css,在angular.json或其他地方引入。
在这里插入图片描述
接下来就是使用问题了,直接贴出基本使用代码,注意最好是在ngAfterViewInit中写,就不解释了

简单使用openlayer

<div id="map" class="map-container"></div>
<div class="map-container">经度:{
  {coordinate[0]}}纬度:{
  {coordinate[1]}}</div>
ngAfterViewInit(): void {
   
    const that = this;
    this.map = new Map({
   
      target: 'map',
      controls: defaults().extend([
        // 鼠标移入显示坐标
        new MousePosition({
    projection: 'EPSG:4326' })
      ]),
      layers: [
        new TileLayer({
   
          source: new OSM({
   
            attributions: 'xxxx股份
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不要葱花

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值