— Android — 2 min read
안드로이드 14 UpsideDownCake가 나온지 한참 되었지만, 대응에 관한 글이 없어 작성해보고자 한다...
안드로이드 14에서 바뀐 점들이 꽤 많은데 다 나열할 수는 없고 일단 중요한 포인트 들만 나열한다면 이렇게 7가지 종류가 있다. 모든 변경 사항을 확인하고 싶다면 개발자 사이트를 확인하자.
중요한 점들이 몇가지 있는데 보통 많이 적용하는 것들 위주로 설명한다면
우선 암시적 인텐트를 사용할 수 없다는 것은 앱이 manifest에 설정되지 않은 패키지나 설정창 등에 접근하게 하려면 Intent를 수정해야한다.
이렇게 선언된 것들은 모두 exception을 발생시킨다.
1// Throws an exception when targeting Android 14.2context.startActivity(Intent("com.example.action.APP_ACTION"))
그렇다고 방법이 없는 것은 아니다. 이와 같이 변경하면 암시적 인텐트를 사용할 수 있다.
1// This makes the intent explicit.2val explicitIntent =3 Intent("com.example.action.APP_ACTION")4explicitIntent.apply {5 package = context.packageName6}7context.startActivity(explicitIntent)
예를 들자면 만약 앱의 설정화면으로 이동해야한다면 기존 코드는 아래와 같다.
1val intent = Intent().apply {2 action = Settings.ACTION_APP_NOTIFICATION_SETTINGS3 }4 try {5 startActivity(intent)6 } catch (e: Exception) {7 Timber.e(e.message)8 }
안드로이드 14를 타겟팅 한다면 다음과 같이 변경해 주어야한다. packageName은 당연히 이 앱의 이름이다.
1val intent = Intent(Settings.ACTION_APP_NOTIFICATION_SETTINGS).apply {2 putExtra(Settings.EXTRA_APP_PACKAGE, packageName)3 }4 try {5 startActivity(intent)6 } catch (e: Exception) {7 Timber.e(e.message)8 }
이건 알람을 쓰는 앱에서는 치명적인데 만약 앱이 알람을 쓰고있지 않다면 당신은 Lucky.. 하지만 그렇게 복잡하지는 않다.
그냥 exactAlarm() 을 사용하고 싶다면 권한을 추가하고, 권한을 사용자에게 요구하면 된다. 말로는 쉽지만 .. 하지만 포그라운드 서비스 유형보다는 백만배 쉽다.
정확한 알림 설정구글에서 제공한 코드에 !! 가 들어가있는 것은 가히 충격적이지만 이 부분은 수정하도록하자 ..
1val alarmManager: AlarmManager = context.getSystemService<AlarmManager>()!!2when {3 // If permission is granted, proceed with scheduling exact alarms.4 alarmManager.canScheduleExactAlarms() -> {5 alarmManager.setExact(...)6 }7 else -> {8 // Ask users to go to exact alarm page in system settings.9 startActivity(Intent(ACTION_REQUEST_SCHEDULE_EXACT_ALARM))10 }11}
얘가 제일 골치 아프다.. 일단 Service 를 사용한다면 그 Service를 왜 사용하고 있고, 그 유형에 맞는 서비스동작을 manifest에 추가해 주어야한다. 그리고 아무도 안알려주지만, 앱 심사시에 그 Service 권한에 대해 왜 사용하는지, 필요한 이유가 뭔지에 대한 동영상을 제출해야 심사가 가능하다...
서비스유형은 다음과 같다
다행히 FirebaseMessaging Service를 사용하고 있다면 remoteMessaging 권한은 추가하지 않아도 된다. 하지만... 서버에서 사용하는 push Alaram 을 받고 있다면 이 권한에 대한 설정이 필요하다.
자세한 내용은 역시 제공자이자.. 크리에이터인 google의 문서를 보자
만약 위젯에서 Service를 사용한다면 이번 기회에 WorkManager로 마이그레이션 하는 것이 훨씬 빠를지도 모른다. 하지만 여기서 함정은 "JobScheduler가 콜백 및 네트워크 동작을 강화" 인데, 만약 background WorkManager가 지정된 시간보다 오래걸리면 ANR을 뱉어낸다.
그래서 지정된 시간이 얼만데 .. 안알려줘서 AOSP 를 까보았다.
1if (transientExtras.getBoolean(EXTRA_SLOW_START)) {2 try {3 Thread.sleep(60_000);4 } catch (InterruptedException e) {5 Log.e(TAG, "Interrupted sleeping for slow start");6 }7 }
TestJobService를 보니 ANR 이 트리거 되는 시간은 60_000 이다. 이런건 왜 문서에 안적어줄까? .. 아무튼 WorkManager로 마이그레이션한다면 이 시간에 주의하도록 하자.
이렇게 모든 것들을 마치고 나서 동영상까지 제출하고 심사를 통과한다면 당신은 성공한 것이다! 하지만 ... Android 15가 다가오고 있으므로 또 다시 마이그레이션 할 준비를 하도록하자 ..!