일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- ar vr 차이
- 안드로이드 유닛 테스트
- 객체
- jvm이란
- 멤버변수
- rxjava disposable
- 2022 플러터 안드로이드 스튜디오
- rxjava cold observable
- 서비스 vs 쓰레드
- jvm 작동 원리
- 서비스 쓰레드 차이
- 자바 다형성
- rxjava hot observable
- 안드로이드 레트로핏 crud
- 플러터 설치 2022
- 안드로이드 라이선스
- Rxjava Observable
- 스택 자바 코드
- 2022 플러터 설치
- 안드로이드 os 구조
- 큐 자바 코드
- android ar 개발
- android retrofit login
- 안드로이드 유닛 테스트 예시
- 안드로이드 라이선스 종류
- 안드로이드 레트로핏 사용법
- ANR이란
- 안드로이드 유닛테스트란
- 클래스
- 스택 큐 차이
- Today
- Total
나만을 위한 블로그
[Android Compose] Material3 SnackBar 사용법 본문
XML 뷰에선 간단하게 쓸 수 있던 스낵바가 Compose에선 좀 번거롭다. 아래는 스낵바를 사용하는 예시 컴포저블이다.
@Composable
fun SnackBarExample() {
val snackBarHostState = remember { SnackbarHostState() }
val coroutineScope = rememberCoroutineScope()
Scaffold(
snackbarHost = { SnackbarHost(hostState = snackBarHostState) }
) { innerPadding ->
Column(
modifier = Modifier
.padding(innerPadding)
.fillMaxSize(),
verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally,
) {
Button(
onClick = {
coroutineScope.launch {
snackBarHostState.showSnackbar(
message = "Hello SnackBar",
duration = SnackbarDuration.Short,
actionLabel = "label"
)
}
}
) {
Text("스낵바 표시")
}
}
}
}
프리뷰에서 확인하면 아래와 같다.
인터랙트 모드로 들어와서 버튼을 누르면 하단에 스낵바가 표시된다. 다크모드인 경우 스낵바 배경색과 글자색이 그에 맞춰 변한다.
아래는 디벨로퍼의 스낵바 공식문서다.
https://developer.android.com/develop/ui/compose/components/snackbar?hl=ko
스낵바를 구현하려면 먼저 SnackBarHostState 타입의 SnackBarHost를 만든다. SnackBarHostState는 showSnackbar()를 호출하는 데 사용할 수 있다. 이 정지 함수는 CoroutineScope가 필요하다(rememberCoroutineScope)
컴포즈에서 showSnackbar()는 정지 함수로 구현돼 있다. 그래서 코루틴 스코프를 만들어야 하고, SnackBarHostState를 remember로 기억시키는 처리가 필요하다.
val snackBarHostState = remember { SnackbarHostState() }
val coroutineScope = rememberCoroutineScope()
그리고 Column 안에 Button을 두고 onClick에서 스낵바를 표시한다.
Button(
onClick = {
coroutineScope.launch {
snackBarHostState.showSnackbar(
message = "Hello SnackBar",
duration = SnackbarDuration.Short,
actionLabel = "label"
)
}
}
)
message는 보다시피 스낵바에 표시할 메시지고 duration은 스낵바의 표시 시간이다. Short, Long, Indefinite 3가지 중 하나를 쓸 수 있다.
actionLabel에는 스낵바 안에서 오른쪽에 표시할 텍스트를 넣을 수 있다. 옵셔널이라 아예 안 쓰거나 null, 공백을 넣으면 표시되지 않는다. 참고로 showSnackbar()의 구현은 아래와 같다.
suspend fun showSnackbar(
message: String,
actionLabel: String? = null,
withDismissAction: Boolean = false,
duration: SnackbarDuration =
if (actionLabel == null) SnackbarDuration.Short else SnackbarDuration.Indefinite
): SnackbarResult
리턴타입이 SnackbarResult인 걸 볼 수 있다. 이 말은 showSnackbar()의 결과를 변수에 담아서 활용할 수도 있단 뜻이다.
Button(
onClick = {
coroutineScope.launch {
val result = snackBarHostState.showSnackbar(
message = "Hello SnackBar",
duration = SnackbarDuration.Short,
actionLabel = "label"
)
when (result) {
SnackbarResult.ActionPerformed -> {
Log.e("snackbar", "actionPerformed")
}
SnackbarResult.Dismissed -> {
Log.e("snackbar", "dismissed")
}
}
}
}
)
ActionPerformed, Dismissed 2종류가 있는데 아래 경우에 호출된다.
- ActionPerformed : actionLabel 버튼 클릭 시 호출
- Dismissed : 스낵바가 자연적으로 사라졌을 때 호출
ActionPerformed에는 undo를 넣어서 뭔가를 삭제한 다음 스낵바를 띄우고 undo 클릭 시 되돌리는 처리를 넣을 수 있겠다. Dismissed에도 필요한 처리를 넣으면 될 것이다.
'Android > Compose' 카테고리의 다른 글
[Android Compose] 버튼의 onClick으로 화면 이동하는 법 (0) | 2024.09.14 |
---|---|
[Android Compose] 바텀 네비게이션 바를 사용해서 컴포즈 화면 이동 구현하는 법 (0) | 2024.09.11 |
[Android Compose] Material 3 버전의 당겨서 새로고침(Pull to Refresh) 화면 구현하기 (0) | 2024.07.07 |
[Android Compose] Scaffold란? (0) | 2024.05.28 |
[Android Compose] 상태란? (0) | 2024.04.07 |