javascript - react native - react-native-maps initialRegion 不起作用

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

我使用 react-native-maps 为 iOS 设备集成了 Google map 。我遇到一个问题,即在我重新渲染 map 后 initialRegion 不起作用。

我的应用程序只包含 2 个组件:来自 react-native-mapsMapView 和一个 Button。单击按钮可显示或隐藏 map 。

这是我的代码:

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)
}

第一次加载 map ,一切正常。但是,当我隐藏 map 并通过单击按钮再次显示它时,它会呈现一个随机区域:

{ 
  longitude: 0,
  latitudeDelta: 0.0004935264587338631,
  latitude: 0,
  longitudeDelta: 0.00027760863304138184 
}

我试过 cacheEnabled 等于 truefalse 但没有帮助。如果您有任何建议,请告诉我。预先感谢您!

最佳答案

当你第一次加载页面时,它会调用 initialRegion,当你隐藏显示 map 时,它不会再次调用 initialRegion 函数,因为 map 已经加载过,所以你需要在隐藏/显示方法上调用函数并通过以下方法设置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** } }            
          >

关于javascript - react native - react-native-maps initialRegion 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46924415/

相关文章:

javascript - 在 Node js 中 for 循环完成时调用函数

ios - 'dump' 核心数据堆栈的最佳方法?

ios - 如何在屏幕导航期间删除 ios 中的黑色?

ios - Iphone 桌面 View

javascript - 使用 maps api v3 获取间歇性 'google not defined' 和其他错误

javascript - 根据 URL 显示切换 div

javascript - 当用户退出我的网站时播放音频

javascript - rowCallback 和 createdRow 不突出显示行

javascript - 谷歌地图 api place_changed 事件未触发

google-maps - Google Maps Api - 使用鼠标点击删除标记