Есть ли какой-нибудь способ узнать широту и долготу моего текущего местоположения в режиме реального времени, используя response-native-maps? - PullRequest
1 голос
/ 15 марта 2019

У меня проблема с моей мобильной системой отслеживания, это почти 2 дня назад, я не могу найти решение. Можете ли вы помочь мне, ребята, как получить текущий лонг и лонг в режиме реального времени? Я могу получить текущий лонг и лонг, но не в реальном времени,

Пример. Если я выхожу за пределы своего дома, автоматически мой лат и длинна этой области будут значением моего состояния. Что я имею в виду каждый раз, когда я переехал, я могу получить широту и длину моего местоположения.

Screenshot

Я покажу вам, ребята, мой код,

My Import and Const:

import MapView, { Marker } from 'react-native-maps';

const {width, height} = Dimensions.get('window')
const SCREEN_HEIGHT = height
const SCREEN_WIDTH = width
const ASPECT_RATIO = width / height
const LATTITUDE_DELTA = 0.005
const LONGTITUDE_DELTA = LATTITUDE_DELTA * ASPECT_RATIO 

Моя функция:

    constructor(props) {
    super(props);

    this.state = {

      currentLocation: {
        latitude:0,
        longitude:0,
        latitudeDelta:0,
        longitudeDelta:0
      },

      updatedLocation: {
        latitude:0,
        longitude:0,
        latitudeDelta:0,
        longitudeDelta:0
      },

      markerPosition: {
        latitude:0,
        longitude:0,
        latitudeDelta:0,
        longitudeDelta:0
      }


    }

  }



  async _currentPosition() {
    navigator.geolocation.getCurrentPosition((position) => {

      //lat and long current
      var lat = parseFloat(position.coords.latitude)
      var long = parseFloat(position.coords.longitude)

      var currentLocationValue = {
        latitude:lat,
        longitude:long,
        latitudeDelta:LATTITUDE_DELTA,
        longitudeDelta:LONGTITUDE_DELTA
      }

      this.setState({currentLocation:currentLocationValue})
      this.setState({markerPosition:currentLocationValue})

      console.log(currentLocationValue);


   },(error) => alert(JSON.stringify(error)),
   {enableHighAccuracy:true,timeout:5000})
  }


  async _updatedPosition() {
    this.watchID = navigator.geolocation.watchPosition((position) => {

        //lat and long current
        var lat = parseFloat(position.coords.latitude)
        var long = parseFloat(position.coords.longitude)

        var updateLocationValue = {
          latitude:lat,
          longitude:long,
          latitudeDelta:LATTITUDE_DELTA,
          longitudeDelta:LONGTITUDE_DELTA
        }

        this.setState({updatedLocation:updateLocationValue})
        this.setState({markerPosition:updateLocationValue})

        console.log(updateLocationValue);


    },(error) => alert(JSON.stringify(error)),
    {enableHighAccuracy:true,timeout:5000,maximumAge:2000})
  }


  componentDidMount() {
    this._currentPosition();
    this._updatedPosition();

  }

  componentWillUnmount() {
    //navigator.geolocation.clearWatch(this.watchID)
  }

Мой рендер:

    render() {
    return (
        <View style={styles.container}>

          <MapView 
              style = {styles.mapcontainer}
              region = {this.state.currentLocation}
              onRegionChange={this.onRegionChange}

              >

              <MapView.Marker 
                  coordinate={this.state.markerPosition}>
                  <View style={styles.radius}>
                      <View style={styles.marker}/>
                  </View>
              </MapView.Marker>

          </MapView>
          <Text>
            {this.state.markerPosition.latitude},{this.state.markerPosition.longitude}
          </Text>
        </View>
      )
  }
...