2017-06-21 60 views
1

我想要做一個workaround for this issue如果interactable.view快照到屏幕的頂部那麼該按鈕不會呈現,如果它捕捉到屏幕的底部然後按鈕呈現,利用Interactable.ViewonSnap屬性:反應本機Interactable對Android不起作用

代碼:

<Interactable.View 
     style={{ 
     height: Screen.height, 
     width: '100%', 
     zIndex: 19, 
     backgroundColor: '#222222', 
     position: 'absolute', 
     padding: 20 
     }} 
     onSnap={(e) => { 
     if(e.nativeEvent.index === 2) { 
      this.setState({showButton: false}) 
     } else { 
      this.setState({showButton: true}) 
     } 
     }} 
     boundaries={{ top: 0, bounce: 0.5 }} 
     verticalOnly={true} 
     snapPoints={[ 
     { y: (Platform.OS === 'ios') ? Screen.height - 55 : Screen.height - 85, damping: 0.7 }, 
     { y: (Platform.OS === 'ios') ? Screen.height - 190 : Screen.height - 230, damping: 0.7 }, 
     { y: 0, damping: 0.7 } 
     ]} 
     initialPosition={{ x: 0, y: (Platform.OS === 'ios') ? Screen.height - 55 : Screen.height - 85 }} 


     ref={view => this.interactableView2 = view}> 

    </Interactable.View> 

    {this.state.showButton && 
     <Button 
     small 
     icon 
     ref={view => this.button1 = view} 
     style={mapStyle.toggleMenuButton} 
     onPress={() => { 
      this.interactableView.snapTo({ index: 0 }) 
      this.props.onToggleMenuClick() 
      this.props.setSelectedShop({ id: -1 }) 
      this.props.updateSearchResults({ products: [] }) 
     }}> 
     <Icon name="sliders" size={20} color="#FFFFFF" /> 
     </Button> 
    } 

它適用於iOS和Android上不知何故從連動頂端停止Interactable.View,並且按鈕只是失去了它的圖標,變得無法點擊。在控制檯中不顯示錯誤。

任何想法,爲什麼Android的如此越野車?

編輯:這裏是按鈕的應該消失風格:

export default { 
    toggleMenuButton: { 
    top: 30, 
    left: 10, 
    width: 50, 
    position: 'absolute', 
    zIndex: 5, 
    height: 50, 
    borderRadius: 25, 
    backgroundColor: '#FF3B3F', 
    shadowColor: '#000000', 
    shadowOffset: { 
     width: 0, 
     height: 1 
    }, 
    shadowRadius: 1, 
    shadowOpacity: 1.0 
    } 
} 

編輯:全碼:

Map.js

import { 
    StyleSheet, 
    View, 
    Text, 
    FlatList, 
    TouchableHighlight, 
    Dimensions, 
    Platform, 
    //findNodeHandle, 
    Image 
} from 'react-native' 
import React, { Component } from 'react' 
import MapView from 'react-native-maps' 
import { connect } from 'react-redux' 
import { 
    Button, 
    Container 
} from 'native-base' 

import { updateRegion } from './map.action' 
import Icon from 'react-native-vector-icons/FontAwesome' 
import { toggleMenu } from '../search-page/searchPage.action' 
import mapStyle from './style' 
import Interactable from 'react-native-interactable' 
import { setSelectedShop } from '../search-results/searchResults.action' 
import { updateHeight } from '../search-results/searchResultsPresenter.action' 
import { getSelectedProduct } from './markers.selector' 
import { updateSearchResults } from '../search-page/searchPage.action' 
//import { BlurView } from 'react-native-blur' 


const Screen = { 
    width: Dimensions.get('window').width, 
    height: Dimensions.get('window').height 
} 

const mapStateToProps = (state) => ({ 
    region: state.get('map').get('region'), 
    markers: state.get('searchResults').get('products'), 
    selectedProduct: getSelectedProduct(state) 
}) 

const mapDispatchToProps = (dispatch) => ({ 
    onRegionChange: (region) => { 
    dispatch(updateRegion(region)) 
    }, 
    updateSearchResults: (results) => { 
    dispatch(updateSearchResults(results)) 
    }, 
    onToggleMenuClick:() => { 
    dispatch(toggleMenu()) 
    }, 
    setSelectedShop: id => { 
    dispatch(setSelectedShop(id)) 
    }, 
    updateHeight: height => { 
    dispatch(updateHeight(height)) 
    } 
}) 

class Map extends Component { 

    constructor(props) { 
    super(props) 
    //this.state = { viewRef: null } 
    } 

    componentDidMount() { 
    const { store } = this.context 
    this.unsubscribe = store.subscribe(() => { }) 
    //this.setState({ viewRef: findNodeHandle(this.viewToBlur) }) 
    } 

    componentWillUnmount() { 
    this.unsubscribe() 
    } 

    interactableView; 
    interactableView2; 

    render() { 
    return (
     <Container> 
     <MapView 
      style={styles.map} 
      region={this.props.region} 
      onRegionChangeComplete={this.props.onRegionChange}> 
      { 
      this.props.markers.map(marker => { 
       return (
       <MapView.Marker 
        coordinate={marker.shop.coordinate} 
        title={marker.shop.name} 
        identifier={marker.shop.id.toString()} 
        onPress={e => { 
        console.log(e.nativeEvent) 
        this.interactableView.snapTo({ index: 1 }) 
        this.props.setSelectedShop(marker.shop) 
        console.log(this.props.selectedProduct) 
        }} 
       /> 
      ) 
      }) 
      } 
     </MapView> 

//********************************************************************// 
       the button 
//********************************************************************// 

     <Button 
      small 
      icon 
      style={mapStyle.toggleMenuButton} 
      onPress={() => { 
      this.interactableView.snapTo({ index: 0 }) 
      this.props.onToggleMenuClick() 
      this.props.setSelectedShop({ id: -1 }) 
      this.props.updateSearchResults({ products: [] }) 
      }}> 
      <Icon name="sliders" size={20} color="#FFFFFF" /> 
     </Button> 

//********************************************************************// 
       the interactable.view 
//********************************************************************// 

     <Interactable.View 
      style={{ 
      height: Screen.height, 
      width: '100%', 
      zIndex: 19, 
      backgroundColor: '#222222', 
      position: 'absolute', 
      borderRadius: 10, 
      padding: 20 
      }} 
      boundaries={{ top: 0, bounce: 0.5 }} 
      verticalOnly={true} 
      snapPoints={[ 
      { y: (Platform.OS === 'ios') ? Screen.height - 55 : Screen.height - 85, damping: 0.7 }, 
      { y: (Platform.OS === 'ios') ? Screen.height - 190 : Screen.height - 230, damping: 0.7 }, 
      { y: 0, damping: 0.7 } 
      ]} 
      initialPosition={{ x: 0, y: (Platform.OS === 'ios') ? Screen.height - 55 : Screen.height - 85 }} 


      ref={view => this.interactableView2 = view}> 

      </Interactable.View> 


     <Interactable.View 
      style={{ 
      height: Screen.height, 
      width: '100%', 
      zIndex: 20, 
      backgroundColor: '#222222', 
      borderRadius: 10, 
      padding: 20 
      }} 
      boundaries={{ top: 0, bounce: 0.5 }} 
      verticalOnly={true} 
      snapPoints={[{ y: (Platform.OS === 'ios') ? Screen.height - 55 : Screen.height - 85, damping: 0.7 }, 
      { y: (Platform.OS === 'ios') ? Screen.height - 190 : Screen.height - 230, damping: 0.7 }]} 
      initialPosition={{ x: 0, y: (Platform.OS === 'ios') ? Screen.height - 55 : Screen.height - 85 }} 
      ref={view => this.interactableView = view}> 
      <View 
      style={{ width: '100%', height: 200 }}> 
      <Text 
       style={{ 
       color: 'white', 
       marginTop: (Platform.OS === 'ios') ? 0 : 2, 
       marginBottom: (Platform.OS === 'ios') ? 20 : 25, 
       textAlign: 'center', 
       width: '100%' 
       }}> 
       {this.props.selectedProduct ? this.props.selectedProduct.shop.name : ''} 
      </Text> 
      {this.props.selectedProduct ? (
       <FlatList 
       horizontal={true} 
       style={{ 
        height: 200 
       }} 
       data={this.props.selectedProduct ? this.props.selectedProduct.products : [{ name: '' }]} 
       renderItem={({ item }) => { 
        return (
        <TouchableHighlight onPress={() => this.interactableView2.snapTo({ index: 2 })}> 
         <View 

         //ref={x => this.viewToBlur = x} 
         style={{ width: 100, marginRight: 20 }}> 
         {/*<View style={{ 
          borderWidth: 1, 
          borderColor: 'black', 
          margin: 0, 
          backgroundColor: 'red' 
         }} />*/} 
         {item.image ? (
         <Image 
          style={{ 
          width: 100, 
          height: 100, 
          zIndex: 45 
          }} 
          source={{ uri: item.image }} 
         />) : (
          <Image 
          style={{ 
          width: 100, 
          height: 100, 
          zIndex: 45 
          }} 
          source={ require('../add-page/noimage.png') } 
         /> 
         )} 

         <Text style={{ 
          color: 'white', 
          width: '100%', 
          textAlign: 'center' 
         }}>{item.name}</Text> 
         </View> 

        </TouchableHighlight> 
       ) 
       }} />) : <View />} 
      </View> 
      {/*<BlurView 
      style={{ 
       position: 'absolute', 
       top: 0, 
       bottom: 0, 
       left: 0, 
       right: 0, 
       borderWidth: 1, 
       borderColor: 'black', 
       zIndex: 60 
      }} 
      blurType="dark" 
      viewRef={this.state.viewRef} 
      blurAmount={20} 
      blurRadius={20} />*/} 
     </Interactable.View> 
     </Container > 
    ) 
    } 
} 



Map.contextTypes = { 
    store: React.PropTypes.object 
} 

Map.propTypes = { 
    region: React.PropTypes.shape({ 
    latitude: React.PropTypes.number, 
    longitude: React.PropTypes.number, 
    latitudeDelta: React.PropTypes.number, 
    longitudeDelta: React.PropTypes.number 
    }).isRequired, 
    updateHeight: React.PropTypes.func, 
    setSelectedShop: React.PropTypes.func, 
    selectedProduct: React.PropTypes.object, 
    onRegionChange: React.PropTypes.func.isRequired, 
    onToggleMenuClick: React.PropTypes.func.isRequired, 
    markers: React.PropTypes.array, 
    updateSearchResults: React.PropTypes.func 
} 

export default connect(
    mapStateToProps, 
    mapDispatchToProps 
)(Map) 

const styles = StyleSheet.create({ 
    map: { 
    ...StyleSheet.absoluteFillObject, 
    zIndex: 3 
    } 
}) 

回答

0

我們在這裏看不到你的風格,但它看起來像是同樣的問題y你在相關的問題中。

elevation覆蓋zIndex,所以它可以使您的按鈕可以在視圖的頂部,但由於React Native計算根據zIndex和完全無視elevation你的觸動 - 您的按鈕位於頂部,但觸摸實際上是要與視圖高於其下方的zIndex。如果同樣的事情發生在我身上,花了我一天的時間才意識到問題所在。

+0

謝謝,雖然這似乎不是我不幸的解決方案。我完全刪除了高程,問題依然存在。它也不能解釋爲什麼我的解決方法在Android上創建了一個新的奇怪的錯誤。 – BeniaminoBaggins

+0

它創建了什麼奇怪的錯誤?我想我描述了你所做的同樣的事情,我有同樣的問題。另外,請添加'toggleMenuButton'的樣式,以便我們可以給您更好的幫助。 –

+0

我剛剛用樣式更新了問題。該錯誤:在Android上,它以某種方式停止了'Interactable.View'甚至移動到屏幕的頂部,並且該按鈕保持可見狀態,並且丟失了它的圖標,並且變得無法使用。所以基本上在iOS上,按鈕會消失,而在Android上它永遠不會消失。謝謝。 – BeniaminoBaggins