2017-07-21 197 views
0

我是0123,的新手任何人都可以請告訴我如何使用進度條創建一個標題菜單,如附加圖像。任何意見,非常感謝...React-native導航進度條

我已經取得了進展,我怎樣才能刪除在每一步之間的空間?

enter image description here

<View style={styles.stepIndicatorBox}> 
     {stepsIds.map((step, idx) => { 
     const words = steps[step].split(' '); 
     const activeStepStyle = step === activeStep && styles.activeStep; 
     return (
      <View key={`${step}${idx}`}> 
      <Svg height="25" width="100"> 
       <Line 
       x1="10" 
       y1="10" 
       x2="100" 
       y2="10" 
       stroke={theme.colors.blue} 
       strokeWidth="2" 
       /> 
       <Circle 
       cx="50" 
       cy="10" 
       r="3" 
       stroke={theme.colors.blue} 
       strokeWidth="2.5" 
       fill={theme.colors.lightBlue} 
       /> 
      </Svg> 
      {words.map(w => 
       <Text style={[styles.stepName, activeStepStyle]}> 
       {w} 
       </Text> 
      )} 
      </View> 
     ); 
     })} 
    </View> 

我的風格是:

const styles = StyleSheet.create({ 
    sceneContainer: { 
    bottom: 0, 
    left: 0, 
    position: 'absolute', 
    right: 0, 
    top: 0, 
    }, 
    stepIndicatorBox: { 
    height: theme.utils.em(4), 
    flexDirection: 'row', 
    alignItems: 'center', 
    justifyContent: 'space-between', 
    backgroundColor: theme.colors.lightBlue, 
    paddingHorizontal: theme.metrics.mainPadding, 
    }, 
    activeStep: { 
    ...theme.fontStyles.smallBold, 
    color: theme.colors.activeStepName, 
    fontWeight: 'bold', 
    }, 
    stepName: { 
    ...theme.fontStyles.small, 
    color: theme.colors.blue, 
    textAlign: 'center', 
    }, 
}); 
+0

爲什麼向下票????????我還應該怎麼說這個問題? – Bomber

+0

不用擔心,我爲你優惠! :)我認爲這是一個很好的問題,但我認爲downvoter希望你展示你嘗試過的東西,這在SO中是推薦的,例如參見[常見問題]。 – David

+0

感謝您的解釋,我現在明白了 – Bomber

回答

0

我用下面的代碼和react-native-svg

_renderStepIndicator =() => { 
     const { navigation } = this.props; // {dispatch} 
     const { steps, getStep } = stepsOptions; 

     const route = navigation.state.routes[navigation.state.routes.length - 1]; 
     const activeStep = getStep(route.routeName); 
     const stepsIds = Object.keys(steps); 
     const { height, width } = Dimensions.get('window'); 

     const stepWidth = width/5; 

     const RouteComponent = StepIndicatorRouter.getComponentForRouteName(
     route.routeName 
    ); 

     if (RouteComponent.navigatorType === STEP_INDICATOR) { 
     return null; 
     } 

     return (
     <View style={styles.stepIndicatorBox}> 
      {stepsIds.map((step, idx) => { 
      const words = steps[step].split(' '); 
      const activeStepStyle = step === activeStep && styles.activeStep; 

      return (
       <View key={`${step}${idx}`} style={styles.stepIndicatorStep}> 
       <Svg height="25" width={stepWidth}> 
        <Line 
        x1="0" 
        y1="15" 
        x2={stepWidth} 
        y2="15" 
        stroke={theme.colors.blue} 
        strokeWidth="2" 
        /> 
        <Circle 
        cx="40" 
        cy="15" 
        r="3" 
        stroke={theme.colors.blue} 
        strokeWidth="2" 
        fill={ 
         step === activeStep 
         ? theme.colors.blue 
         : theme.colors.lightBlue 
        } 
        /> 
       </Svg> 
       {words.map(w => 
        <Text style={[styles.stepName, activeStepStyle]}> 
        {w} 
        </Text> 
       )} 
       </View> 
      ); 
      })} 
     </View> 
    ); 
    };