Development/Android

- 간혹 전체 텍스트에 url이 중간에 섞여있고, 이 부분을 링크 처리하여 사용자가 바로 외부로 연결할 수 있도록 구현이 필요할 때 아래와 같은 함수를 구성해서 사용한다.fun setHyperlinkedText(textView: TextView, rawText: String) { val spannable = SpannableString(rawText) val urlRegex = Regex("""https?://[^\s]+""") val matches = urlRegex.findAll(rawText) for (match in matches) { val url = match.value val start = match.range.first val en..
- XML 파일을 기반으로 Ripple을 구현하는 과정 - drawable에 ripple 태그를 활용해 효과 시에 보일 모양을 지정할 수 있다. - 그리고 생성한 리소스를 foreground로 설정해주면 완료val tab = FrameLayout(context).apply { layoutParams = LinearLayout.LayoutParams(0, MATCH_PARENT, 1f).apply { setMargins(tabMargin / 2, tabMargin, tabMargin / 2, tabMargin) } isClickable = true isFocusable = true s..
- 위젯 갱신을 위한 refresh 함수에서 생성자 접근 시에 발생했다.val widgetInstance = widgetClass.getDeclaredConstructor().newInstance() - 위젯 클래스를 생성자 없는 object로 선언하고, 생성자 접근 코드를 제거하여 refresh 함수를 수정했다.object MemoListWidget : GlanceAppWidget() {fun updateAll(context: Context) { CoroutineScope(Dispatchers.IO).launch { val manager = GlanceAppWidgetManager(context) val now = System.currentTimeMillis() ..
val bitmap = Bitmap.createBitmap(200, 200, Bitmap.Config.ARGB_8888)val canvas = Canvas(bitmap)val paint = Paint()val path = Path()path.fillType = Path.FillType.EVEN_ODDpath.moveTo(0f, 40f)path.lineTo(5f, 0f)path.lineTo(5f, 80f)path.lineTo(0f, 40f)canvas.drawPath(path, paint)paint.strokeWidth = 10fcanvas.drawLine(5f, 40f, 200f, 40f, paint)val rightPath = Path()rightPath.fillType = Path.FillType.E..
- 다음과 같은 NestedScrollView를 화면에서 사용할 때, 사용자 편의성을 위해 최상단으로 한 번에 스크롤하는 기능이 필요할 때가 있다. - 그럴 때에 다음 scrollTo 함수를 사용해주면 된다.//스무스하게 이동fun scrollToTop() = with(binding) { scrollView.post { scrollView.smoothScrollTo(0, 0) }}//즉시 이동fun scrollToTopInstantly(scrollView: NestedScrollView) { scrollView.post { scrollView.scrollTo(0, 0) }}
- 내가 편하게 쓰려고 메모장 앱을 간단하게 만들고 있는데, 외부 웹 사이트에서 링크를 쉽게 공유하고 싶어 내 앱으로의 Intent 공유 기능을 활성화했다. - 과정은 다음과 같다. 일단 Intent로 공유받는 데이터를 수신할 Activity를 하나 생성해 준다.class ReceiveShareActivity : ComponentActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) val sharedUrl = if (intent?.action == Intent.ACTION_SEND && intent.type == "text/plain") { ..
- Glance에서 어떤 동작을 수행하고 나서 위젯을 업데이트하기 위해 아래와 같은 로직을 호출했다.CoroutineScope(Dispatchers.IO).launch { val manager = GlanceAppWidgetManager(context) widgetList.forEach { (widgetClass, stateKey) -> val glanceIds = manager.getGlanceIds(widgetClass) val widgetInstance = widgetClass.getDeclaredConstructor().newInstance() glanceIds.forEach { glanceId -> widgetInstance.u..
- 안드로이드 Glance에서 특정 화면을 열거나 로직을 수행하기 위해서는 GlanceModifier.onClick()에 Action을 명시해주어야 한다. - Glance의 Action은 UI 요소에 "동작"을 연결하는 역할을 하는 개념이다.위젯에서 특정 Activity 열기- 먼저 Glance에서 특정 화면을 열기 위해 ActionIntent는 아래와 같이 사용한다.modifier = GlanceModifier .size(20.dp) .clickable(onClick = actionStartActivity( Intent(context, WidgetSettingsActivity::class.java).apply { data = Uri.parse(KEY_WIDGE..
- 위젯을 구현하다 보면 사이즈 별로 다른 레이아웃을 제공하거나 높이 너비에 따라 View의 구성이 달라지는 구현을 필요로 할 때가 있다. - 기존 RemoteViews에서는 AppWidgetInfo에 접근하여 사이즈 값에 대해 확인했으나 Glance에서는 좀 다르다.appWidgetManager.getAppWidgetInfo(appWidgetId).minHeight - SizeMode 라는 값을 통해 위젯 크기 변화에 따른 레이아웃 구성 대응이 가능하다. - SizeMode는 Glance 위젯이 시스템에서 요구하는 사이즈 정보의 유연성을 어떻게 처리할지를 정의한다.sealed interface SizeMode { /** * The [GlanceAppWidget] provides a sing..
- 코틀린 코드로 XML 뷰 높이를 조절하는 코드val heightInPx = TypedValue.applyDimension( TypedValue.COMPLEX_UNIT_DIP, myViewHeight, myView.context.resources.displayMetrics).toInt()myView.updateLayoutParams { height = heightInPx }- dp 값을 px로 변환 후에 androidx.core.view.updateLayoutParams를 import 하여 LayoutParams에 접근한다.
SeungYong.Lee
'Development/Android' 카테고리의 글 목록 (4 Page)