본문 바로가기

Android

configChanges 앱 runtime중 환경에 변화가 일어나면 실행중인 activity는 destory되며 재시작됩니다. 이때 activity가 재시작되는 것을 원치 않을때에는 manifest에 android:configChanges의 attribute에 알맞은 값을 넣어서 재시작을 방지합니다. attribute의 속성은 다음과 같은 종류가 있습니다. mcc : SIM 이 Detect 되고 MCC 가 Update. ( IMSI Mobile Country Code가 변한 경우) mcc : SIM 이 Detect 되고 MNC 가 Update. ( IMSI Mobile Network Code가 변한 경우 ) locale : 새로운 언어(Locale)를 변경했을 때 touchscreen : Touch Screen Hardware .. 더보기
build.gradle 쉽게 관리해보자. 프로젝트 개발을 하다보면 build.gradle에 여러가지 작업을 해야합니다. 기존적인 앱설정, 라이브러리의 추가 등등.. 이번에 개발한 프로젝트에서는 추가한 sdk들이 너무 많았고 그로인해 추가해야할 설정값들이 많았습니다. 관리적 측면에서 build.gradle에서 BuildConfig에 추가하여 관리하는 것이 낫다고 생각했습니다. apply plugin: 'com.android.application' apply plugin: 'kotlin-android' apply plugin: 'kotlin-android-extensions' apply plugin: 'kotlin-kapt' android { compileSdkVersion 28 defaultConfig { applicationId "com.tes.. 더보기
okhttp3를 이용하여 재인증하기(refresh token) 지난시간에는 retrofit2와 okhttp3의 해더를 이용해 인증하는 방법에 대해서 알아보았습니다. https://akaisun.tistory.com/72 retrofit2를 사용하여 Authorization 인증하기 앱에서 서버와 통신할 때 사용자의 인증이 필요한경우 해더에 Authorization를 넣어 통신한다. Authorization에도 BearerToken, ApiKey, OAuth2.0등 여러가지 종류가 있다. 그럼 어떻게 해더에 Authorization를 넣.. akaisun.tistory.com 앱에서 서버로 인증할때는 OAuth 2.0방법을 가장많이 사용하는데 이에 대한 설명은 아래의 링크를 참조해주세요. https://oauth.net/2/ OAuth 2.0 — OAuth OAuth.. 더보기
retrofit2를 사용하여 Authorization 인증하기 앱에서 서버와 통신을 할 때 사용자의 인증이 필요한 경우가 있습니다. 이럴 경우에는 해더에 Authorization를 추가하여 인증된 사용자만 정보를 취득하도록 합니다. Authorization에도 BearerToken, ApiKey, OAuth2.0등 여러가지 종류가 있습니다. 그럼 어떻게 해더에 Authorization를 넣을까요? 제가 즐겨쓰는 retofit2와 okhttp3를 이용하여 알아보도록 할게요. 먼저 retorfit2의 custom header를 사용하여 추가하는 방법입니다. public interface ApiService { @Headers("Authorization: your auth token") @GET("/test") List getTestData(); } 또 다른 방법으로는 .. 더보기
progress wrapper 안드로이드 개발을 하다보면 progress를 사용하여 현재 데이터를 처리중이라는 것을 알려야할 때가 있다. 다음은 우리가 흔히 볼수 있는 progress를 사용하는 방법이다. 위의 코드는 왼쪽과 같은 결과를 나타낸다. xml 디자인을 하다보면 다양한 뷰를 추가해아하고 progress의 경우 다른 뷰보다 최상위로 표현하기위해 가장 하단에 선언하여 사용한다. 하지만 좀 더 직관적이면서 심플하게 xml에 적용하고 싶었고 custom view를 만들어 사용하게됬다. 다음은 custom view를 이용한 progress wrapper를 만들어 사용한 예제다. custom_progress.xml ProgressWrapper.kt class ProgressWrapper @JvmOverloads constructor(.. 더보기
바코드, QR CODE 생성 및 스캐너 바코드는 문자와 숫자를 막대와 공백으로 표시함으로서 상품관리를 편리하게 하는 것으로 가장 간단하게 구현하는 방법에 대해 알아보겠습니다. gradle에 다음의 라이브러리들을 추가합니다. //바코드 읽기 implementation 'com.budiyev.android:code-scanner:2.1.0' //바코드 쓰기 implementation('com.journeyapps:zxing-android-embedded:3.6.0') { transitive = false } zxing에서 제공하는 바코드 유형은 17개정도인데 아래는 QR_CODE를 생성하는 예제입니다. 이 외에도 CODE_39나 CODE_93등의 바코드 유형도 생성가능합니다. val barcodeEncoder = BarcodeEncoder() v.. 더보기
webview scroll detecting 프로젝트를 진행하던 중 웹뷰의 스크롤에 따라 toolbar를 collapse, expand를 하는 기능을 만들게 되었다. 안드로이드에서는 web view의 스크롤을 감지하는 Listener를 제공하는데 다음과 같다. webView.setOnScrollChangeListener { v, scrollX, scrollY, oldScrollX, oldScrollY -> // insert your code } 하지만 문제가 있었는데 위의 기능은 API 23부터 제공하는 기능이었다. 그렇다면 23이전에서는 어떻게 스크롤을 탐지할 수 있을까? 구글링의 결과 끝에 원하는 답을 찾을 수 있었다. class CustomWebView : WebView { private var oldY: Float = 0.toFloat() .. 더보기
Room에서 LiveData사용과 paging처리 Room을 이용하여 내부에 대량의 데이터를 저장할 경우. 저장된 데이터를 페이징처리를 통하여 효율적인 리스트를 표현하는 것이 좋다. Dao @Query("SELECT * FROM table") abstract fun selectList() : DataSource.Factory 페이징처리 부분 val config = PagedList.Config.Builder() .setInitialLoadSizeHint(20) //최초 로드사이즈는 20개 .setPageSize(10) // 페이징당 10개 .setPrefetchDistance(10) // 10개마다 다음페이지를 미리불러오기 .setEnablePlaceholders(true) .build() var pagedItems = LivePagedListBuild.. 더보기