묻고 답해요
141만명의 커뮤니티!! 함께 토론해봐요.
인프런 TOP Writers
-
해결됨아이비의 안드로이드 드릴
선생님 아직 디스코드 초대가 안됐습니다.!
구글폼이 정상적으로 작성되었나요? ㅜㅜ
-
해결됨아이비의 안드로이드 드릴
네비게이션
home_graph.xml의 시작점app:startDestination="@id/navigation_home"app:startDestination="@id/navigation_다른 activity"이렇게 나눠서 하나는 home activity의 FragmentContainerView 에서 상용하고 다른 하나는 detail activity의 FragmentContainerView에서 사용할 수 있나요?
-
해결됨[LV1] Jetpack Compose - UI 연습하기
TextField에서 테두리 제거하는 방법이 궁금합니다.
안녕하세요. CoupangEx-3 강의에서 검색 기능을 위해 TextField를 만들었는데, TextField 주위에 있는 회색의 테두리를 어떻게 제거할 수 있는지 궁금합니다.... 인터넷 검색을 해도 동작하지 않거나, 언더라인을 지우는 코드들만 나와서 자료를 못 찾겠습니다. 감사합니다.
-
미해결모던 안드로이드 - Jetpack Compose 입문
깃허브에 있는 MemoryTodoRepository 는 룸을 사용하는게 아닌 메모리에 저장, 수정, 삭제 하는건가요?
Room처럼 내부저장소에 저장하는 것이 맞다면,Room을 사용 하지 않는 방법인데 작동되는 건 아예 똑같은 건가요?아니면 저장되는 곳이 다르다거나 저장방식은 다른데 같은 역할로써 쓰일 수 있는건가요?
-
해결됨모던 안드로이드 - Jetpack Compose 입문
이젠 아래와 같은 오류가 뜨는데 KSP가 문제 인걸까요?
파랑색 둘다 해봤는데 이유를 못 찾겠네요 ㅠㅠ
-
미해결모던 안드로이드 - Jetpack Compose 입문
영상 1분쯤에서 MainActivity에서 viewModel이 저는 안되고 그래들 문제인거 같은데 해결 방법을 모르겠습니다.
깃허브에 있는걸 복붙하면 viewModel 부분에서 맨 아래와 같이 오류가 발생해서 맨 위에있는건 https://developer.android.com/codelabs/basic-android-kotlin-training-viewmodel?hl=ko#3이 링크에서 implementation 하라고 하는걸 넣은 것이고 가운데는 첫번째를 2번째와 같이 변경하라는 추천해서 변경된 내용을 넣은겁니다.저기서 compose로 끝나는게 그래들이 안되서 MainActivity에서의 viewModel도 영상과 달리 아래처럼만 되어 있는데 해결방법을 전혀 모르겠습니다.
-
해결됨모던 안드로이드 - Jetpack Compose 입문
전자액자에서 영상과 깃허브의 내용이 달라서 영상을 다보고 깃허브 내용으로 돌려봤는데 권한요청부터가 안됩니다.
에뮬레이터에서는 정상 작동을 하는데제 핸드폰으로 돌리면 권한요청에서부터 안됩니다.SDK는 아래와 같이 되어있고 제 핸드폰은 버전 14인데 이게 문제일까요?namespace = "com.example.photoframe" compileSdk = 34 defaultConfig { applicationId = "com.example.photoframe" minSdk = 28 targetSdk = 34 versionCode = 1 versionName = "1.0" testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" vectorDrawables { useSupportLibrary = true } }
-
미해결모던 안드로이드 - Jetpack Compose 입문
Navigation수업에서 string대신 bitmap을 인자로 넘겨주는 방법?
네비게이션 수업도중 궁금한 점이 있어서 질문드립니다.ThirdScreen으로 Bitmap데이터를 인자로 넘기고 싶습니다. 어떻게 해야 할지 모르겠습니다.예를들어, 카메라 캡쳐해서 다음 스크린으로 캡쳐한 사진을 보내서 이미지를 보여주고 싶을 때, 어떻게 해야 하나요?
-
미해결모던 안드로이드 - Jetpack Compose 입문
TodoList - 04에서 recentlyDeleteTodo가 null일 경우 처리 방법 문의
개인적으로 변수가 null일 경우변수?.let {}이렇게 사용해 왔는데요. 강의에서는 viewModelScope.launch { todoRepository.addTodo(recentlyDeleteTodo ?: return@launch) }이렇게 사용 하셨는데요. 해당 부분만 보면 뭐가 더 좋다 이럴게 없어 보이기는 하는데요. 혹시 특정한 상황에서 ?: return 으로 하는 것이 필요한(or 더 좋은) 경우가 있을까요?
-
미해결[중급편] 친절한 JETPACK 개론 <하> (Android Kotlin)
ListAdapter / DiffUtil 관련 강의 문의
섹션 2 에 해당하는 모든 강의가 화면이 안보이는데원래 그런건가요? 혹시 삭제된 걸까요?
-
미해결[중급편] 친절한 JETPACK 개론 <하> (Android Kotlin)
질문드립니다!
챕터9에 검색한 데이터 요청 챕터에서 viewmodel과 viewmodelfactory로 나눈 이유가 있을까요?
-
미해결냉동코더의 알기 쉬운 Modern Android Development 입문
안녕하세요. 용어에 대해 질문이 있어 글 남깁니다.
안녕하세요. 강의 잘듣고 있습니다.다만, 제가 이 강의부터 시작해서 그런지 용어에 대한 개념이 헷갈립니다. util 디렉토리와 source.kt 파일의 역할은 정확히 무엇인가요?util 디렉토리에 들어가는 파일들의 내용은 무엇이고,DataSource의 역할이 무엇인지 궁금합니다 !감사합니다..
-
미해결[중급편] 친절한 JETPACK 개론 <상> (Android Kotlin)
Json 형식 데이터 모델 설계 질문드립니다 :)
안녕하세요! 항상 좋은 강의 찍어주셔서 감사하다는 말씀부터 드립니다 :)다름이 아니라 제가 강의를 보고 혼자서 따라하고 있는데 막히는 부분이 있어서 질문 드립니다 !제가 막히는 부분은 Open RestAPI(https://restcountries.com/v3.1/all)를 이용을 하여 데이터를 가지고 오려고 하는데 이걸 가지고 오게 해주는 데이터 모델 설계 부분에서 막힙니다. !!제가 설계한 데이터 모델 설계은 Json 형식으로 되어 있는것을 자동으로 변환해주는 안드로이드 스튜디오 플러그인(Json to Kotlin class)을 이용을 하게 되는데요! 간단한 Json 형태로 되어 있다면 문제가 없이 잘 설계를 해주더라구요!EX) 제가 생각한 간단한 Json 형태{ "student" : [ { "student_id": 30410, "name" : "홍길동", "phone" : "010-12345-1234" }, { "student_id": 30411, "name" : "고길동", "phone" : "010-53455-1256" }, { "student_id": 30413, "name" : "둘리", "phone" : "010-35243-5345" }, { "student_id": 30414, "name" : "아이유", "phone" : "010-13352-5343" } ] }위와 같은 형식은 예를들어 respose.body.studuent.student_id 이렇게 모든 값들이 찍히는것을 알 수 있습니다.하지만 제가 사용하려는 Json 형식의 데이터 형태들은 간단하지 않고, 특정 값을 입력을 해야하는데 이 값이 특정되게 입력해줄 수 없는 형태인데요! 제가 안드로이드 스튜디오 플러그인(Json to Kotlin class)을 이용을 하여 제가 사용하려는 JSON 형태를 data class로 변환을 하여 만들었는데 엄청나게 많은 클래스(500개)가 생겨났습니다. 이유는 모든 데이터 클래스를 생성하여 그에 따른 가능성을 모두 생성하여 대입해줬기 때문입니다.제가 생각해본 방법은 Map을 이용하면 될 것 같은데 1주일동안 고민하고 해결해보려고 했지만 성공하지 못했습니다. 혹시 방법이 있을까요?EX) 내가 사용하려는 복잡한 구조의 Json 형태[ { "name": { "common": "Saint Pierre and Miquelon", "official": "Saint Pierre and Miquelon", "nativeName": { "fra": { "official": "Collectivité territoriale de Saint-Pierre-et-Miquelon", "common": "Saint-Pierre-et-Miquelon" } } }, "currencies": { "EUR": { "name": "Euro", "symbol": "€" } }, "translations": { "ara": { "official": "سان بيير وميكلون", "common": "سان بيير وميكلون" }, "bre": { "official": "Sant-Pêr-ha-Mikelon", "common": "Sant-Pêr-ha-Mikelon" }, "ces": { "official": "Saint-Pierre a Miquelon", "common": "Saint-Pierre a Miquelon" } }, "languages": { "fra": "French" } } ]위는 제가 현재 사용하려는 Json 형태의 일부분 입니다. name-common 같은 부분은 it.name.common을 사용하게 되면 문제없이 사용이 가능하고 생성되는 data class도 적습니다. 이유는 name-common 이라는 필드가 모든 나라에 대해서 공통으로 사용하고 있어서 고정값으로 사용할 수 가 있기 때문입니다.하지만 name-nativeName - "fra" 필드를 보게되면 특정한 값인 fra(위의 예시의 경우)를 특정되게 입력을 해줘야 값을 받아올 수 있습니다. 이러한 "fra"라는 값은 이 나라의 고유의 값이 아니라 모든 나라에서 사용하는 언어 중 한 개 입니다. 그래서 @Path를 이용해 매개변수에 정확하게 입력해줄 수 있는것이 아니라 가능성(모든 나라의 언어)에 대해 모든것을 대입해야만 했습니다. 모든것을 대입해야만 했기 때문에 data class가 매우 많이 생성되는것을 겪었습니다. ( nativeName 필드뿐 아니라 languages 필드를 보더라도 특정되게 "fra"를 찝어야 가져 올 수 있습니다. )아래는 제가 생성한 data model class 입니다.구조는 Country_Response_Detail - Country-ResponseItem)Detail - [ capital, cioc, currencies, languages, name, population, region] 으로 해서 뻗어 나가는 구조입니다 !. if(it.capital==null) { val capital = "" } else { val capital = it.capital.toString().substring(1,it.capital.toString().length-1) //activity_countries_detail.xml 사용 할 capital(수도) 변수 capital_Input_Detail.text = capital //capital_Input_Detail이라는 TextView와 capital 변수 연결 } if (it.currencies==null) { currency_Input_Detail.text = "" //currency_Input_Detail이라는 TextView와 currency 변수 연결 } else { val currency_Index1 = it.currencies.toString().indexOf("name") + 5 val currency_Index2 = it.currencies.toString().indexOf(",",currency_Index1) val currency_Index3 = it.currencies.toString().indexOf("symbol") + 7 val currency_Index4 = it.currencies.toString().indexOf(")",currency_Index1) val currencies_Name = it.currencies.toString().substring(currency_Index1,currency_Index2) val currencies_Symbol = it.currencies.toString().substring(currency_Index3,currency_Index4) val currency = StringBuilder().append(currencies_Symbol).append("(").append(currencies_Name).append(")").toString() //activity_countries_detail.xml 사용 할 currency(화폐) 변수 println("currency_Input : ${currency}") currency_Input_Detail.text = currency //currency_Input_Detail이라는 TextView와 currency 변수 연결 }위에서 만든 data class를 통해 데이터를 받아오면 null 값도 전부 받아오기 때문에..이렇게 데이터를 정제해서 쓰고 있습니다.. 혹시 편하게 그냥 null 값이 아니면 그 데이터의 값만 나오게 가능할 지도 궁금합니다.. 저는 이러한 문제에 직면을 하고 있습니다..두서없이 적어서 이해가 안되실것입니다 ㅜㅜ.. 도움을 주시면 정말 감사하겠습니다 :)
-
미해결모던 안드로이드 - 코틀린과 Jetpack 활용
Repository에서 Error처리를 하고 싶은데 잘 모르겠습니다.
안녕하세요 sunflower 예제와 해당 강의를 참고해서 프로젝트를 진행중인데요 repository에서 통신(retrofit2 사용합니다)을 요청해서 값을 받아와서 해당 값을 viewmodel이 전달받아 LiveData에 전달하여 UI컴포넌트에서 view를 그려주고 있습니다. 딱 이구조를 참고해서 만들고 있습니다. 그런데 통신 요청과정중 Exception이 발생했을때 Throwable 데이터를 viewmodel에 error라는 라이브데이터로 전달하여 UI컴포넌트에서 유저에게 Exception 관련 Dialog를 노출하고 싶은데 Repository에서 viewmodel에 error를 어떻게 전달해야 할지 방법을 못찾고 있습니다.제가 참고한 예제에서는 Repository에서 정상적인 통신으로 전달받은 data만 반환해주는 메서드이기때문에 예외가 발생했을때 Error에 대해 Viewmodel로 전달할 방법을 고민중입니다. 단순하게 Data와 Error을 묶을 상위 클래스를 객체화 시켜 반환하는 방법도 생각해봤는데 paging3도 함께 사용중인데 이경우에도 사용할수있는 깔끔한 방법이 생각이 안나서 질문 드립니다. 혹시 참고할만한 예제를 알고 있으시다면 알려주시면 감사하겠습니다. 두서없고 정리안된 질문 죄송합니다.. 지금 머리속이 너무 복잡해서요 ㅠㅠ