Замораживание карты после изменения вкладки в Ionic - PullRequest
0 голосов
/ 23 мая 2018

Я использую вкладку в моем ионном приложении, сначала мои карты не отображаются, когда я перехожу на другую вкладку, а затем снова возвращаюсь на страницу карты.А потом я нашел обходной путь в Интернете, и моя карта снова появилась после перехода на другую вкладку.Но проблема в том, что теперь карта зависла, я не могу перетаскивать, перемещать или масштабировать свои карты.Вот мой код для отображения карты.

import { Component , ViewChild, ElementRef} from '@angular/core';
import { NavController } from 'ionic-angular';
import {GoogleMap, GoogleMaps, LatLng, CameraPosition, GoogleMapsEvent , Marker, MarkerOptions } from '@ionic-native/google-maps';
import {Geolocation} from '@ionic-native/geolocation';

@Component({
  selector: 'page-home',
  templateUrl: 'home.html'
})
export class HomePage {
 @ViewChild('map') mapelement : ElementRef;
 map : GoogleMap;
 initialMapLoad: boolean = true;
  constructor(public navCtrl: NavController, private _googlemap : GoogleMaps, 
    private _geolocation : Geolocation) {

  }
  ionViewDidLoad(){

    this.initMap();

  }


  initMap(){
    let element = this.mapelement.nativeElement;
    this.getlocation().then(res => {
      let loc = new LatLng(res.coords.latitude, res.coords.longitude);
      this.map = this._googlemap.create('map', {      
        camera:{
          target: loc,
          zoom: 15
        }

      });
      this.createmarker(loc, 'Me');
    }).catch (err => {
       console.log(err);
    });


  }
  ionViewDidEnter(){
    if (!this.initialMapLoad) {
      this.map.setDiv('map');
    } else {
      this.initialMapLoad = false;
    }
  }
  getlocation(){
    return this._geolocation.getCurrentPosition();
  }
  movecamer(loc : LatLng){
   let options : CameraPosition<LatLng> ={
     target: loc,
     zoom: 15,
     tilt: 10
   }
   this.map.moveCamera(options)
  }
  createmarker(loc: LatLng, title : string){
    let markeroptions : MarkerOptions = {
        position : loc,
        title : title
    }
    return this.map.addMarker(markeroptions);
  }

}

Кто-нибудь может мне помочь?и скажи мне, что здесь не так.

Почему карта зависла, и я не могу переместить карту?спасибо

1 Ответ

0 голосов
/ 07 августа 2018

Я решил проблему, удалив событие watchPosition, просто вызовем событие getCurrentPosition в обещании, и оно решит проблему с зависанием вкладки.

this.geolocation.getCurrentPosition().then((resp) => {
 // resp.coords.latitude
 // resp.coords.longitude
}).catch((error) => {
  console.log('Error getting location', error);
});
...