Ionic - Maps Drawing Tools - переменная доступа внутри слушателя - PullRequest
0 голосов
/ 06 января 2019

Я работаю с API карт Google и библиотеками инструментов рисования.

Мне удалось нарисовать многоугольник на карте. Теперь мне нужно сохранить координаты в строку.

Как я могу получить доступ к глобальной переменной в исходном коде слушателя?

я также не могу хранить в локальном хранилище, потому что я получаю следующую ошибку:

this.storage.set('pruebaArray', JSON.stringify(this.armaJSON));

Невозможно прочитать свойство 'set' из неопределенного

В save() Метод, который я получаю:

console.log(armaJSON);

неопределенный

Надеюсь, вы мне поможете.

Спасибо.

import { Component, ViewChild, ElementRef } from '@angular/core';
import { IonicPage, NavController, NavParams, Platform } from 'ionic-angular';
import { Storage } from '@ionic/storage';

declare var google;
var armaJSON;

@IonicPage()
@Component({
  selector: 'page-area',
  templateUrl: 'area.html',
})
export class AreaPage {
  @ViewChild('map') mapElement: ElementRef;
  map: any;
  selectedShape: any;
  public jsonsave:string;

  constructor(public navCtrl: NavController,
    private platform: Platform,
    private storage: Storage,
    public navParams: NavParams) {

    platform.ready().then(() => {
      this.addMap(-34.8440489, -60.30644789);  //My place
      this.initDraw();
    });
  }


  addMap = (lat, long): void => {
    let latLng = new google.maps.LatLng(lat, long);

    let mapOptions = {
      center: latLng,
      zoom: 15,
      mapTypeId: google.maps.MapTypeId.SATELLITE,
      disableDefaultUI: true,
      zoomControl: true
    }
    this.map = new google.maps.Map(this.mapElement.nativeElement, mapOptions);
  }

  initDraw = (): void => {

    var polyOptions = {
      strokeWeight: 0,
      fillOpacity: 0.45,
      fillColor: '#ffff00',
      editable: true
    };

    var drawingManager = new google.maps.drawing.DrawingManager({
      drawingMode: google.maps.drawing.OverlayType.MARKER,
      drawingControl: true,
      drawingControlOptions: {
        position: google.maps.ControlPosition.TOP_CENTER,
        drawingModes: ['marker', 'polygon']
      },
      markerOptions: { icon: 'assets/imgs/beachflag.png' },
      polygonOptions: polyOptions,
      circleOptions: {
        fillColor: '#ffff00',
        fillOpacity: 1,
        strokeWeight: 5,
        clickable: false,
        editable: true,
        zIndex: 1
      }
    });

    google.maps.event.addListener(drawingManager, 'overlaycomplete', function (e) {
      //POLYGON
      if (e.type != google.maps.drawing.OverlayType.MARKER) {
        drawingManager.setDrawingMode(false);
        var newShape = e.overlay;
        newShape.type = e.type;
        this.armaJSON='[';
        for (var i = 0; i < newShape.getPath().getLength(); i++) {
          if (i > 0) {
            this.armaJSON+=','
          }
         this.armaJSON+='{"lat": ' + + newShape.getPath().getAt(i).lat() + ', "lng": ' + newShape.getPath().getAt(i).lng() + '}';
        }
        this.armaJSON+=']';
        this.jsonsave=this.armaJSON;
        console.log(this.armaJSON);
        //Se almacena el array
        this.storage.set('pruebaArray', JSON.stringify(this.armaJSON));
      }

      //MARKER
      if (e.type == google.maps.drawing.OverlayType.MARKER) {
        var newShape = e.overlay;
        newShape.type = e.type;
        console.log('Lat:' + newShape.getPosition().lat() + ' - Long:' + newShape.getPosition().lng());
      }
    });

    drawingManager.setMap(this.map);
  }

  save() {
    console.log(armaJSON);
    //Se almacena el array
    //this.storage.set('pruebaArray', armaJSON);
  }



} //end class
page-area {
    #map {
        height: 100%;
      }
}
<ion-navbar *navbar>
  <button menuToggle>
      <ion-icon name="menu"></ion-icon>
  </button>
  <ion-title>Start</ion-title>
</ion-navbar>


<ion-content>
  <div #map id="map"></div>
</ion-content>

<ion-footer style="padding:4px">
  <button ion-button (click)="save()" style="width: 31%; margin-left:2px">Save</button>
</ion-footer>  
...