본문 바로가기
반응형

hilt7

[Android] Clean Architecture With Pokedex (feat. Jetpack Compose, Hilt) - 4 이번 포스팅은 Presentation 레이어를 구현한다. 즉, presentation 모듈을 구현하게 된다. presentation 레이어는 앱의 UI, UI에 보여줄 데이터를 획득하는 기능을 담당한다. UI를 그리기 위해 Compose를 활용할 것이며, UI의 데이터, 즉 상태를 관리하는 기능은 ViewModel을 활용할 것이다. 먼저 포켓몬 리스트 데이터를 담당하는 ViewModel을 구현해보자. @HiltViewModel class PokemonListViewModel @Inject constructor( getPokemonListUseCase: GetPokemonListUseCase ) : ViewModel() { val pokemonList = getPokemonListUseCase .invok.. 2023. 1. 1.
[Android] Clean Architecture With Pokedex (feat. Jetpack Compose, Hilt) - 3 이번 포스팅은 Domain 레이어와 Presentation 레이어를 연결해주는 Data 레이어를 구현한다. 즉, data 모듈을 구현하게 된다. 실제 앱을 구현할 때, 데이터를 획득하는 방법은 크게 두 가지이다. Rest api등과 같은 Remote 데이터, 로컬 데이터베이스와 같은 Local 데이터다. 이 예제에서는 Remote 데이터만을 다룰 것이다. data모듈은 Domain 레이어의 Repository interface를 구현하게 된다. 구현 과정에서 API를 호출하여 네트워크 데이터를 획득하고 Domain 레이어의 Entity로 변환하는 작업이 필요하다. 우선 Retrofit을 활용하여 API 부터 구현한다. interface PokemonApi { @GET("pokemon") suspend f.. 2022. 7. 10.
[Android] Clean Architecture With Pokedex (feat. Jetpack Compose, Hilt) - 2 이번 포스팅은 Clean architecture의 가장 안쪽 레이어인 Domain 레이어를 구현할 것이다. 즉, 이전 포스팅에서 생성한 domain 모듈을 구현한다. 먼저 entity를 구현해보도록 하겠다. 포켓몬 도감은 포켓몬들을 리스트업하고 상세한 내용을 볼 수 있는 기능을 갖는다. 따라서 포켓몬 리스트를 구성할 Entity와 포켓몬 상세를 표현할 Entity가 필요하다. 아래와 같은 Entity 코드를 작성한다. data class PokemonEntity( val id: Int, val name: String, val imageUrl: String ) data class PokemonDetailEntity( val id: Int, val name: String, val imageUrl: Strin.. 2022. 7. 9.
[Android] Jetpack Compose + Flow로 네트워크 연결 상태 처리를 해보자. 저는 안드로이드 관련된 Medium 포스팅을 메일로 전달받고 있습니다. 최근 제목과 같이 Jetpack Compose와 Flow를 활용하여 네트워크 연결 상태 처리를 하는 포스팅을 보고 예제를 간단하게 작성하여 포스팅하려 합니다. 참고한 Medium 링크는 아래와 같으니, 원문을 보고 싶다면 참고하면 됩니다. https://attilaakinci.medium.com/network-connectivity-on-compose-a35f6efa1a5c Network Connectivity on Jetpack Compose Brief story on network connectivity usages on modern android development style with jetpack compose support.. 2021. 12. 26.