react native ProgressBarAndroid 使用详解

本文介绍了一个React Native应用程序中使用ProgressBarAndroid组件的方法。该应用通过不同的样式属性展示了多种类型的进度条,并实现了进度随时间自动更新的功能。此外,还提供了更改进度条颜色的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ProgressBarAndroid:android进度条

View props:可以使用View的所有属性
color:进度条颜色
indeterminate:是否要显示一个不确定的进度
progress:当前的进度值(在0到1之间)。
styleAttr:进度条的样式 Horizontal、Small、Large、Inverse、SmallInverse、LargeInverse

/**
 * Created by on 2017/5/17.
 */
import React, {Component} from 'react';
import {
    StyleSheet,
    View,
    ProgressBarAndroid,
    Text,
    Button,
} from 'react-native';

export default class ProgressBarAndroidDemo extends Component {
    static navigationOptions = {
        title: 'ProgressBarAndroid',
    };

    componentDidMount() {
        setInterval(() => {
            if (this.state.progress >= 1) {
                this.setState({progress: 0})
            } else {
                this.setState({progress: this.state.progress + 0.1})
            }

        }, 500)
    }

    state = {
        color: 'red',
        indeterminate: true,
        progress: 0,
        styleAttr: 'Large',
    }

    render() {
        return (
            <View style={{flex:1}}>
                <View style={{flexDirection:'row',alignItems:'center'}}>
                    <Text>设置color:</Text>
                    <Button title='red' onPress={()=>{this.setState({color:'red'})}}/>
                    <Button title='blue' onPress={()=>{this.setState({color:'blue'})}}/>
                </View>

                <ProgressBarAndroid
                    indeterminate={false}
                    color={this.state.color}
                    progress={this.state.progress}
                    styleAttr='Horizontal'/>


                <View style={{flexDirection:'row',alignItems:'center',flexWrap:'wrap'}}>
                    <Text>Horizontal</Text>
                    <ProgressBarAndroid
                        styleAttr='Horizontal'/>

                </View>

                <View style={{flexDirection:'row',alignItems:'center',flexWrap:'wrap'}}>
                    <Text>Small</Text>
                    <ProgressBarAndroid
                        styleAttr='Small'/>

                </View>

                <View style={{flexDirection:'row',alignItems:'center',flexWrap:'wrap'}}>
                    <Text>Large</Text>
                    <ProgressBarAndroid
                        styleAttr='Large'/>

                </View>

                <View style={{flexDirection:'row',alignItems:'center',flexWrap:'wrap'}}>
                    <Text>Inverse</Text>
                    <ProgressBarAndroid
                        styleAttr='Inverse'/>

                </View>

                <View style={{flexDirection:'row',alignItems:'center',flexWrap:'wrap'}}>
                    <Text>SmallInverse</Text>
                    <ProgressBarAndroid
                        styleAttr='SmallInverse'/>

                </View>

                <View style={{flexDirection:'row',alignItems:'center',flexWrap:'wrap'}}>
                    <Text>LargeInverse</Text>
                    <ProgressBarAndroid
                        styleAttr='LargeInverse'/>

                </View>
            </View>
        );
    }
}

这里写图片描述

github下载地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

老孟Flutter

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值