加载后如何打开React Native Maps标记的标注

时间:2019-10-08 17:23:41

标签: reactjs react-native react-native-maps

我希望在安装屏幕组件时打开所有标记的所有标注。当前,它仅在单击标记时才打开。如何在功能组件中使用useRef?

const markerRef = useRef(React.createRef)

return (
    <View style={styles.container}>
        <MapView 
            style={{ flex: 1 }} 
            region={region}
            onRegionChangeComplete={onRegionChangeComplete}
        >
            {data && data.posts.map(marker => (
                <Marker
                    ref={markerRef}
                    key={marker.id}
                    coordinate={{latitude: marker.latitude, longitude: marker.longitude }}    
                >
                    <Callout>
                        <Text>{marker.title}</Text>
                        <Text>{JSON.stringify(marker.price)}</Text>
                    </Callout>
                </Marker>
            ))}
        </MapView>
        <View style={styles.inputContainer}> 
            <Icon name="magnify" size={30} color="lightgrey" />
            <TextInput 
                placeholder="Search Term"
                style={styles.input}
                onChangeText={setSearch}
                value={search}
                returnKeyType="search"
                onSubmitEditing={handleSubmit}
            />
        </View>
    </View>

当我console.log(markerRef.current)时,它不提供showCallout()方法。

1 个答案:

答案 0 :(得分:1)

最干净的方法是创建自己的视图作为标记。 Arbitrary React Views as Markers

您可以看到标记here的示例。 这是使用here的示例。

这只是一个开始。您可以将自己的点击处理程序放在标记上并将其隐藏。

因此,这可能不太理想,但可以作为一种技巧。 从渲染功能开始。

renderCallout() {
    if(this.state.calloutIsRendered === true) return;
    this.setState({calloutIsRendered: true});
    this.markerRef.showCallout();
}

然后将其添加到onRegionChangeComplete事件中。

<MapView
  onRegionChangeComplete={() => this.renderCallout()}
  ...
>