라벨이 android인 게시물 표시

Tanix W2(Amlogic S905W2) tv box.

Tanix W2(Amlogic S905W2)를 구매하고 펌웨어 업데이트를 했습니다. 기기 스펙은 좋은데 안드로이드11을 지원해서 아쉬웠습니다. 저는 AMLogic Burn Card Maker 으로 하는 방법이 안되서 AMLogic USB Burning Tool 으로 했습니다. 케이블은 usb-c 2.0 케이블 2개를 연장젠더로 연결했습니다. 펌웨어. https://www.tanixtvbox.com/firmware-centre/ 펌웨어 설치. https://blog.naver.com/destinyrev/222139130994 펌웨어 설치에 조금더 자세한. https://blog.naver.com/serinari/222224893193

샤오미 홍미노트 9s 펌웨어 업데이트.

2024.11 업데이트. 전체적인 과정은  1. 리커버리 툴(twrp or OrangeFox)을 설치. 2. 리커버리 툴에서 펌웨어 설치와 동시에 GApps(구글 앱)설치. 1. 리커버리 툴(twrp or OrangeFox) 설치. 처음 설치한다면 아래 예전 버전을 참조해 설치한다. OrangeFox는 twrp보다 디자인, 안전성이 향상 됐다고 하는데 이건 설치 해도 되고 안해도 된다. - twrp 에 OrangeFox 를 설치. twrp가 설치되어 있다면  USB 드라이브에 OrangeFox를 다운로드 받아 twrp 에서 install 에서 OrangeFox<*****>.zip 를 선택해 설치하면 된다. 2. 리커버리 툴에서 펌웨어 설치와 동시에 GApps(구글 앱)설치. 펌웨어와 GApps를 usb 메모리에 다운로드 받는다. 전원 종료후 볼륨상단+전원 버튼을 동시에 눌러 리커버리 툴(twrp or OrangeFox)로 진입합니다. - 초기화. "Wipe" 옵션을 선택하고 "Format Data" 옵션을 선택해 포맷합니다. 포맷이 완료되면 "Wipe" 메뉴로 돌아가 "Advanced Wipe"를 선택하고 Dalvik Cache, Cache, System, Data 파티션을 선택하고 "Swipe to Wipe"를 실행합니다. 초기화 옵션이 툴 버전에 따라 다를수 있는데 최대한 비슷하게 하면 됩니다. 참고- 초기화가 잘 안된다면 아래 문제해결 을 참고하세요. - 펌웨어와 GApps 설치. twrp - 메인화면에서 install 메뉴를 선택해  OrangeFox - 파일에서 펌웨어와 GApps의 zip 파일을 선택해 펌웨어와 GApps를 순서대로 설치합니다. - 주의. 설치후 또는 부팅후 초기 설정시에 리커버리 영역을 덮어쓸거냐고 물어보는데 절대 동의하면 안됨. twrp, OrangeFox 이 지워지게 됩니다. twrp, OrangeFox 다운로드 링크....

android Settings Activity 구현. kotlin

아래와 같이 액티비티를 추가한다. Android Studio  File - New - Activity - Settings Activity  res - xml 에 root_preferences.xml 와 비슷한 파일명을 열어 아래와 같이 수정한다. Activity <PreferenceScreen xmlns: app ="http://schemas.android.com/apk/res-auto" xmlns: android ="http://schemas.android.com/apk/res/android" > <PreferenceCategory app :title ="@string/messages_header" > <EditTextPreference app :key ="test1" app :title ="@string/signature_title" app :useSimpleSummaryProvider ="true" /> <SeekBarPreference app :key ="test2" app :title ="font sizw" app :iconSpaceReserved ="false" app :showSeekBarValue ="true" app :defaultValue ="15" app :min ="10" android :max ="35" /> <ListPreference app :defaultValue =...

android RecyclerView 심플 구현. kotlin

텍스트뷰만 있는 간단한 RecyclerView 구현이다. activity layout xml 파일에 RecyclerView 을 추가한다. <androidx.recyclerview.widget.RecyclerView android :id ="@+id/text_list" android :layout_width ="match_parent" android :layout_height ="match_parent" app :layoutManager ="androidx.recyclerview.widget.LinearLayoutManager" /> listitem_contents.xml 파일을 layout 폴더에 추가한다. <? xml version ="1.0" encoding ="utf-8" ?> <TextView xmlns: android ="http://schemas.android.com/apk/res/android" android :id ="@+id/item_text" android :layout_width ="match_parent" android :layout_height ="wrap_content" android :gravity ="center_vertical" android :paddingStart ="?android:attr/listPreferredItemPaddingStart" android :paddingEnd ="?android:attr/listPreferredItemPaddingEnd" /> Adapter 클래스를 추가한다. class ContentsAdapter( private val textList : Muta...

android getSharedPreferences 사용법. kotlin

getSharedPreferences을 사용하면  키-값 데이터 저장을 위해 간단하게 사용할 수 있다. Androd studio 오른쪽 하단의 Device Explorer를 열면 저장된 폴더에 접근할 수 있다. 저장 폴더의 위치는 다음과 같다. /data/data/{packageName}/shared_prefs/ getPreferences도 동일하게 사용할 수 있다. getSharedPreferences는 프로젝트의 모든 곳에서 동일한 키값에 접근할 수 있지만  getPreferences는 호출된 액티비티에서만 접근할 수 있다. 코드. private fun load () { val sharedPref = getSharedPreferences( "configApp" , Application. MODE_PRIVATE ) val configVersion = sharedPref.getString( "configVersion" , "" ) } private fun save () { val sharedPref = getSharedPreferences( "configApp" , Application. MODE_PRIVATE ) val editor: SharedPreferences.Editor = sharedPref.edit() editor.putString( "configVersion" , "appVersion" ) editor.commit() }

android 전역 폰트 변경. kotlin

사용하는 테마 설정에 android:typeface 을 추가한다. 코드를 실행한다. 코드 실행후 현재 액티비티에 적용하려면 액티비티 리스타트를 해야 한다. styles.xml <style name ="AppTheme" parent ="Theme.AppCompat.DayNight.DarkActionBar" >      <item name ="android:typeface" > serif </item> </style> 코드. fun setFont (defaultFontNameToOverride: String , newFontFileNameInAssets: String): Boolean { try { val fontMaintext = Typeface.createFromAsset(context(). assets , newFontFileNameInAssets) val defaultFontTypefaceField: Field = Typeface:: class . java .getDeclaredField(defaultFontNameToOverride) defaultFontTypefaceField.setAccessible( true ) defaultFontTypefaceField.set( null, fontMaintext ) } catch (e: java.lang.Exception) { return false } return true } 액티비티 리스타트. val intent: Intent = getIntent() finish() startActivity(intent)

android theme 다크 테마 구현. kotlin

스타일은 DayNight 를 상속받게 해야한다.  이후 setTheme 로 적용한다. setTheme 실행후 현재 액티비티에 적용하려면 액티비티 리스타트를 해야 한다. styles.xml <style name ="AppTheme" parent ="Theme.AppCompat.DayNight.DarkActionBar" > 코드. val LIGHT_THEME = "light" val DARK_THEME = "dark" val DEFAULT_THEME = "system" fun setTheme (themeName: String) { when (themeName) { LIGHT_THEME -> { AppCompatDelegate.setDefaultNightMode(AppCompatDelegate. MODE_NIGHT_NO ) } DARK_THEME -> { AppCompatDelegate.setDefaultNightMode(AppCompatDelegate. MODE_NIGHT_YES ) } else -> { if (Build.VERSION. SDK_INT >= Build.VERSION_CODES. Q ) { AppCompatDelegate.setDefaultNightMode(AppCompatDelegate. MODE_NIGHT_FOLLOW_SYSTEM ) } else { AppCompatDelegate.setDefaultNightMode(AppCompatDelegate. MODE_NIGHT_AUTO_BATTERY ) } } } } 액티비티 리스타트. val intent: Intent...

android RecyclerView의 TextView에서 textIsSelectable ="true "가 작동하지 않을때 해결방법.

android  RecyclerView의 TextView에서 textIsSelectable ="true "가 작동하지 않는다. - 증상. 리스트 상단에서는 텍스트 선택이 되다가 하단으로 스크롤 시키면 텍스트가 선택되지 않는다. - 해결. Adapter의 onBindViewHolder에 다음과 같은 코드를 추가한다. override fun onBindViewHolder (holder: TextHolder , position: Int) { holder.textView.setTextIsSelectable( false ) ; holder.textView.measure(- 1 , - 1 ) ; holder.textView.setTextIsSelectable( true ) ; } - 출처. https://stackoverflow.com/questions/36801486/androidtextisselectable-true-not-working-for-textview-in-recyclerview

안드로이드 툴바 ScrollView 스크롤시 툴바 감추기. kotlin

NestedScrollView 대신 ScrollView로 스크롤시 툴바를 감출수 있다. ScrollView에 다음 속성을 넣어주면 된다. android:nestedScrollingEnabled="true" app:layout_behavior="@string/appbar_scrolling_view_behavior" <androidx.coordinatorlayout.widget.CoordinatorLayout xmlns: android ="http://schemas.android.com/apk/res/android" xmlns: app ="http://schemas.android.com/apk/res-auto" android :id ="@+id/coordinator" android :layout_width ="match_parent" android :layout_height ="match_parent" android :fitsSystemWindows ="true" > <com.google.android.material.appbar.AppBarLayout android :id ="@+id/appBarLayout" android :layout_width ="match_parent" android :layout_height ="wrap_content" > <androidx.appcompat.widget.Toolbar android :id ="@+id/toolbar" android :layout_width ="match_parent" android :layout_height ="?attr/actionBarSize" ...

kotlin SharedPreferences Generic MutableList 읽기, 쓰기.

https://stackoverflow.com/questions/7361627/how-can-write-code-to-make-sharedpreferences-for-array-in-android stackoverflow 에 올라온 코드를 참조해 제네릭하게 만들어 봤습니다. 사용법은 아래와 같습니다. val sharedPref = getSharedPreferences("config", MODE_PRIVATE) setArrayPref<String>(sharedPref, "testList ", <<inList>> ) val testList = getArrayPref<String>(sharedPref, "testList") fun < T > setArrayPref (prefs: SharedPreferences , key: String , values: MutableList< T >) { val editor = prefs.edit() val jArray = JSONArray() for (i in 0 until values. size ) { jArray.put(values[i]) } if (values. isNotEmpty ()) { editor.putString(key , jArray.toString()) } else { editor.putString(key , null ) } editor.commit() } fun < T > getArrayPref (prefs: SharedPreferences , key: String): MutableList< T > { val json = prefs.getString(key , null ) val list = mutableListOf < T >() if (json...

Kotlin 문법 정리.

// 주석. /* 주석 */ // private 현재 파일에서만. // internal 같은 모듈에서만.  // protected 상속받은 클래스에서. class Test {     // Double, float, Long, int, Short, Byte, String, Char     val hello : String = """ hi                             hello """     // val 읽기 전용, var 쓰기 가능.     val a: Int = 1       var b: Int? = null       // lateinit 늦은 초기화.     lateinit private var mHandler: Handler     fun voidFunc() {}     fun sum(a: Int, b: Int) = a + b     fun sum(a: Int, b: Int = 10): Int { return a + b }     // int? 널타입 리턴 가능.     fun parseInt(str: String): Int? { return null }          fun NullCheck() {         var aa: Int? = 11         var bb: Int? = null           var cc: Int = aa!! // !! 널이 아님을 보증.   ...

Kotlin 개발 참고.

https://kotlinlang.org https://kotlinlang.org/docs/reference/  - 레퍼런스. https://play.kotlinlang.org  - 온라인 연습. https://kotlinlang.org/docs/reference/basic-syntax.html  - 간단 문법. https://play.kotlinlang.org/byExample/overview  문법 예제. https://github.com/android/user-interface-samples  - 실제 사용예를 볼수 있다. https://kotlinlang.org/docs/reference/collections-overview.html  - 콜렉션. https://kotlinlang.org/docs/reference/functions.html  - 함수, 람다. https://kotlinlang.org/docs/reference/classes.html  - 클래스. https://kotlinlang.org/docs/reference/coroutines/coroutines-guide.html  - 코루틴. https://kotlinlang.org/api/latest/jvm/stdlib/  - Kotlin Standard Library.

android studio assets raw 차이.

res/, assets/ - res 레이아웃, 아이콘 등이 위치하며 R클래스로 편리하게 접근할 수 있다. 즉 컴파일러가 데이터 처리를 위한 각종 동작을 한다. 파일 이름이 소문자, 숫자, 마침표, 언더바 로만 구성. - assets 모든 유형의 파일을 포함할 수 있고 파일 이름 제약이 거의 없다. apk 파일을 열어보면 보인다. 즉 사전처리 하지 않고 apk에 포함 시킨다. 여러 이름으로 여러개의 폴더를 만들수 있다. AssetManager로 접근할 수 있다. 읽기 전용. - 결론. 이미지, xml, 폰트 등 아래 링크에서 지원하는 형태의 데이터는 res 를 사용하면 된다. https://developer.android.com/guide/topics/resources/available-resources?hl=ko res에서 지원하지 않거나 이런 저런 이유로 직접 컨트롤하는 데이터는 assets을 사용하면 된다. R클래스를 사용할 수 없어서 좀 불편하긴 하지만 아무데나 만능으로 사용할 수 있다.

flutter MaterialApp - themeMode, theme, darkTheme

themeMode -  App 테마를 선택한다. light - OS 시스템 설정에 관계없이 항상 라이트 모드. theme 사용. dark - OS 시스템 설정에 관계없이 항상 다크 모드. darkTheme 사용. darkTheme가 null이면 테마 사용으로 대체됨. system - OS 시스템 설정에 따른다. 기본값이다. API 문서에 이런 말도 있습니다. MediaQuery.platformBrightnessOf가 Brightness.light 라면 theme가 사용된다. Brightness.dark인 경우 darkTheme가 사용된다.  darkTheme  themeMode가 dark이거나 시스템 설정이 dark 일때 사용됩니다. ThemeData.brightness가 Brightness.dark으로 설정되어야 합니다. darkTheme가 null일 경우 Theme가 대신 사용됩니다. darkTheme가 null이고 Theme도 null이면 ThemeData.light()로 설정됩니다. Theme themeMode가 light 이거나 시스템 설정이 light 일때 사용됩니다. 사용방법. Theme, darkTheme에 ThemeData(테마 속성 세부값)을 세팅한다. themeMode 를 어떻게 사용할지 정하여 사용한다. 참고. https://api.flutter.dev/flutter/material/MaterialApp/theme.html https://api.flutter.dev/flutter/material/MaterialApp/darkTheme.html https://api.flutter.dev/flutter/material/MaterialApp/themeMode.html https://api.flutter.dev/flutter/material/ThemeData-class.html

플러터(flutter) 개발 참고 사이트들.

플러터 프로젝트 사이트. https://flutter.dev/ https://api.flutter-ko.dev/ - API 레퍼런스. https://flutter-ko.dev/docs/cookbook - 사용방법. https://flutter-ko.dev/docs/get-started/install/windows - 플러터 설치. https://flutter-ko.dev/docs/development/ui/widgets - Widget catalog 카테고리 https://flutter-ko.dev/docs/reference/widgets - Widget catalog 알파벳 플러터 패키지 사이트. https://pub.dev/flutter/packages 플러터 라이브러리, 툴, 튜토리얼을 정리한 곳. https://github.com/Solido/awesome-flutter 예제 코드들. https://codelabs.developers.google.com/?cat=Flutter  - 코드랩 https://x-wei.github.io/flutter_catalog/#/  - 웹브라우저에서 위젯 예제와 코드를 볼수 있다. 플러터로 만들어진 App들을 볼수 있다. https://flutterawesome.com/ 플러터 UI를 웹브라우저에서 배치. https://flutterstudio.app/ https://widget.studio/#/ 다트 프로젝트 사이트. https://dart.dev/ https://api.dart.dev/ - API 레퍼런스. https://dartpad.dev/ - Dart 웹 코딩. 테스트 코드용. https://dart.dev/guides/language/language-tour - 간단한 문법.

flutter 개발환경 세팅 - Android Studio.

1. sdk 다운로드. https://flutter.dev/docs/get-started/install 2. 압축을 푼후 시스템 환경변수에 PATH를 추가한다. 예) D:\Dev\flutter\bin 3. flutter doctor 실행. 개발에 필요한 사항을 체크하여 알려준다. 예) 콘솔(cmd.exe)에서 위의 경로로(D:\Dev\flutter\bin) 이동후 flutter doctor 실행. 4. Android Studio 설치. 아래 경로에서 다운받아 설치하세요. https://developer.android.com/studio 5. Android Studio에서 flutter 플러그인 설치. file - setting - pluguns 로 이동하여 flutter 검색후 설치 후 Android Studio 재시작. - 트러블슈팅. 가상 안드로이드 실행시 adb를 못찾는다는 에러와 함께 디버깅이 되지 않았습니다. 해결은 다음과 같이 했습니다. 파일 - Close project 로 Welcome to Android Studio 창으로 이동합니다. 하단 Configure - SDK Manager 로 이동하여 sdk를 업데이트 했습니다.  이 외에도 Android  sdk 재설치를 해도 해결될거 같습니다. Android SDK Platform-Tools 재설치로는 해결되지 않았습니다. - 트러블슈팅2. cmdline-tools component is missing Android Studio를 실행하고 SDK Tools 옵션에서 Android SDK Command-line Tools (latest) 설치. 참고. 윈도우에서 설치 https://flutter-ko.dev/docs/get-started/install/windows