Scaffold

Material Design에서 스켈레톤은 복잡한 사용자 인터페이스를 위한 표준화된 플랫폼을 제공하는 기본 구조입니다. 앱 바 및 플로팅 작업 버튼과 같은 UI의 여러 부분을 함께 유지하여 앱에 일관된 디자인을 제공합니다.

Scaffold 컴포저블은 Material Design 가이드라인에 따라 앱 구조를 빠르게 조합하는 데 사용할 수 있는 간단한 API를 제공합니다. Scaffold는 여러 컴포저블을 매개변수로 허용합니다. 여기에는 다음이 포함됩니다.

  • topBar: 화면 상단에 있는 앱 바입니다.
  • bottomBar: 화면 하단에 있는 앱 바입니다.
  • floatingActionButton: 화면 오른쪽 하단에 마우스를 가져가면 표시되는 버튼으로, 주요 작업을 노출하는 데 사용할 수 있습니다.

상단 및 하단 앱 바를 모두 구현하는 방법에 관한 자세한 예는 앱 바 페이지를 참고하세요.

다른 컨테이너에 전달하는 것처럼 Scaffold 콘텐츠를 전달할 수도 있습니다. innerPadding 값을 content 람다에 전달하며, 이 값은 하위 컴포저블에서 사용할 수 있습니다.

다음 예는 Scaffold를 구현하는 방법의 전체 예를 제공합니다. 여기에는 상단 앱 바, 하단 앱 바, Scaffold의 내부 상태와 상호작용하는 플로팅 작업 버튼이 포함되어 있습니다.

@Composable
fun ScaffoldExample() {
    var presses by remember { mutableIntStateOf(0) }

    Scaffold(
        topBar = {
            TopAppBar(
                colors = topAppBarColors(
                    containerColor = MaterialTheme.colorScheme.primaryContainer,
                    titleContentColor = MaterialTheme.colorScheme.primary,
                ),
                title = {
                    Text("Top app bar")
                }
            )
        },
        bottomBar = {
            BottomAppBar(
                containerColor = MaterialTheme.colorScheme.primaryContainer,
                contentColor = MaterialTheme.colorScheme.primary,
            ) {
                Text(
                    modifier = Modifier
                        .fillMaxWidth(),
                    textAlign = TextAlign.Center,
                    text = "Bottom app bar",
                )
            }
        },
        floatingActionButton = {
            FloatingActionButton(onClick = { presses++ }) {
                Icon(Icons.Default.Add, contentDescription = "Add")
            }
        }
    ) { innerPadding ->
        Column(
            modifier = Modifier
                .padding(innerPadding),
            verticalArrangement = Arrangement.spacedBy(16.dp),
        ) {
            Text(
                modifier = Modifier.padding(8.dp),
                text =
                """
                    This is an example of a scaffold. It uses the Scaffold composable's parameters to create a screen with a simple top app bar, bottom app bar, and floating action button.

                    It also contains some basic inner content, such as this text.

                    You have pressed the floating action button $presses times.
                """.trimIndent(),
            )
        }
    }
}

이 구현은 다음과 같이 표시됩니다.

간단한 상단 및 하단 앱 바와 카운터를 반복하는 플로팅 작업 버튼이 포함된 스캐폴드의 구현입니다. 스캐폴드의 내부 콘텐츠는 구성요소를 설명하는 간단한 텍스트입니다.
그림 1. 스캐폴드의 구현입니다.

추가 리소스