Skip to content

Commit

Permalink
[Feat]: 애니메이션 적용 (#106)
Browse files Browse the repository at this point in the history
  • Loading branch information
jinuemong authored Feb 20, 2024
1 parent 722f9c4 commit 9f6ddaf
Show file tree
Hide file tree
Showing 16 changed files with 569 additions and 395 deletions.
4 changes: 2 additions & 2 deletions gradle/libs.versions.toml
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ ktor = "2.3.7"
kotlinx-serialization = "1.6.1"
# UI
coil-compose = "2.4.0"
lottie = "5.2.0"
lottie-compose = "5.2.0"
holix-bottomsheet-compose = "1.3.1"
chargemap-picker-compose = "1.0.3"
constraintlayout-compose = "1.0.1"
Expand Down Expand Up @@ -96,7 +96,7 @@ kotlinx-serialization = { module = "org.jetbrains.kotlinx:kotlinx-serialization-
# UI
coil-compose = { module = "io.coil-kt:coil-compose", version.ref = "coil-compose" }
ted-permission = { module = "io.github.ParkSangGwon:tedpermission-coroutine", version.ref = "ted-permission" }
lottie = { module = "com.airbnb.android:lottie", version.ref = "lottie" }
lottie-compose = { module = "com.airbnb.android:lottie-compose", version.ref = "lottie-compose" }
holix-bottomsheet-compose = { module = "com.holix.android:bottomsheetdialog-compose", version.ref = "holix-bottomsheet-compose" }
chargemap-picker-compose = { module = "com.chargemap.compose:numberpicker", version.ref = "chargemap-picker-compose" }
constraintlayout-compose = { module = "androidx.constraintlayout:constraintlayout-compose", version.ref = "constraintlayout-compose" }
Expand Down
2 changes: 1 addition & 1 deletion presentation/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ dependencies {
implementation(libs.hilt.compose)

implementation(libs.bundles.androidx.presentation)
implementation(libs.lottie)
implementation(libs.lottie.compose)
implementation(libs.coil.compose)
implementation(libs.holix.bottomsheet.compose)
implementation(libs.chargemap.picker.compose)
Expand Down

Large diffs are not rendered by default.

Large diffs are not rendered by default.

Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,9 @@ class HistoryViewModel @Inject constructor(
{ getGroupHeartHistoryUseCase() },
{ getUnrecordedScheduleListUseCase("") }
).onSuccess { (groups, unrecordedSchedule) ->
_state.value = HistoryState.Init
_groups.value = groups
_unrecordedSchedule.value = unrecordedSchedule
_state.value = HistoryState.Init
}.onFailure { exception ->
_state.value = HistoryState.Init
when (exception) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ import androidx.compose.foundation.layout.width
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
Expand All @@ -38,6 +39,10 @@ import androidx.compose.ui.text.font.FontWeight
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.Dp
import androidx.compose.ui.unit.dp
import com.airbnb.lottie.compose.LottieAnimation
import com.airbnb.lottie.compose.LottieCompositionSpec
import com.airbnb.lottie.compose.LottieConstants
import com.airbnb.lottie.compose.rememberLottieComposition
import kotlinx.datetime.LocalDate

@Composable
Expand All @@ -49,13 +54,58 @@ fun HistoryDetailBackgroundComponent(
onClickGrowthInfo: () -> Unit,
onClickBack: () -> Unit
) {

val animationBottomOffset = when(currentGrowthType){
HistoryDetailGrowthType.LEVEL_ONE -> (-42.73).dp
HistoryDetailGrowthType.LEVEL_TWO -> (-3.38).dp
HistoryDetailGrowthType.LEVEL_THREE -> 21.92.dp
HistoryDetailGrowthType.LEVEL_FOUR -> 18.18.dp
HistoryDetailGrowthType.LEVEL_FIVE -> 19.53.dp
HistoryDetailGrowthType.LEVEL_SIX -> 9.37.dp
}

val animationEndOffset = when(currentGrowthType){
HistoryDetailGrowthType.LEVEL_ONE -> (-44.24).dp
HistoryDetailGrowthType.LEVEL_TWO -> (-15.51).dp
HistoryDetailGrowthType.LEVEL_THREE -> (-13.78).dp
HistoryDetailGrowthType.LEVEL_FOUR -> (-12.74).dp
HistoryDetailGrowthType.LEVEL_FIVE -> 3.72.dp
HistoryDetailGrowthType.LEVEL_SIX -> 99.14.dp
}

val animationRaw = when(currentGrowthType){
HistoryDetailGrowthType.LEVEL_ONE -> R.raw.history_lv_1
HistoryDetailGrowthType.LEVEL_TWO -> R.raw.history_lv_2
HistoryDetailGrowthType.LEVEL_THREE -> R.raw.history_lv_3
HistoryDetailGrowthType.LEVEL_FOUR -> R.raw.history_lv_4
HistoryDetailGrowthType.LEVEL_FIVE -> R.raw.history_lv_5
HistoryDetailGrowthType.LEVEL_SIX -> R.raw.history_lv_6
}
val composition by rememberLottieComposition(
spec = LottieCompositionSpec.RawRes(resId = animationRaw)
)

Box(
modifier = Modifier
.fillMaxWidth()
.height(contentHeight)
.background(color = Color(currentGrowthType.backgroundColor))
) {

Box(
modifier = Modifier
.align(Alignment.BottomEnd)
.offset(
y = animationBottomOffset,
x = animationEndOffset
)
){
LottieAnimation(
composition = composition,
iterations = LottieConstants.IterateForever
)
}

Box(
modifier = Modifier
.align(Alignment.BottomStart)
Expand Down Expand Up @@ -109,11 +159,6 @@ fun HistoryDetailBackgroundComponent(
)
}

//TODO Lottie
Box(
modifier = Modifier.align(Alignment.BottomEnd)
)

Column(
modifier = Modifier
.fillMaxSize()
Expand Down Expand Up @@ -226,73 +271,140 @@ fun HistoryDetailBackgroundComponent(
}
}

private val sampleHistoryDetailModel = HistoryDetailModel(
state = HistoryDetailState.Init,
relationDetail = RelationDetailWithUserInfo(
id = 0L,
name = "김진우",
imageUrl = "",
memo = "무르는 경사비 관리앱으로 사용자가 다양한 개인적인 축하 상황에 대해 금전적 기여를 쉽게 할 수 있게 돕는 모바일 애플리케이션입니다",
group = RelationDetailGroup(
id = 0,
name = "친척"
),
giveMoney = 100000L,
takeMoney = 100000L
),
hearts = listOf(
RelatedHeart(
id = 0,
give = true,
money = 10000,
day = LocalDate(2024, 1, 23),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = listOf()
),
RelatedHeart(
id = 0,
give = true,
money = 10000,
day = LocalDate(2024, 1, 24),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = HistoryTagType.entries.map { it.tagName }
),
RelatedHeart(
id = 0,
give = false,
money = 500000,
day = LocalDate(2024, 1, 25),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리 메모 내용 한 줄 넘어가면 숨김 처리 ",
tags = listOf("참석", "현금")
),
RelatedHeart(
id = 0,
give = false,
money = 10000,
day = LocalDate(2024, 1, 26),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = listOf()
),
RelatedHeart(
id = 0,
give = true,
money = 10000,
day = LocalDate(2024, 1, 27),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = listOf()
),
)
)

@Preview
@Composable
fun HistoryDetailBackgroundComponentPreview() {
fun HistoryDetailBackgroundComponent1Preview() {
HistoryDetailBackgroundComponent(
currentGrowthType = HistoryDetailGrowthType.LEVEL_SIX,
model = HistoryDetailModel(
state = HistoryDetailState.Init,
relationDetail = RelationDetailWithUserInfo(
id = 0L,
name = "김진우",
imageUrl = "",
memo = "무르는 경사비 관리앱으로 사용자가 다양한 개인적인 축하 상황에 대해 금전적 기여를 쉽게 할 수 있게 돕는 모바일 애플리케이션입니다",
group = RelationDetailGroup(
id = 0,
name = "친척"
),
giveMoney = 100000L,
takeMoney = 100000L
),
hearts = listOf(
RelatedHeart(
id = 0,
give = true,
money = 10000,
day = LocalDate(2024, 1, 23),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = listOf()
),
RelatedHeart(
id = 0,
give = true,
money = 10000,
day = LocalDate(2024, 1, 24),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = HistoryTagType.entries.map { it.tagName }
),
RelatedHeart(
id = 0,
give = false,
money = 500000,
day = LocalDate(2024, 1, 25),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리 메모 내용 한 줄 넘어가면 숨김 처리 ",
tags = listOf("참석", "현금")
),
RelatedHeart(
id = 0,
give = false,
money = 10000,
day = LocalDate(2024, 1, 26),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = listOf()
),
RelatedHeart(
id = 0,
give = true,
money = 10000,
day = LocalDate(2024, 1, 27),
event = "생일",
memo = "메모 내용 한 줄 넘어가면 숨김 처리",
tags = listOf()
),
)
),
model = sampleHistoryDetailModel,
contentHeight = 480.dp,
onClickRelationInfo = {},
onClickGrowthInfo = {},
onClickBack = {}
)
}

@Preview
@Composable
fun HistoryDetailBackgroundComponent2Preview() {
HistoryDetailBackgroundComponent(
currentGrowthType = HistoryDetailGrowthType.LEVEL_ONE,
model = sampleHistoryDetailModel,
contentHeight = 480.dp,
onClickRelationInfo = {},
onClickGrowthInfo = {},
onClickBack = {}
)
}

@Preview
@Composable
fun HistoryDetailBackgroundComponent3Preview() {
HistoryDetailBackgroundComponent(
currentGrowthType = HistoryDetailGrowthType.LEVEL_TWO,
model = sampleHistoryDetailModel,
contentHeight = 480.dp,
onClickRelationInfo = {},
onClickGrowthInfo = {},
onClickBack = {}
)
}

@Preview
@Composable
fun HistoryDetailBackgroundComponent4Preview() {
HistoryDetailBackgroundComponent(
currentGrowthType = HistoryDetailGrowthType.LEVEL_THREE,
model = sampleHistoryDetailModel,
contentHeight = 480.dp,
onClickRelationInfo = {},
onClickGrowthInfo = {},
onClickBack = {}
)
}

@Preview
@Composable
fun HistoryDetailBackgroundComponent5Preview() {
HistoryDetailBackgroundComponent(
currentGrowthType = HistoryDetailGrowthType.LEVEL_FOUR,
model = sampleHistoryDetailModel,
contentHeight = 480.dp,
onClickRelationInfo = {},
onClickGrowthInfo = {},
onClickBack = {}
)
}

@Preview
@Composable
fun HistoryDetailBackgroundComponent6Preview() {
HistoryDetailBackgroundComponent(
currentGrowthType = HistoryDetailGrowthType.LEVEL_FIVE,
model = sampleHistoryDetailModel,
contentHeight = 480.dp,
onClickRelationInfo = {},
onClickGrowthInfo = {},
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
package ac.dnd.mour.android.presentation.ui.main.splash

import ac.dnd.mour.android.presentation.R
import ac.dnd.mour.android.presentation.common.util.LaunchedEffectWithLifecycle
import ac.dnd.mour.android.presentation.common.util.alarm.registerAlarm
import ac.dnd.mour.android.presentation.common.util.alarm.unregisterAlarm
Expand All @@ -14,13 +15,18 @@ import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.rememberCoroutineScope
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Brush
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.platform.LocalContext
import androidx.compose.ui.tooling.preview.Preview
import com.airbnb.lottie.compose.LottieAnimation
import com.airbnb.lottie.compose.LottieCompositionSpec
import com.airbnb.lottie.compose.LottieConstants
import com.airbnb.lottie.compose.rememberLottieComposition
import kotlinx.coroutines.CoroutineExceptionHandler

@Composable
Expand All @@ -34,6 +40,10 @@ fun SplashScreen(
val scope = rememberCoroutineScope()
val context = LocalContext.current

val compositionSplash by rememberLottieComposition(
spec = LottieCompositionSpec.RawRes(resId = R.raw.splash)
)

fun navigateToLogin() {
appState.navController.navigate(LoginConstant.ROUTE) {
popUpTo(SplashConstant.ROUTE) {
Expand Down Expand Up @@ -77,7 +87,10 @@ fun SplashScreen(
),
contentAlignment = Alignment.Center
) {

LottieAnimation(
composition = compositionSplash,
iterations = LottieConstants.IterateForever
)
}

LaunchedEffectWithLifecycle(event, handler) {
Expand Down
1 change: 1 addition & 0 deletions presentation/src/main/res/raw/history_lv_1.json
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.5.4","a":"","k":"","d":"","tc":""},"fr":29.9700012207031,"ip":0,"op":173.000007046434,"w":100,"h":90,"nm":"Group 1437257361-1","ddd":0,"assets":[{"id":"image_0","w":91,"h":84,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"레이어 1","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":60,"s":[3]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":114,"s":[-3]},{"t":168.00000684278,"s":[0]}],"ix":10},"p":{"a":0,"k":[49.818,86.4,0],"ix":2},"a":{"a":0,"k":[45.482,83.162,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":900.000036657751,"st":0,"bm":0}],"markers":[]}
Loading

0 comments on commit 9f6ddaf

Please sign in to comment.