使用Google API坐标在react-native-map上添加多个折线

时间:2018-03-14 20:31:27

标签: react-native polyline google-polyline react-native-maps

我想在反应原生的谷歌地图上放置多条折线。我正在使用react-native-maps和@ mapbox /折线来创建我在顶部导入的折线:

import MapView from 'react-native-maps';
import Polyline from '@mapbox/polyline';

以下是代码的其余部分:

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

import React, { Component } from 'react';
import {
   Platform,
   StyleSheet,
   Text,
   View,
   Button
 } from 'react-native';

 export default class consults extends Component {
  constructor(props) {
  super(props);
  this.state = {
    coords: []
  }
 }

componentDidMount() {
   this.getDirections("55.23607109335242, 10.478553771972656", "55.178279530181264, 10.525074005126953");
   this.getDirections("55.067434, 10.607282", "55.093088, 10.588734");
 }

 async getDirections(startLoc, destinationLoc) {

   try {
       let resp = await fetch(`https://maps.googleapis.com/maps/api/directions/json?origin=${ startLoc }&destination=${ destinationLoc }&mode=${'walking'}`)
       let respJson = await resp.json();
       let points = Polyline.decode(respJson.routes[0].overview_polyline.points);

       let coords = points.map((point, index) => {
           return  {
               latitude : point[0],
               longitude : point[1]
           }
       })


       this.setState({coords: coords})
       return coords
   } catch(error) {
       alert(error)
       return error
   }
}


static navigationOptions = {
title: 'Kort over stier'
};

render () {
 const { navigate } = this.props.navigation;
 const { region } = this.props;
 console.log(region);

 return (
   <View style ={styles.container}>
    <MapView
      style={styles.map}
      region={{
        latitude: 55.0598,
        longitude: 10.6068,
        latitudeDelta: 0.40,
        longitudeDelta: 0.40,
      }}
    >

    <MapView.Polyline
        coordinates={this.state.coords}
        strokeWidth={2}
        strokeColor="red"/>

    </MapView>
  </View>
 )
}

}

const styles = StyleSheet.create({
container: {
position: 'absolute',
top: 0,
left: 0,
right: 0,
bottom: 0,
justifyContent: 'flex-end',
alignItems: 'center',
},
map: {
position: 'absolute',
top: 0,
left: 0,
right: 0,
bottom: 0,
},

});

当我只是请求从一个位置到另一个位置的坐标时,它会绘制一个行示例:

this.getDirections("55.23607109335242, 10.478553771972656", "55.178279530181264, 10.525074005126953");

当我请求两个时,我得到最后一个的坐标。知道如何在同一张地图上绘制多条折线的人吗?提前谢谢: - )

更新 从另一个stakoverflow问题中找到此示例图片。我想要相同但没有标记:

Polyline image

1 个答案:

答案 0 :(得分:1)

您是否尝试过存储多段线?必须对组件进行一些更改,顺便说一下:

     TIME      M1      M2  K1  K2        SEP  ECC  R1/ROL1  R2/ROL2  \
0  0.0000  30.000  15.000   1   1   694880.0  0.0    0.000      0.0   
1  0.0000  30.000  15.000   1   1   694880.0  0.0    0.000      0.0   
2  5.9523  27.735  14.912   2   1   733350.0  0.0    0.000      0.0   
3  5.9611  27.663  14.912   4   1   734590.0  0.0    0.004      0.0   
4  6.3588  14.790  14.903   4   1  1056200.0  0.0    0.004      0.0   

                                                TYPE  
0                                            INITIAL  
1  PreMS aperi=694884 t1=0 f1=0 R1=7.74028 R1/RLp...  
2                                         TYPE_CHNGE  
3                                         TYPE_CHNGE  
4                                              q-inv  

和渲染方法:

...
constructor(props) {
    super(props)
    this.state = { coordsArray: [] }
}
...
async getDirections(startLoc, destinationLoc) {
    ...
    const newCoordsArray = [ ...this.state.coordsArray, coords]
    this.setState({ coordsArray: newCoordsArray })
    ...
}
...