反应原生 - react-native-maps initialRegion不起作用

时间:2017-10-25 05:09:54

标签: javascript ios google-maps react-native react-native-maps

我使用react-native-maps整合了Google地图for iOS设备。我有一个问题,initialRegion在重新渲染地图后无效。

我的应用程序仅包含2个组件:来自MapView的{​​{1}}和react-native-maps。单击按钮以显示或隐藏地图。

这是我的代码:

Button

第一次加载地图,一切都很完美。但是,当我隐藏地图并通过单击按钮再次显示它时,它会呈现一个随机区域:

render() {
    return (
        <View style={styles.mapContainer}>
            {this.renderMap()}
            <TouchableOpacity
                onPress={this.onButtonPress.bind(this)}
                style={styles.showMapButtonContainer}>
                <Text style={styles.showMapButtonText}>Show and Hide Map</Text>
            </TouchableOpacity>
        </View>
    );
}

renderMap() {
    if (this.state.showMap) {
        return (
            <MapView
                provider={PROVIDER_GOOGLE}
                style={styles.map}
                initialRegion={{
                    latitude: 37.78825,
                    longitude: -122.4324,
                    latitudeDelta: LATITUDE_DELTA,
                    longitudeDelta: LONGITUDE_DELTA,
                }}
                cacheEnabled={true}
                onRegionChangeComplete={this.onRegionChangeComplete.bind(this)}
            >
            </MapView>
        );
    } else {
        return <View style={styles.map}/>;
    }
}

onButtonPress() {
    this.setState({
        showMap: !this.state.showMap,
    })
}

onRegionChangeComplete(region) {
    console.log("new region", region)
}

我尝试{ longitude: 0, latitudeDelta: 0.0004935264587338631, latitude: 0, longitudeDelta: 0.00027760863304138184 } 等于cacheEnabledtrue但没有帮助。如果您有任何建议,请告诉我。提前谢谢!

1 个答案:

答案 0 :(得分:1)

当您第一次加载页面时,它将调用initialRegion,当您隐藏显示地图时,它将不会再次调用initialRegion函数,因为地图已经加载,因此您需要调用函数隐藏/ show method并通过以下方法设置initialRegion

this.map.setNativeProps({ region });

this.map.animateToRegion({
       latitude: this.props.latitude,
       longitude: this.props.longitude,
       longitudeDelta: LONGITUDE_DELTA ,
       latitudeDelta: LATITUDE_DELTA
}, 1)}

您需要按照以下方式添加ref={ref => { this.map = ref; } },因此在功能方面,您需要this.map作为参考

         <MapView                   
                ref={ref => { this.map = ref; } }                 
                initialRegion={{
                  latitude: 37.78825,
                  longitude: -122.4324,
                  latitudeDelta: LATITUDE_DELTA,
                  longitudeDelta: LONGITUDE_DELTA,
                }}
                 onRegionChangeComplete={(region) => { **somefuncation** } }            
          >
相关问题