Reference version

This is documentation for the next SDK version. For up-to-date documentation, see the latest version (SDK 55).

进度指示器

用于显示操作状态的 Jetpack Compose 进度指示器组件。

Android

For the complete documentation index, see llms.txt. Use this Use this file to discover all available pages.

Expo UI 进度指示器与官方 Jetpack Compose Progress Indicator API 保持一致。

安装

Terminal
npx expo install @expo/ui

If you are installing this in an existing React Native app, make sure to install expo in your project.

用法

线性进度

一个水平条,通过填充来表示进度。在确定模式下,请提供一个介于 01 之间的 progress 值。

LinearExample.tsx
import { Host, LinearProgressIndicator } from '@expo/ui/jetpack-compose'; export default function LinearExample() { return ( <Host matchContents> <LinearProgressIndicator progress={0.5} /> </Host> ); }

圆形进度

一个旋转的圆环,其描边会增长以表示进度。

CircularExample.tsx
import { Host, CircularProgressIndicator } from '@expo/ui/jetpack-compose'; export default function CircularExample() { return ( <Host matchContents> <CircularProgressIndicator progress={0.75} /> </Host> ); }

不确定进度

省略 progress 属性即可持续动画显示,而不指示具体完成比例。

IndeterminateExample.tsx
import { CircularProgressIndicator, CircularWavyProgressIndicator, Column, Host, LinearProgressIndicator, LinearWavyProgressIndicator, } from '@expo/ui/jetpack-compose'; export default function IndeterminateExample() { return ( <Host matchContents> <Column verticalArrangement={{ spacedBy: 16 }}> <LinearProgressIndicator /> <CircularProgressIndicator /> <CircularWavyProgressIndicator /> <LinearWavyProgressIndicator /> </Column> </Host> ); }

自定义颜色

使用 color 设置指示器颜色,使用 trackColor 设置背景轨道颜色。

ColorsExample.tsx
import { Host, CircularProgressIndicator } from '@expo/ui/jetpack-compose'; export default function ColorsExample() { return ( <Host matchContents> <CircularProgressIndicator progress={0.6} color="red" trackColor="#cccccc" /> </Host> ); }

波浪变体

LinearWavyProgressIndicatorCircularWavyProgressIndicator 添加了来自 Material 3 Expressive 的富有表现力的波浪动画。

WavyExample.tsx
import { Host, LinearWavyProgressIndicator, CircularWavyProgressIndicator, Column, } from '@expo/ui/jetpack-compose'; export default function WavyExample() { return ( <Host matchContents> <Column verticalArrangement={{ spacedBy: 16 }}> <LinearWavyProgressIndicator progress={0.6} /> <CircularWavyProgressIndicator progress={0.6} /> </Column> </Host> ); }

API

import { LinearProgressIndicator, CircularProgressIndicator, LinearWavyProgressIndicator, CircularWavyProgressIndicator, } from '@expo/ui/jetpack-compose';

Components

CircularProgressIndicator

Android

Type: React.Element<ComponentType<CircularProgressIndicatorProps>>

A circular progress indicator that displays progress in a circular format.

Matches the Jetpack Compose CircularProgressIndicator.

CircularProgressIndicatorProps

gapSize

Android
Optional • Type: number

Gap size between the indicator and track in dp.

strokeCap

Android
Optional • Type: StrokeCap • Default: 'round'

Stroke cap style for the indicator ends.

strokeWidth

Android
Optional • Type: number

Width of the circular stroke in dp.

Inherited Props

CircularWavyProgressIndicator

Android

Type: React.Element<ComponentType<ProgressCommonConfig>>

A circular progress indicator with wavy animation style.

Matches the Jetpack Compose CircularWavyProgressIndicator.

LinearProgressIndicator

Android

Type: React.Element<ComponentType<LinearProgressIndicatorProps>>

A linear progress indicator that displays progress in a horizontal bar.

Matches the Jetpack Compose LinearProgressIndicator.

LinearProgressIndicatorProps

drawStopIndicator

Android
Optional • Type: DrawStopIndicatorConfig

Configuration for the stop indicator dot at the end of the determinate progress track.

gapSize

Android
Optional • Type: number

Gap size between the indicator and track in dp.

strokeCap

Android
Optional • Type: StrokeCap • Default: 'round'

Stroke cap style for the indicator ends.

Inherited Props

LinearWavyProgressIndicator

Android

Type: React.Element<ComponentType<LinearWavyProgressIndicatorProps>>

A linear progress indicator with wavy animation style.

Matches the Jetpack Compose LinearWavyProgressIndicator.

LinearWavyProgressIndicatorProps

stopSize

Android
Optional • Type: number

Size of the stop indicator in dp at the end of the determinate progress track.

Inherited Props

Types

DrawStopIndicatorConfig

Android

Configuration for the stop indicator dot at the end of the determinate linear progress track. When provided, draws a stop indicator with the given options. Omit to use the Compose default.

PropertyTypeDescription
color(optional)ColorValue

Color of the stop indicator. Defaults to the indicator's color.

stopSize(optional)number

Size of the stop indicator in dp. Defaults to the Material 3 default.

strokeCap(optional)StrokeCap

Stroke cap style for the stop indicator. Defaults to the indicator's strokeCap.

ProgressCommonConfig

Android

Common props shared by all progress indicator variants.

PropertyTypeDescription
color(optional)ColorValue

Progress indicator color.

modifiers(optional)ModifierConfig[]

Modifiers for the component.

progress(optional)number | null

The current progress value between 0 and 1. Omit for indeterminate.

trackColor(optional)ColorValue

Track (background) color.

StrokeCap

Android

Literal Type: string

Stroke cap style for progress indicators.

Acceptable values are: 'round' | 'butt' | 'square'