Фрагмент
| Последнее обновление | Стабильный релиз | Предварительная версия релиза | Бета-версия | Альфа-версия |
|---|---|---|---|---|
| 13 августа 2025 г. | 1.8.9 | - | - | - |
Объявление зависимостей
Чтобы добавить зависимость от Fragment, необходимо добавить репозиторий Google Maven в ваш проект. Для получения дополнительной информации ознакомьтесь с информацией в репозитории Google Maven .
Добавьте зависимости для необходимых артефактов в файл build.gradle вашего приложения или модуля:
классный
dependencies { def fragment_version = "1.8.9" // Java language implementation implementation "androidx.fragment:fragment:$fragment_version" // Kotlin implementation "androidx.fragment:fragment-ktx:$fragment_version" // Compose implementation "androidx.fragment:fragment-compose:$fragment_version" // Testing Fragments in Isolation debugImplementation "androidx.fragment:fragment-testing-manifest:$fragment_version" androidTestImplementation "androidx.fragment:fragment-testing:$fragment_version" }
Котлин
dependencies { val fragment_version = "1.8.9" // Java language implementation implementation("androidx.fragment:fragment:$fragment_version") // Kotlin implementation("androidx.fragment:fragment-ktx:$fragment_version") // Compose implementation("androidx.fragment:fragment-compose:$fragment_version") // Testing Fragments in Isolation debugImplementation("androidx.fragment:fragment-testing:$fragment_version") }
Для получения дополнительной информации о зависимостях см. раздел «Добавление зависимостей сборки» .
Обратная связь
Ваши отзывы помогают улучшить Jetpack. Сообщите нам, если вы обнаружите новые проблемы или у вас есть идеи по улучшению этой библиотеки. Пожалуйста, ознакомьтесь с существующими проблемами в этой библиотеке, прежде чем создавать новую. Вы можете проголосовать за существующую проблему, нажав кнопку со звездочкой.
Для получения более подробной информации см. документацию по системе отслеживания ошибок .
Версия 1.8
Версия 1.8.9
13 августа 2025 г.
Выпущена версия androidx.fragment:fragment-*:1.8.9 . Версия 1.8.9 содержит следующие коммиты .
Исправлены ошибки
- Исправлена ошибка, из-за которой отмена предиктивного жеста «назад», приводящего к операции скрытия, приводила к некорректной анимации последующего жеста при использовании аниматоров. ( I0a400 , b/384765586 )
- Исправлена ошибка, из-за которой комбинация
setMaxLifecycleиpopBackStackмогла не переместить верхний фрагмент в состояние RESUMED. ( I3448b , b/406127576 )
Версия 1.8.8
4 июня 2025 г.
Выпущена версия androidx.fragment:fragment-*:1.8.8 . Версия 1.8.8 содержит следующие коммиты .
Исправлены ошибки
- Исправлена ошибка, из-за которой
FragmentManagerаварийно завершал работу при попытке сохранить состояние фрагментов, добавленных с помощьюsetMaxLifecycle(Lifecycle.State.INITIALIZED). Поскольку эти фрагменты никогда не проходилиonCreate(), у них больше не сохраняется состояние и не вызываетсяonSaveInstanceState(). ( I6e37a )
Версия 1.8.7
20 мая 2025 г.
Выпущена версия androidx.fragment:fragment-*:1.8.7 . Версия 1.8.7 содержит следующие коммиты .
Исправлены ошибки
- Исправлена ошибка, из-за которой
FragmentManagerнаходился в некорректном состоянии после операций pop и replace в одном и том же фрейме, что могло привести к сбою при одновременном удалении стека возврата либо с помощьюpopBackStack, либо с помощью предиктивного жеста возврата. ( I50ad1 ) - Исправлена ошибка, приводившая к сбою при использовании переходов AndroidX и возникновению ситуации, когда быстрые последовательные транзакции фрагментов пытались отменить незапущенный переход, а библиотека переходов AndroidX некорректно очищала состояние перехода. (см. b/414612221 ). ( Ib5235 )
Версия 1.8.6
12 февраля 2025 г.
androidx.fragment:fragment-*:1.8.6 is released. Version 1.8.6 contains these commits .
Исправлены ошибки
- В методе
setOnApplyWindowInsetsListenerклассаFragmentContainerViewтеперь принимается нулевой слушатель, что соответствует возможностям фреймворка. ( I575f0 , b/282790626 )
Версия 1.8.5
30 октября 2024 г.
androidx.fragment:fragment-*:1.8.5 is released. Version 1.8.5 contains these commits .
Исправлены ошибки
- Fixed an
IllegalStateExceptiontriggered bysaveBackStackonly after a Predictive Back gesture was canceled or interrupted. ( I3387d , b/342419080 )
Версия 1.8.4
2 октября 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.8.4 . Версия 1.8.4 содержит следующие коммиты .
Исправлены ошибки
- Исправлена ошибка, из-за которой быстрое нажатие системной кнопки «Назад» или быстрое выполнение жеста «Назад» приводило к сбою Fragments при использовании переходов Androidx. ( Ibc038 , b/364804225 )
- Исправлена ошибка во фрагментах, из-за которой прерывание предиктивного жеста «назад» приводило к тому, что менеджер фрагментов переходил в неопределенное состояние и даже отображал неправильный фрагмент. ( If82e2 , b/338624457 )
- Исправлена ошибка
UninitializedPropertyAccessExceptionвAndroidFragmentпри динамической замене класса, используемого экземпляромAndroidFragment. ( I12dea )
Версия 1.8.3
4 сентября 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.8.3 . Версия 1.8.3 содержит следующие коммиты .
Исправлены ошибки
- Теперь
FragmentManagerкорректно учитывает незавершенные операции при обработке жеста «Предсказательное возвращение назад». Это должно гарантировать, что выполнение системного возврата назад больше не будет вызывать исключениеIndexOutOfBoundsException. ( I9ba32 , b/342316801 ) -
AndroidFragmentбольше не приводит к сбою, если он добавляется в композицию, когда состояние содержащей его активности/фрагмента уже сохранено. ( I985e9 , b/356643968 )
Версия 1.8.2
24 июля 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.8.2 . Версия 1.8.2 содержит следующие коммиты .
Исправлены ошибки
- Теперь
AndroidFragmentкорректно обрабатывает случаи, когда родительский фрагмент помещается в стек возврата Fragment, избегая проблем с ошибкой «No view found for id» при возврате к этому фрагменту. ( I94608 ) - Фрагменты, добавленные с помощью метода
FragmentTransaction.add, принимающегоViewGroup, теперь ожидаютonContainerAvailableпрежде чем перейти кonStart(). Это влияет на пользователей этого API, например, наAndroidFragment, который теперь ожидает повторного входаAndroidFragmentв композицию, прежде чем перейти кonStart(). ( I94608 )
Версия 1.8.1
26 июня 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.8.1 . Версия 1.8.1 содержит следующие коммиты .
Исправлены ошибки
- Исправлена ошибка, из-за которой фрагменты без контейнера немедленно
DESTROYEDпри начале выполнения жеста "предсказательное движение назад". Теперь они остаются в состоянииCREATEDдо завершения жеста. ( If6b83 , b/345244539 )
Версия 1.8.0
12 июня 2024 г.
androidx.fragment:fragment-*:1.8.0 is released. Version 1.8.0 contains these commits .
Important changes since 1.7.0
- Артефакт
fragment-composeтеперь содержит компонентAndroidFragmentComposable, позволяющий добавлять фрагменты в иерархию Compose по имени класса фрагмента. Он автоматически обрабатывает сохранение и восстановление состояния фрагмента. Это следует использовать в качестве прямой замены ранее рекомендуемого подхода с использованиемAndroidViewBindingдля создания фрагмента. - Теперь коллбэк
onBackStackChangeCancelledв интерфейсеOnBackStackChangedListenerклассаFragmentManagerсрабатывает как часть операций выполнения вFragmentManager, что приближает его по времени к коллбэкуonBackStackChangeCommitted.
Версия 1.8.0-rc01
29 мая 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.8.0-rc01 . Версия 1.8.0-rc01 содержит следующие коммиты .
Исправлены ошибки
- Теперь коллбэк
onBackStackChangeCancelledв интерфейсеFragmentManagers OnBackStackChangedListenerсрабатывает как часть операций выполнения вFragmentManager, что приближает его по времени к коллбэкуonBackStackChangeCommitted. ( I5ebfb , b/332916112 )
Версия 1.8.0-beta01
14 мая 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.8.0-beta01 . Версия 1.8.0-beta01 содержит следующие коммиты .
Исправлены ошибки
- Начиная с фрагмента
1.7.1: Функция предиктивного возврата теперь будет запускаться только для транзакций, в которых все фрагменты имеют либо аниматор, либо переход Androidx с возможностью перемотки. Это исправляет проблему, из-за которой отмена частично перемотаемой транзакции приводила к черному экрану. ( I43037 , b/339169168 )
Версия 1.8.0-alpha02
17 апреля 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.8.0-alpha02 . Версия 1.8.0-alpha02 содержит следующие коммиты .
Исправлены ошибки
- Начиная с фрагмента
1.7.0-rc02: Добавлены логи, указывающие на причину сбоя при установкеsharedElementбез каких-либо других переходов. ( Iec48e ) - Из фрагмента
1.7.0-rc02: Исправлена ошибка, из-за которой добавление неперемещаемого общего элемента к транзакции, в которой все остальные переходы перемещаемы, приводило к сбою. Теперь транзакция будет корректно считаться неперемещаемой. ( I18ccd )
Версия 1.8.0-alpha01
3 апреля 2024 г.
androidx.fragment:fragment-*:1.8.0-alpha01 is released. Version 1.8.0-alpha01 contains these commits .
Новые функции
- Новый компонент
AndroidFragmentComposableпозволяет добавлять фрагменты в иерархию Compose по имени класса фрагмента. Он автоматически обрабатывает сохранение и восстановление состояния фрагмента. Его можно использовать в качестве прямой замены компонента AndroidViewBindingComposable( b/312895363 , Icf841 ).
Изменения в документации
- Updated documentation for the
OnBackStackChangedListenerAPIs to indicate when they are called and how they should be used. ( I0bfd9 )
Обновление зависимостей
- Fragment now depends on Profile Installer 1.3.1 .
Версия 1.7
Версия 1.7.1
14 мая 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.7.1 . Версия 1.7.1 содержит следующие коммиты .
Исправлены ошибки
- Функция предиктивного возврата теперь будет запускаться только для транзакций, в которых все фрагменты имеют либо анимацию, либо переход типа Seekable Androidx. Это исправляет проблему, из-за которой отмена частично перемещаемой транзакции приводила к пустому экрану. ( I43037 , b/339169168 )
Версия 1.7.0
1 мая 2024 г.
androidx.fragment:fragment-*:1.7.0 is released. Version 1.7.0 contains these commits .
Прогнозируемая поддержка жестов спины
- Теперь фрагменты поддерживают предиктивный жест "назад" внутри приложения при использовании
Animatorили AndroidX Transition 1.5.0 . Это позволяет пользователям использовать жест "назад", чтобы увидеть предыдущий фрагмент, переместив Animator/Transition, прежде чем принять решение о завершении транзакции путем выполнения жеста или отмене.
| Система перехода | XML-ресурс | Supports Predictive Back |
|---|---|---|
Animation | R.anim | Нет |
Animator | R.animator | Да |
Framework Transition | R.transition | Нет |
AndroidX Transition with Transition 1.4.1 or less | R.transition | Нет |
Transition на AndroidX с Transition 1.5.0 | R.transition | Да |
Если после включения функции предиктивного нажатия кнопки "Назад" во фрагментах вы обнаружите какие-либо проблемы с её поддержкой, пожалуйста, создайте заявку в репозиторий Fragment, приложив пример проекта, воспроизводящего вашу проблему. Вы можете отключить предиктивное нажатие кнопки "Назад", используя FragmentManager.enabledPredictiveBack(false) в методе onCreate() вашего Activity.
Теперь FragmentManager.OnBackStackChangedListener() предоставляет обработчики событий onBackStackChangeProgressed() и onBackStackChangeCancelled() для получения прогнозируемых событий возврата назад и отмены соответственно.
Fragment Compose Artifact
Создан новый артефакт fragment-compose , ориентированный на поддержку приложений, находящихся в процессе перехода от архитектуры на основе фрагментов к полностью архитектуре на основе Compose.
Первая функция, доступная в этом новом артефакте, — это метод расширения content для Fragment , который призван упростить использование Compose для пользовательского интерфейса отдельного фрагмента, создавая для вас ComposeView и устанавливая правильную ViewCompositionStrategy .
class ExampleFragment : Fragment() {
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
) = content {
// Write your @Composable content here
val viewModel: ExampleViewModel = viewModel()
// or extract it into a separate, testable method
ExampleComposable(viewModel)
}
}
Версия 1.7.0-rc02
17 апреля 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.7.0-rc02 . Версия 1.7.0-rc02 содержит следующие коммиты .
Исправлены ошибки
- Added logs to indicate why setting a
sharedElementwithout any other transitions will fail to run. ( Iec48e ) - Исправлена ошибка, из-за которой добавление неперемещаемого общего элемента в транзакцию, в которой все остальные переходы перемещаемы, приводило к сбою. Теперь транзакция будет корректно считаться неперемещаемой. ( I18ccd )
Версия 1.7.0-rc01
3 апреля 2024 г.
androidx.fragment:fragment-*:1.7.0-rc01 is released. Version 1.7.0-rc01 contains these commits .
Обновление зависимостей
- Fragment now depends on Profile Installer 1.3.1 .
Версия 1.7.0-beta01
20 марта 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.7.0-beta01 . Версия 1.7.0-beta01 содержит следующие коммиты .
Изменения в API
- Теперь
FragmentHostCallbackнаписан на Kotlin таким образом, что допустимость значения null для обобщенного типа Host соответствует допустимости значения null для возвращаемого типа методаonGetHost(). ( I40af5 )
Исправлены ошибки
- Исправлена ошибка, из-за которой при выполнении жеста «Назад» с предиктивным вводом на фрагменте, не находящемся в контейнере, этот фрагмент никогда не уничтожался. Теперь фрагмент будет немедленно перемещен в конечное состояние. ( Ida0d9 )
- Исправлена ошибка во фрагментах, из-за которой прерывание входящих переходов с помощью предиктивного жеста «назад» уничтожало входящее представление и оставляло пустой экран. ( Id3f22 , b/319531491 )
Версия 1.7.0-alpha10
7 февраля 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.7.0-alpha10 . Версия 1.7.0-alpha10 содержит следующие коммиты.
Исправлены ошибки
- Исправлена известная проблема из предыдущей версии Fragment, из-за которой при использовании поддержки предиктивного возврата (Predictive Back) для
Animatorили AndroidX Transition, Fragment выбрасывалNullPointerExceptionизhandleOnBackProgressed, еслиFragmentManager.OnBackStackChangedListenerне был добавлен с помощьюaddOnBackStackChangedListener. ( I7c835 )
Версия 1.7.0-alpha09
24 января 2024 г.
Выпущена версия androidx.fragment:fragment-*:1.7.0-alpha09 . Версия 1.7.0-alpha09 содержит следующие коммиты.
Фрагмент Составить Артефакт
A new fragment-compose artifact has been created that focuses on supporting apps that are in the process of moving from a Fragment based architecture to a fully Compose based architecture.
Первая функция, доступная в этом новом артефакте, — это метод расширения content для Fragment , который призван упростить использование Compose для пользовательского интерфейса отдельного фрагмента путем создания ComposeView и установки правильной ViewCompositionStrategy . ( 561cb7 , b/258046948 )
class ExampleFragment : Fragment() {
override fun onCreateView(
inflater: LayoutInflater,
container: ViewGroup?,
savedInstanceState: Bundle?
) = content {
// Write your @Composable content here
val viewModel: ExampleViewModel = viewModel()
// or extract it into a separate, testable method
ExampleComposable(viewModel)
}
}
Новые функции
-
FragmentManager.OnBackStackChangedListener()now provides theonBackStackChangeProgressed()andonBackStackChangeCancelled()for receiving predictive back progress and canceled events respectively. ( 214b87 )
Известная проблема
- При использовании поддержки предиктивной отправки "Назад" в Fragment для
Animatorили AndroidX Transition, Fragment будет выдаватьNullPointerExceptionизhandleOnBackProgressed, еслиFragmentManager.OnBackStackChangedListenerне был добавлен с помощьюaddOnBackStackChangedListener. Добавление слушателя вручную позволит обойти эту проблему. Исправление будет доступно в следующем релизе Fragments.
Version 1.7.0-alpha08
10 января 2024 г.
androidx.fragment:fragment-*:1.7.0-alpha08 is released. Version 1.7.0-alpha08 contains these commits.
Уборка
- Removed workaround for Transition library that has been fixed in Transition
1.5.0-alpha06. ( I04356 )
Версия 1.7.0-alpha07
29 ноября 2023 г.
androidx.fragment:fragment-*:1.7.0-alpha07 is released. Version 1.7.0-alpha07 contains these commits.
Исправлены ошибки
- Fixed a
NullPointerExceptioncaused by setting a shared element transition and failing to set an enter/exitTransition as well. ( I8472b ) - Начиная с версии Fragment
1.6.2: При создании фрагментаFragmentContainerViewего состояния, такие какFragmentManager, Host и id, теперь доступны в коллбэкеonInflate. ( I1e44c , b/307427423 ) - Начиная с версии Fragment
1.6.2: При использованииclearBackStackдля удаления набора фрагментов,ViewModelлюбого вложенного фрагмента теперь будет очищаться одновременно с очисткойViewModelsродительского фрагмента. ( I6d83c , b/296173018 )
Версия 1.7.0-alpha06
4 октября 2023 г.
androidx.fragment:fragment-*:1.7.0-alpha06 is released. Version 1.7.0-alpha06 contains these commits.
Обновление зависимостей
- Fragments has been updated to depend on the new
animateToStartAPI added in Transition1.5.0-alpha04.
Version 1.7.0-alpha05
20 сентября 2023 г.
androidx.fragment:fragment-*:1.7.0-alpha05 is released. Version 1.7.0-alpha05 contains these commits.
Новые функции
- Теперь фрагменты поддерживают функцию предиктивного возврата при использовании переходов Androidx. Это позволяет использовать жест «назад» для перехода к предыдущему фрагменту с вашим пользовательским переходом Androidx, прежде чем принять решение о подтверждении или отмене транзакции с помощью жеста «завершено». Для включения этой функции необходимо использовать версию Transition
1.5.0-alpha03. ( Ib49b4 , b/285175724 )
Известные проблемы
- В настоящее время существует проблема, при которой после отмены жеста «Назад» с помощью перехода при следующем запуске перехода, он не выполняется, что приводит к пустому экрану. Это может быть вызвано ошибкой в библиотеке Transition ( b/300157785 ). Если вы столкнулись с этой проблемой, пожалуйста, сообщите о ней в репозиторий Fragment, предоставив пример проекта, воспроизводящего вашу проблему. Вы можете отключить предиктивный возврат, используя
FragmentManager.enabledPredictiveBack(false)в методеonCreate()вашей Activity.
Version 1.7.0-alpha04
6 сентября 2023 г.
androidx.fragment:fragment-*:1.7.0-alpha04 is released. Version 1.7.0-alpha04 contains these commits.
Исправлены ошибки
- Исправлена ошибка, возникавшая при отмене предиктивного жеста «назад», из-за которой фрагменты не переходили в правильное состояние жизненного цикла. ( I7cffe , b/297379023 )
- Fixed a regressions where Animations were allowed to run with Transitions. ( I59f36 )
- Fixed an issue when using Predictive Back with fragments where attempting to go back twice in quick succession on the second to last fragment on the back stack would cause a crash. ( Ifa1a4 )
Версия 1.7.0-alpha03
23 августа 2023 г.
androidx.fragment:fragment-*:1.7.0-alpha03 is released. Version 1.7.0-alpha03 contains these commits.
Исправлены ошибки
- Исправлена ошибка с фрагментами при использовании предиктивного возврата, из-за которой первый фрагмент в стеке возврата менеджера фрагментов пропускался, а Activity завершалась при использовании системного возврата с помощью навигации тремя кнопками или предиктивного жеста возврата. ( I0664b , b/295231788 )
Version 1.7.0-alpha02
9 августа 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.7.0-alpha02 . Версия 1.7.0-alpha02 содержит следующие коммиты.
Исправлены ошибки
- При использовании фрагментов с предиктивными жестами возврата, начиная с API 34, если вы используете систему переходов, которая не поддерживает перемотку (
Animations,Transitions) или вообще не поддерживает переходы, фрагменты будут ждать завершения жеста, прежде чем выполнить действие возврата. ( I8100c )
Версия 1.7.0-alpha01
7 июня 2023 г.
androidx.fragment:fragment-*:1.7.0-alpha01 is released. This version is developed in an internal branch.
Новые функции
- Теперь фрагменты поддерживают предиктивный жест "назад" в приложении при использовании
Animator. Это позволяет использовать жест "назад", чтобы увидеть предыдущий фрагмент с вашим пользовательским Animator, прежде чем решить, подтвердить ли транзакцию жестом "завершено" или отменить. Вы также можете отключить это новое поведение, используя экспериментальную функциюenablePredictiveBack()и передав значениеfalse.
Версия 1.6
Версия 1.6.2
1 ноября 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.2 . Версия 1.6.2 содержит следующие коммиты.
Исправлены ошибки
- When the Fragment of a
FragmentContainerViewis inflated, its states such asFragmentManager, Host, and id are now accessible in theonInflatecallback. ( I1e44c , b/307427423 ) - При использовании
clearBackStackдля удаления набора фрагментов,ViewModelлюбого вложенного фрагмента теперь будет очищаться одновременно с очисткойViewModelsродительского фрагмента. ( I6d83c , b/296173018 )
Version 1.6.1
26 июля 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.1 . Версия 1.6.1 содержит следующие коммиты.
Исправлены ошибки
- Исправлена ошибка, из-за которой сохраненное состояние, хранившееся при остановке, но не уничтожении активности, некорректно кэшировалось даже после того, как экземпляр фрагмента возвращался в состояние
RESUMED. Это приводило к повторному использованию кэшированного состояния, если экземпляр фрагмента находился в стеке возврата при использовании API множественных стеков возврата для сохранения и восстановления этого фрагмента. ( I71288 , b/246289075 )
Обновление зависимостей
- Fragment now depends on Activity 1.7.2 . This fixes an issue where Kotlin users could not extend
ComponentDialogwithout an explicit dependency on Activity. ( b/287509323 )
Версия 1.6.0
7 июня 2023 г.
androidx.fragment:fragment-*:1.6.0 is released. Version 1.6.0 contains these commits.
Important changes since 1.5.0
- The saved state of
Fragments has been split entirely between private library state (customParcelableclasses) and state provided by the developer, which is now always stored in aBundlethat allows determining exactly where a fragment's state is originating. - Интерфейс
FragmentManager.OnBackStackChangedListenerбыл расширен двумя дополнительными функциями обратного вызова:onBackStackChangeStartedиonBackStackChangeCommitted, которые вызываются для каждогоFragmentнепосредственно перед его добавлением/удалением из стека возврата фрагмента и сразу после подтверждения транзакции, соответственно. -
FragmentStrictModeдобавлена новая ошибкаWrongNestedHierarchyViolation, которая обнаруживает ситуацию, когда дочерний фрагмент вложен в иерархию View родительского элемента, но не добавлен вchildFragmentManagerродительского элемента. - API-интерфейсы
FragmentиFragmentManager, принимающиеIntentилиIntentSenderтеперь корректно аннотированы@NonNull, чтобы предотвратить передачу значения null, поскольку такое значение всегда немедленно приводило бы к сбою соответствующих API-интерфейсов Android-фреймворка, вызываемых этими методами. - Теперь
DialogFragmentпредоставляет доступ к базовому компонентуComponentDialogчерез APIrequireComponentDialog(). - Fragment now depends on Lifecycle
2.6.1. - Fragment now depends on SavedState
1.2.1. - Теперь Fragment зависит от ProfileInstaller
1.3.0. The
fragment-testing-manifestartifact separates out the manifest entries from the rest of the fragment-testing components. This means you can do the following:debugImplementation("androidx.fragment:fragment-testing-manifest:X.Y.Z") androidTestImplementation("androidx.fragment:fragment-testing:X.Y.Z")Это позволяет избежать конфликтов, возникающих из-за несоответствия версий между
fragment-testingиandroidx.test
Version 1.6.0-rc01
10 мая 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-rc01 . Версия 1.6.0-rc01 содержит следующие коммиты.
Исправлены ошибки
- Исправлена ошибка, из-за которой
ActivityResultотправлялся с некорректным кодом запроса при выполнении нескольких запросовstartActivityForResultподряд. ( If0b9d , b/249519359 ) - Fixed an issue where the
onBackStackChangeListenercallbacks were being dispatched for transactions that did not actually change the back stack if they were mixed in with transactions that do. ( I0eb5c , b/279306628 )
Version 1.6.0-beta01
19 апреля 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-beta01 . Версия 1.6.0-beta01 содержит следующие коммиты.
Исправлены ошибки
- Использование
postponeEnterTransitionс таймаутом и последующей заменой отложенного фрагмента больше не приводит к утечке отложенного фрагмента. ( I2ec7d , b/276375110 ) - Новые функции обратного вызова
onBackStackChangeStartedиonBackStackChangeCommittedтеперь будут отправлять фрагмент только один раз, даже если несколько транзакций содержат один и тот же фрагмент. ( Ic6b69 )
Version 1.6.0-alpha09
5 апреля 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-alpha09 . Версия 1.6.0-alpha09 содержит следующие коммиты.
Изменения в API
- Теперь
DialogFragmentпредоставляет доступ к базовомуComponentDialogчерез APIrequireComponentDialog(). ( I022e3 , b/234274777 ) - The fragment
commitNow(),executePendingTransactions(), andpopBackStackImmediate()APIs have been annotated with@MainThreadmeaning they will now all throw build errors when they are not called from the main thread instead of waiting to fail at runtime. ( Ic9665 , b/236538905 )
Исправлены ошибки
- Исправлена ошибка в
FragmentManager, из-за которой сохранение и восстановление в одном и том же кадре могло привести к сбою. ( Ib36af , b/246519668 ) - Теперь обработчики событий
OnBackStackChangedListeneronBackStackChangeStartedиonBackStackChangeCommittedвыполняются только при изменении стека возвратаFragmentManager. ( I66055 , b/274788957 )
Version 1.6.0-alpha08
22 марта 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-alpha08 . Версия 1.6.0-alpha08 содержит следующие коммиты.
Behavior Change
- The timing of the
OnBackStackChangedListener.onBackStackChangeCommitedcallback has been adjusted to execute before fragment operations are executed. This ensures that the callback will never be passed a fragment that is detached. ( I66a76 , b/273568280 )
Исправлены ошибки
- From Fragment
1.5.6: Fixed an issue where callingclearFragmentResultListenerinside asetFragmentResultListenerwouldn't work if theLifecyclewas alreadySTARTEDand a result was already available. ( If7458 )
Обновления зависимостей
- Теперь Fragment зависит от Lifecycle
2.6.1. ( 586fe7 ) - Fragment now depends on SavedState
1.2.1. ( 078e4e ) - Теперь Fragment зависит от ProfileInstaller
1.3.0( 3fc05b ).
Version 1.6.0-alpha07
8 марта 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-alpha07 . Версия 1.6.0-alpha07 содержит следующие коммиты.
Исправлены ошибки
- Начиная с версии Fragment
1.5.6: Исправлена ошибка, из-за которой удаление любого фрагмента, независимо от того, добавлял ли он пункты меню или нет, приводило к неработоспособности меню активности. ( 50f098 , b/244336571 )
Version 1.6.0-alpha06
22 февраля 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-alpha06 . Версия 1.6.0-alpha06 содержит следующие коммиты.
Behavior change
- Новый коллбэк
onBackStackChangedStartedв обработчикеonBackStackChangedListenerклассаFragmentManagerтеперь будет выполняться до того, как фрагменты начнут перемещаться в целевые состояния. ( I34726 )
Version 1.6.0-alpha05
8 февраля 2023 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-alpha05 . Версия 1.6.0-alpha05 содержит следующие коммиты.
Новые функции
- The
FragmentManager.OnBackStackChagnedListenerinterface now offers two additional callbacks,onBackStackChangeStartedandonBackStackChangeCommitted, that allow for additional information and control when back stack changes occur in theFragmentManager. ( Ib7ce5 , b/238686802 )
Изменения в API
- The
FragmentandFragmentManagerAPIs that take anIntentorIntentSenderare now properly annotated with@NonNullto prevent passing in a null value as a null value would always immediately crash the respective Android framework APIs these methods call into. ( I06fd4 )
Version 1.6.0-alpha04
7 декабря 2022 г.
Выпущена версия androidx.fragment:fragment-*:1.6.0-alpha04 . Версия 1.6.0-alpha04 содержит следующие коммиты.
Новые функции
-
FragmentStrictModeadded a newWrongNestedHierarchyViolationthat detects when a child fragment is nested within it's parent's View hierarchy, but not added to the parent'schildFragmentManager. ( I72521 , b/249299268 )
Изменения в поведении
- Теперь фрагменты восстанавливают свое состояние
SavedStateRegistryпередonAttach(), гарантируя его доступность из всех последующих методов жизненного цикла. ( I1e2b1 )
Изменения в API
- Артефакт
fragment-testing-manifestотделяет записи манифеста от остальных компонентов фрагментного тестирования. Это означает, что вы можете сделать следующее:
debugImplementation("androidx.fragment:fragment-testing-manifest:X.Y.Z")
androidTestImplementation("androidx.fragment:fragment-testing:X.Y.Z")
Это позволяет избежать конфликтов, возникающих из-за несоответствия версий между fragment-testing и androidx.test ( I8e534 , b/128612536 ).
Исправлены ошибки
- Начиная с версии Fragment
1.5.5: Фрагменты больше не будут некорректно сохранять состояниеViewModelкак часть сохраненного состояния реестра представлений. ( I10d2b , b/253546214 )
Version 1.6.0-alpha03
5 октября 2022 г.
androidx.fragment:fragment:1.6.0-alpha03 , androidx.fragment:fragment-ktx:1.6.0-alpha03 , and androidx.fragment:fragment-testing:1.6.0-alpha03 are released. Version 1.6.0-alpha03 contains these commits.
Изменения в API
- Теперь классам, наследующим
DialogFragmentпотребуется вызывать super в своих переопределенных методахonDismiss(). ( I14798 , b/238928865 )
Исправлены ошибки
- Fixed regressions caused by the integration of the new provider callback interfaces (
OnConfigurationChangedProvider,OnMultiWindowModeChangedProvider,OnTrimMemoryProvider,OnPictureInPictureModeChangedProvider) to ensure that fragments always get the proper callbacks. ( I9b380 , I34581 , ( I8dfe6 , b/242570955 ), If9d6b , Id0096 , I690b3 , I2cba2 )
Version 1.6.0-alpha02
24 августа 2022 г.
androidx.fragment:fragment:1.6.0-alpha02 , androidx.fragment:fragment-ktx:1.6.0-alpha02 , and androidx.fragment:fragment-testing:1.6.0-alpha02 are released. Version 1.6.0-alpha02 contains these commits.
Исправлены ошибки
- From Fragment
1.5.2: Fixed an issue where executing apopBackStack()and areplace()transaction at the same time could cause exiting fragments to run the wrongAnimation/Animator. ( Ib1c07 , b/214835303 )
Version 1.6.0-alpha01
27 июля 2022 г.
androidx.fragment:fragment:1.6.0-alpha01 , androidx.fragment:fragment-ktx:1.6.0-alpha01 , and androidx.fragment:fragment-testing:1.6.0-alpha01 are released. Version 1.6.0-alpha01 contains these commits.
Изменения в поведении
- The saved state of
Fragments has been split entirely between private library state (customParcelableclasses) and state provided by the developer, which is now always stored in aBundlethat allows determining exactly where a fragment's state is originating. ( b/207158202 )
Исправлены ошибки
- Начиная с фрагмента
1.5.1: Исправлена ошибка вDialogFragmentCallbacksDetector, из-за которой использование версии lint, входящей в состав AGP 7.4, приводило к сбою lint. ( b/237567009 )
Dependency update
- Начиная с версии Fragment
1.5.1: Библиотека Fragment теперь зависит от Lifecycle2.5.1. ( Id204c ) - Начиная с версии Fragment
1.5.1: Библиотека Fragment теперь зависит от Activity1.5.1. ( I10f07 )
Версия 1.5
Версия 1.5.7
19 апреля 2023 г.
Выпущены androidx.fragment:fragment:1.5.7 , androidx.fragment:fragment-ktx:1.5.7 и androidx.fragment:fragment-testing:1.5.7 . Версия 1.5.7 содержит эти коммиты.
Исправлены ошибки
- Использование
postponeEnterTransitionс таймаутом и последующей заменой отложенного фрагмента больше не приводит к утечке отложенного фрагмента. ( I2ec7d , b/276375110 )
Версия 1.5.6
22 марта 2023 г.
Выпущены androidx.fragment:fragment:1.5.6 , androidx.fragment:fragment-ktx:1.5.6 и androidx.fragment:fragment-testing:1.5.6 . Версия 1.5.6 содержит эти коммиты.
Исправлены ошибки
- Исправлена ошибка, из-за которой удаление любого фрагмента, независимо от того, добавлял ли он пункты меню или нет, приводило к неработоспособности меню активности. ( 50f098 , b/244336571 )
- Исправлена ошибка, из-за которой вызов
clearFragmentResultListenerвнутриsetFragmentResultListenerне работал, еслиLifecycleуже былSTARTEDи результат уже был доступен. ( If7458 )
Версия 1.5.5
7 декабря 2022 г.
Выпущены androidx.fragment:fragment:1.5.5 , androidx.fragment:fragment-ktx:1.5.5 и androidx.fragment:fragment-testing:1.5.5 . Версия 1.5.5 содержит эти коммиты.
Исправлены ошибки
- Фрагменты больше не будут некорректно сохранять состояние
ViewModelкак часть сохраненного состояния реестра представлений. ( I10d2b , b/253546214 )
Версия 1.5.4
24 октября 2022 г.
Выпущены androidx.fragment:fragment:1.5.4 , androidx.fragment:fragment-ktx:1.5.4 и androidx.fragment:fragment-testing:1.5.4 . Версия 1.5.4 содержит эти коммиты.
Исправлены ошибки
- Fixed an error where using a custom
FragmentControllerwith a host that does not implement a provider callback interface (OnConfigurationChangedProvider,OnMultiWindowModeChangedProvider,OnTrimMemoryProvider,OnPictureInPictureModeChangedProvider) and calling its deprecated dispatch function would fail to dispatch to child fragments. ( I9b380 )
Версия 1.5.3
21 сентября 2022 г.
Выпущены androidx.fragment:fragment:1.5.3 , androidx.fragment:fragment-ktx:1.5.3 и androidx.fragment:fragment-testing:1.5.3 . Версия 1.5.3 содержит эти коммиты.
Исправлены ошибки
- Fixed an error that caused fragments on the back stack to get
onMultiWindowModeChanged(),onPictureInPictureModeChanged(),onLowMemory(), andonConfigurationChanged()callbacks. ( I34581 , I8dfe6 , b/242570955 ) - Nested child fragments will no longer receive multiple
onMultiWindowModeChanged(),onPictureInPictureModeChanged(),onLowMemory(), oronConfigurationChanged()callbacks. ( I690b3 , Id0096 , If9d6b , I2cba2 )
Версия 1.5.2
10 августа 2022 г.
Выпущены androidx.fragment:fragment:1.5.2 , androidx.fragment:fragment-ktx:1.5.2 и androidx.fragment:fragment-testing:1.5.2 . Версия 1.5.2 содержит эти коммиты.
Исправлены ошибки
- Исправлена ошибка, из-за которой одновременное выполнение операций
popBackStack()иreplace()могло привести к запуску неправильнойAnimation/Animatorв выходящих фрагментах. ( Ib1c07 , b/214835303 )
Версия 1.5.1
27 июля 2022 г.
Выпущены androidx.fragment:fragment:1.5.1 , androidx.fragment:fragment-ktx:1.5.1 и androidx.fragment:fragment-testing:1.5.1 . Версия 1.5.1 содержит эти коммиты.
Исправлены ошибки
- Исправлена ошибка в
DialogFragmentCallbacksDetector, из-за которой использование версии lint, входящей в состав AGP 7.4, приводило к сбою lint. ( b/237567009 )
Dependency update
- Библиотека Fragment теперь зависит от Lifecycle
2.5.1( Id204c ). - Библиотека фрагментов теперь зависит от Activity
1.5.1( I10f07 ).
Версия 1.5.0
29 июня 2022 г.
Выпущены androidx.fragment:fragment:1.5.0 , androidx.fragment:fragment-ktx:1.5.0 и androidx.fragment:fragment-testing:1.5.0 . Версия 1.5.0 содержит эти коммиты.
Important changes since 1.4.0
- Интеграция с CreationExtras —
Fragmentтеперь может предоставлятьViewModelProvider.Factoryбез сохранения состояния черезCreationExtrasв Lifecycle2.5.0. - Интеграция компонентного диалога —
DialogFragmentтеперь используетComponentDialogиз Activity1.5.0в качестве диалога по умолчанию, возвращаемого функциейonCreateDialog(). - Saved Instance State Refactoring - Fragments have begun to change the way they save their instance state. This is an effort to help clearly identify what state has been saved in the fragment and the source of the state. The current changes include the following:
- Теперь
FragmentManagerсохраняет состояние своего экземпляра вBundle, а не напрямую в пользовательскийParcelable. - Результаты, заданные через
Fragment Result APIs, которые еще не были реализованы, теперь сохраняются отдельно от внутреннего состоянияFragmentManager. - The state associated with each individual fragment is now saved separately from the internal state of the
FragmentManager, thus allowing you to correlate the amount of saved state associated with an individual fragment with the unique IDs present in theFragmentdebug logging.
- Теперь
Другие изменения
- Теперь
FragmentStrictModeпозволяет частным фрагментам сторонних разработчиков обходить определенные санкции за нарушения, используяallowViolation()с указанием имени класса. - The Fragment APIs for providing a menu to your activity's
ActionBarhave been deprecated. TheMenuHostandMenuProviderAPIs added in Activity1.4.0provide a testable, lifecycle aware equivalent API surface that fragments should use.
Version 1.5.0-rc01
11 мая 2022 г.
Выпущены коммиты androidx.fragment:fragment:1.5.0-rc01 , androidx.fragment:fragment-ktx:1.5.0-rc01 и androidx.fragment:fragment-testing:1.5.0-rc01 . Версия 1.5.0-rc01 содержит следующие коммиты.
Saved Instance State Refactoring
- The state associated with each individual fragment is now saved separately from the internal state of the
FragmentManager, thus allowing you to correlate the amount of saved state associated with an individual fragment with the unique IDs present in the Fragment debug logging . ( a153e0 , b/207158202 )
Version 1.5.0-beta01
20 апреля 2022 г.
androidx.fragment:fragment:1.5.0-beta01 , androidx.fragment:fragment-ktx:1.5.0-beta01 , and androidx.fragment:fragment-testing:1.5.0-beta01 are released. Version 1.5.0-beta01 contains these commits.
Изменения в API
-
DialogFragmenthas added a newdismissNowmethod that usescommitNowfor parity with theshowNowfunction. Note that this will not make theDialogbe dismissed immediately, it will only synchronously update the state of theFragmentManager. ( I15c36 , b/72644830 )
Saved Instance State Refactoring
-
FragmentManagernow saves its saved instance state into aBundleinstead of directly in a customParcelable. This is the first step in providing additional transparency into what is actually being saved by Fragments. ( I93807 , b/207158202 ) - Results set via the Fragment Result APIs that have not yet been delivered are now saved separately from the internal state of the
FragmentManager. This will allow for additional transparency into what results are being saved as part of your saved instance state. ( I6ea12 , b/207158202 )
Version 1.5.0-alpha05
6 апреля 2022 г.
androidx.fragment:fragment:1.5.0-alpha05 , androidx.fragment:fragment-ktx:1.5.0-alpha05 , and androidx.fragment:fragment-testing:1.5.0-alpha05 are released. Version 1.5.0-alpha05 contains these commits.
Изменения в API
-
Fragment'ssetHasOptionsMenu()has been deprecated. To manage menus and their menu items, the new menu APIs should be used instead as per the Fragment1.5.0-alpha04release notes . ( I7b4b4 , b/226438239 )
Version 1.5.0-alpha04
23 марта 2022 г.
androidx.fragment:fragment:1.5.0-alpha04 , androidx.fragment:fragment-ktx:1.5.0-alpha04 , and androidx.fragment:fragment-testing:1.5.0-alpha04 are released. Version 1.5.0-alpha04 contains these commits.
Изменения в API
- The Fragment APIs for providing a menu to your activity's
ActionBarhave been deprecated as they tightly couple your fragment to your activity and are not testable in isolation. TheMenuHostandMenuProviderAPIs added in Activity1.4.0-alpha01provide a testable, lifecycle aware equivalent API surface that fragments should use. ( I50a59 , I20758 )
Исправлены ошибки
-
SavedStateViewFactorynow supports usingCreationExtraseven when it was initialized with aSavedStateRegistryOwner. If extras are provided, the initialized arguments are ignored. ( I6c43b , b/224844583 )
Version 1.5.0-alpha03
23 февраля 2022 г.
androidx.fragment:fragment:1.5.0-alpha03 , androidx.fragment:fragment-ktx:1.5.0-alpha03 , and androidx.fragment:fragment-testing:1.5.0-alpha03 are released. Version 1.5.0-alpha03 contains these commits.
Изменения в API
- You can now pass
CreationExtrasto theby viewModels()andby activityViewModels()functions. ( Ibefe7 , b/217601110 )
Изменения в поведении
-
DialogFragmentnow usesComponentDialogas the default dialog returned byonCreateDialog(). ( If3784 , b/217618170 )
Version 1.5.0-alpha02
9 февраля 2022 г.
androidx.fragment:fragment:1.5.0-alpha02 , androidx.fragment:fragment-ktx:1.5.0-alpha02 , and androidx.fragment:fragment-testing:1.5.0-alpha02 are released. Version 1.5.0-alpha02 contains these commits.
Новые функции
-
FragmentStrictModenow offers the ability for private third-party fragments to bypass specific violation penalties by usingallowViolation()with the class name. ( I8f678 )
Version 1.5.0-alpha01
26 января 2022 г.
androidx.fragment:fragment:1.5.0-alpha01 , androidx.fragment:fragment-ktx:1.5.0-alpha01 , and androidx.fragment:fragment-testing:1.5.0-alpha01 are released. Version 1.5.0-alpha01 contains these commits.
Новые функции
-
Fragmentnow integrates with ViewModel CreationExtras, introduced as part of Lifecycle2.5.0-alpha01. ( I3060b , b/207012585 )
Исправлены ошибки
- From Fragment
1.4.1:FragmentContainerViewno longer throws an illegal state exception when view IDs generated from xml have negative values. ( Ic185b , b/213086140 ) - From Fragment
1.4.1: When using a customownerProducerlambda with theby viewModels()lazy function, it will now use thedefaultViewModelProviderFactoryfrom that owner if a customViewModelProvider.Factoryis not provided instead of always using the fragment's factory. ( I56170 , b/214106513 ) - Fixed a crash when accessing a
ViewModelfor the very first time from aregisterForActivityResult()callback of aFragment. ( Iea2b3 )
Версия 1.4
Версия 1.4.1
26 января 2022 г.
androidx.fragment:fragment:1.4.1 , androidx.fragment:fragment-ktx:1.4.1 , and androidx.fragment:fragment-testing:1.4.1 are released. Version 1.4.1 contains these commits.
Исправлены ошибки
-
FragmentContainerViewno longer throws an illegal state exception when view IDs generated from xml have negative values. ( Ic185b , b/213086140 ) - When using a custom
ownerProducerlambda with theby viewModels()lazy function, it will now use thedefaultViewModelProviderFactoryfrom that owner if a customViewModelProvider.Factoryis not provided instead of always using the fragment's factory. ( I56170 , b/214106513 )
Версия 1.4.0
17 ноября 2021 г.
androidx.fragment:fragment:1.4.0 , androidx.fragment:fragment-ktx:1.4.0 , and androidx.fragment:fragment-testing:1.4.0 are released. Version 1.4.0 contains these commits.
Important changes since 1.3.0
- The
FragmentStrictModeAPIs provide runtime checks that allow you to verify that your app or libraries you depend on are not calling deprecated fragment APIs. When a violation is detected, you can choose to print a log message, trigger your own custom listener, or crash your app. TheFragmentStrictMode.Policythat controls what checks are enabled and what “penalties” are triggered can be set on aFragmentManagervia the newsetStrictModePolicy()method. That policy applies to thatFragmentManagerand transitively to any child fragment managers that do not set their own unique policy. See StrictMode for fragments . FragmentContainerViewnow provides agetFragment()method which returns the fragment that was most recently added to the container. This uses the same logic asfindFragmentById()with the ID of theFragmentContainerView, but allows chaining the call.val navController = binding.container.getFragment<NavHostFragment>().navControllerFragmentScenarionow implementsCloseable, allowing you to use it with Kotlin'susemethod or try-with-resources .Added
FragmentTransaction#TRANSIT_FRAGMENT_MATCH_ACTIVITY_{OPEN, CLOSE}to specify whether to enable the standard Activity-transition animation taken from your theme in Fragments transition.The experimental API of
FragmentManager.enableNewStateManager(boolean)has been removed and the new state manager is now the only option available.
Multiple back stacks
The FragmentManager maintains a back stack made up of fragment transactions that used addToBackStack() . This allows you to pop those transactions and return to the previous state, using the mechanisms for Saving state with fragments to allow your fragments to restore their state appropriately.
This release expands on these mechanisms by providing three new FragmentManager APIs: saveBackStack(String name) , restoreBackStack(String name) , and clearBackStack(String name) . These APIs use the same name as addToBackStack() to save the state of the FragmentTransaction and the state of every fragment that was added in those transactions and allow you to later restore those transactions and their fragments with their state in tact. This allows you to effectively 'swap' between multiple back stacks by saving the current back stack and restoring a saved back stack.
saveBackStack() operates similarly to popBackStack() in that it is asynchronous and results in all the fragment transactions back to that specific name to be reversed ('popped') and any added fragments to be destroyed and removed, but it differs in a few important ways:
-
saveBackStack()is always inclusive. - Unlike
popBackStack()which will pop all transactions on the back stack if the specified name is not found on the back stack or if a null name is provided,saveBackStack()does nothing if you haven't previously committed a fragment transaction usingaddToBackStack()with that exact, non-null name. - The state of all fragments added from those transactions is saved. This means that the View state of every fragment is stored,
onSaveInstanceState()of every fragment is called and that state is restored, and anyViewModelinstances associated with those fragments are retained (andonCleared()is not called on them).
The fragment transactions that can be used with saveBackStack() must meet certain criteria:
- Every fragment transaction must use
setReorderingAllowed(true)to ensure the transactions can be restored as a single, atomic operation. - The set of transactions saved must be self-contained (ie, they must not explicitly reference any fragments outside of that set of transactions) to ensure that they can be restored at any later time, no matter what changes have been made to the back stack in the intervening time.
- No fragment that is saved can be a retained fragment or have a retained fragment in their transitive set of child fragments to ensure that the
FragmentManagerdoes not return any references to saved fragments after the back stack is saved.
Similar to saveBackStack() , restoreBackStack() and clearBackStack() , which would restore a previously saved back stack or clear a previously saved back stack, respectively, both do nothing if you have not previously called saveBackStack() with the same name.
For more information, see Multiple back stacks: A deep dive .
Версия 1.4.0-rc01
3 ноября 2021 г.
androidx.fragment:fragment:1.4.0-rc01 released with no changes from Fragment 1.4.0-beta01. Version 1.4.0-rc01 contains these commits.
Версия 1.4.0-beta01
27 октября 2021 г.
androidx.fragment:fragment:1.4.0-beta01 , androidx.fragment:fragment-ktx:1.4.0-beta01 , and androidx.fragment:fragment-testing:1.4.0-beta01 are released. Version 1.4.0-beta01 contains these commits.
Исправлены ошибки
- Parent fragments will now dispatch
onHiddenChanged()down their entire hierarchy before launching their own callback. ( Iedc20 , b/77504618 ) - The keyboard will now close automatically when going from a fragment with an open keyboard to a fragment with a recycler view. ( I8b842 , b/196852211 )
-
DialogFragmentnow usessetReorderingAllowed(true)for all transactions it creates when you callshow(),showNow(), ordismiss(). ( Ie2c14 ) - The extremely long Lint warning of
DetachAndAttachFragmentInSameFragmentTransactionhas been shortened toDetachAndAttachSameFragment. ( e9eca3 )
Version 1.4.0-alpha10
29 сентября 2021 г.
androidx.fragment:fragment:1.4.0-alpha10 , androidx.fragment:fragment-ktx:1.4.0-alpha10 , and androidx.fragment:fragment-testing:1.4.0-alpha10 are released. Version 1.4.0-alpha10 contains these commits.
Ворс
- Added the
DetachAndAttachFragmentInSameFragmentTransactionlint warning for detecting calling bothdetach()andattach()on the sameFragmentin the sameFragmentTransaction- as these complementary operations cancel each other out when done in the same transaction, they must be split into separate transactions to actually do anything. ( aosp/1832956 , b/200867930 ) - Added the
FragmentAddMenuProviderlint error for correcting usages of the Fragment Lifecycle to the Fragment view Lifecycle when using theaddMenuProviderAPI ofMenuHost. ( aosp/1830457 , b/200326272 )
Documentation Updates
- The deprecation message for APIs now handled by the Activity Result APIs , namely
startActivityForResult,startIntentSenderForResult,onActivityResult,requestPermissions, andonRequestPermissionsResult, have all been expanded with more details. ( cce80f ) - The deprecation message for
onActivityCreated()for bothFragmentandDialogFragmenthas all been expanded with more details. ( 224db4 )
Version 1.4.0-alpha09
15 сентября 2021 г.
androidx.fragment:fragment:1.4.0-alpha09 , androidx.fragment:fragment-ktx:1.4.0-alpha09 , and androidx.fragment:fragment-testing:1.4.0-alpha09 are released. Version 1.4.0-alpha09 contains these commits.
Новые функции
- You can now call
clearBackStack(name)to clear any state previously saved withsaveBackStack(name). ( I70cd7 )
Изменения в API
- The
FragmentContainerViewclass has been rewritten in Kotlin ensuring that thegetFragmentfunction will properly respect nullability. ( If694a , b/189629145 ) - FragmentStrictMode is now written in Kotlin ( I11767 , b/199183506 )
Исправлены ошибки
- Fixed an issue where the state of a Fragment that was added with
setReorderingAllowed(true)and then immediately removed before executing pending transactions would not be properly cleaned up. ( I8ccb8 )
Version 1.4.0-alpha08
1 сентября 2021 г.
androidx.fragment:fragment:1.4.0-alpha08 , androidx.fragment:fragment-ktx:1.4.0-alpha08 , and androidx.fragment:fragment-testing:1.4.0-alpha08 are released. Version 1.4.0-alpha08 contains these commits.
Исправлены ошибки
- Improved the
UseRequireInsteadOfGetLint check to better handle redundant parenthesis. ( I2d865 ) - Improved the
UseGetLayoutInflaterLint check to handle additional edge cases. ( Ie5423 )
Version 1.4.0-alpha07
18 августа 2021 г.
androidx.fragment:fragment:1.4.0-alpha07 , androidx.fragment:fragment-ktx:1.4.0-alpha07 , and androidx.fragment:fragment-testing:1.4.0-alpha07 are released with no notable changes. Version 1.4.0-alpha07 contains these commits.
Version 1.4.0-alpha06
August 4, 2021
androidx.fragment:fragment:1.4.0-alpha06 , androidx.fragment:fragment-ktx:1.4.0-alpha06 , and androidx.fragment:fragment-testing:1.4.0-alpha06 are released. Version 1.4.0-alpha06 contains these commits.
Исправлены ошибки
- Fixed an issue with multiple back stacks when rapidly swapping between back stacks that would appear as an
IllegalStateExceptionwhile restoring aFragmentTransactionor as a second copy of a fragment appearing. ( I9039f ) - Fixed an issue where
FragmentManagerwould hold onto a copy of state previously saved viasaveBackStack()even after that state was restored. ( Ied212 ) - The
dismissAllowingStateLoss()method ofDialogFragmentno longer crashes when you call it after the state is saved when specifically adding the DialogFragment via theshow(FragmentTransaction, String)method. ( I84422 )
Version 1.4.0-alpha05
21 июля 2021 г.
androidx.fragment:fragment:1.4.0-alpha05 , androidx.fragment:fragment-ktx:1.4.0-alpha05 , and androidx.fragment:fragment-testing:1.4.0-alpha05 are released. Version 1.4.0-alpha05 contains these commits.
Исправлены ошибки
- From Fragment
1.3.6: The Fragment's view is now properly set toGONEwhen usinghide()when the root view hastransitionGroup=”true”set. ( aosp/1766655 , b/193603427 ) - From Fragment
1.3.6:FragmentActivitynow always unlocks the saved state as its first operation in lifecycle callbacks it overrides. ( I6db7a )
Dependency update
- From Fragment
1.3.6: Fragments now depends on Activity1.2.4( I3a66c )
Version 1.4.0-alpha04
30 июня 2021 г.
androidx.fragment:fragment:1.4.0-alpha04 , androidx.fragment:fragment-ktx:1.4.0-alpha04 , and androidx.fragment:fragment-testing:1.4.0-alpha04 are released. Version 1.4.0-alpha04 contains these commits.
Изменения в API
-
FragmentManagernow usesSavedStateRegistryunder the hood to save its state. ThesaveAllState()andrestoreSavedState()methods have also been deprecated inFragmentController. If you are usingFragmentControllerto host fragments outside ofFragmentActivity, you should have yourFragmentHostCallbacksimplementSavedStateRegistryOwner. ( Iba68e , b/188734238 )
Исправлены ошибки
- Fixed an issue where the call to
saveBackStack()as part of supporting multiple back stacks would fail when done at the same time as running aFragmentTransactionthat usedreplace(). ( I73137 ) - Fixed a
NullPointerExceptionthat would occur after manually restoring a saved back stack that contained multiple transactions when using therestoreBackStack()API for multiple back stack support. This also fixed an issue wheresetReorderingAllowed(true)was not being checked for all transactions. ( I8c593 ) - Fixed an issue where
FragmentManagerwould incorrectly continue to restore previously saved state of fragments even after those fragments were removed from theFragmentManager, thus causing the saved state to continuously grow over time. ( I1fb8e )
Version 1.4.0-alpha03
16 июня 2021 г.
androidx.fragment:fragment:1.4.0-alpha03 , androidx.fragment:fragment-ktx:1.4.0-alpha03 , and androidx.fragment:fragment-testing:1.4.0-alpha03 are released. Version 1.4.0-alpha03 contains these commits.
Новые функции
- All Fragment StrictMode
Violationclasses have been updated with more detailed error messages that explain the details of the violation. ( b/187871638 )-
FragmentTagUsageViolationnow contains more detailed error message that container the parent container that the fragment would have been added to. ( Ic33a7 ) -
WrongFragmentContainerViolationnow has more detailed error message that includes the container that the fragment was being added to. ( Ib55f8 ) - The use case classes for
TargetFragmentUsageViolationnow have more detailed error messages to include the fragment causing the violation and any other contained information. ( Icc6ac ) - The classes extending
RetainInstanceUsageViolationnow have more detailed error messages that include the fragment causing the violation. ( I6bd55 ) -
FragmentReuseViolationnow has more detailed error message that includes the previous id of the fragment. ( I28ce2 ) -
SetUserVisibleHintViolationnow has more detailed error message that includes what the user visible hint was being set to. ( Ib2d5f )
-
Изменения в поведении
- Reverted the restriction on calling
fitsSystemWindowson aFragmentContainerView- this no longer crashes your app. ( 6b8ddd , b/190622202 )
Исправлены ошибки
- From Fragment
1.3.5: Fixed a regression in shared element transitions introduced in Fragment1.3.4by aosp/1679887 . Fragments now correctly handle transition groups (either set directly viatransitionGroup="true"or indirectly via atransitionNameorbackground) and shared elements will no longer throwIndexOutOfBoundsExceptions. ( I16484 , b/188679569 , b/188969304 ) - The
FragmentManagerwill no longer crash when you attempt to hide a removing fragment. ( I573dd , b/183634730 ) - The
OnCreateDialogIncorrectCallbacklint check will no longer crash when evaluating a top level variable. ( 0a9efa , b/189967522 )
Версия 1.4.0-alpha02
2 июня 2021 г.
androidx.fragment:fragment:1.4.0-alpha02 , androidx.fragment:fragment-ktx:1.4.0-alpha02 , and androidx.fragment:fragment-testing:1.4.0-alpha02 are released. Version 1.4.0-alpha02 contains these commits.
Новые функции
-
FragmentStrictModewill now always log violations when logging is enabled via theFragmentManager, regardless of the current strict mode policy being used. ( I02df6 , b/187872638 ) FragmentStrictModenow supports exempting particularFragmentclasses from strict modeViolations allowing that class to bypass any penalties. ( Ib4e5d , b/184786736 )The
FragmentStrictModeViolationclass has been expanded to add structure information based on each violation. This allows you to verify exactly what caused the violation along with the violating fragment ( If5118 , b/187871150 ), eachViolationcontains the following:-
WrongFragmentContainerViolationnow contains theViewGroupthat theFragmentwas attempting to be added to. ( I83c75 , b/187871150 ) -
TargetFragmentUsageViolationhas been expanded into,SetTargetFragmentUsageViolation,GetTargetFragmentUsageViolation, andGetTargetFragmentRequestCodeUsageViolation, withSetTargetFragmentUsageViolationcontaining the target fragment and request code. ( I741b4 , b/187871150 ) -
SetUserVisibleHintViolationnow contains the boolean value passed intosetUserVisibleHint(). ( I00585 , b/187871150 ) -
FragmentTagUsageViolationnow contains the ViewGroup that the<fragment>tag was attempting to inflate a fragment into.( I5dbbc , b/187871150 ) -
FragmentReuseViolationnow contains the unique ID of the previous instance of theFragmentthat caused the viotion. ( I0544d , b/187871150 ) -
RetainInstanceUsageViolationis now abstract and has two subclasses,SetRetainInstanceUsageViolationandGetRetainInstanceUsageViolation, representing the two cases for the violation type. ( Ic81e5 , b/187871150 )
-
Изменения в поведении
-
FragmentContainerViewnow throws an exception when attempting to change thefitsSystemWindowattribute programmatically or via XML. Insets should be handled by each individual fragment's view. ( Ie6651 , b/187304502 )
Версия 1.4.0-alpha01
18 мая 2021 г.
androidx.fragment:fragment:1.4.0-alpha01 , androidx.fragment:fragment-ktx:1.4.0-alpha01 , and androidx.fragment:fragment-testing:1.4.0-alpha01 are released. Version 1.4.0-alpha01 contains these commits.
Новые функции
FragmentContainerViewnow provides agetFragment()method which returns the fragment that was most recently added to the container. This uses the same logic asfindFragmentById()with the ID of theFragmentContainerView, but allows chaining the call. ( Ife17a , b/162527857 )val navController = binding.container.getFragment<NavHostFragment>().navControllerAdded
FragmentTransaction#TRANSIT_FRAGMENT_MATCH_ACTIVITY_{OPEN, CLOSE}to specify whether to enable the standard Activity-transition animation taken from your theme in Fragments transition. ( I46652 )
Multiple back stacks
The FragmentManager maintains a back stack made up of fragment transactions that used addToBackStack() . This allows you to pop those transactions and return to the previous state, using the mechanisms for Saving state with fragments to allow your fragments to restore their state appropriately.
This release expands on these mechanisms by providing two new FragmentManager APIs: saveBackStack(String name) and restoreBackStack(String name) . These APIs use the same name as addToBackStack() to save the state of the FragmentTransaction and the state of every fragment that was added in those transactions and allow you to later restore those transactions and their fragments with their state in tact. This allows you to effectively 'swap' between multiple back stacks by saving the current back stack and restoring a saved back stack.
saveBackStack() operates similarly to popBackStack() in that it is asynchronous and results in all the fragment transactions back to that specific name to be reversed ('popped') and any added fragments to be destroyed and removed, but it differs in a few important ways:
-
saveBackStack()is always inclusive. - Unlike
popBackStack()which will pop all transactions on the back stack if the specified name is not found on the back stack or if a null name is provided,saveBackStack()does nothing if you haven't previously committed a fragment transaction usingaddToBackStack()with that exact, non-null name. - The state of all fragments added from those transactions is saved. This means that the View state of every fragment is stored,
onSaveInstanceState()of every fragment is called and that state is restored, and anyViewModelinstances associated with those fragments are retained (andonCleared()is not called on them).
The fragment transactions that can be used with saveBackStack() must meet certain criteria:
- Every fragment transaction must use
setReorderingAllowed(true)to ensure the transactions can be restored as a single, atomic operation. - The set of transactions saved must be self-contained (ie, they must not explicitly reference any fragments outside of that set of transactions) to ensure that they can be restored at any later time, no matter what changes have been made to the back stack in the intervening time.
- No fragment that is saved can be a retained fragment or have a retained fragment in their transitive set of child fragments to ensure that the
FragmentManagerdoes not return any references to saved fragments after the back stack is saved.
Similar to saveBackStack() , restoreBackStack() does nothing if you have not previously called saveBackStack() with the same name. ( b/80029773 )
Fragment StrictMode
The FragmentStrictMode APIs provide runtime checks that allow you to verify that your app or libraries you depend on are not calling deprecated fragment APIs. When a violation is detected, you can choose to print a log message, trigger your own custom listener, or crash your app. The FragmentStrictMode.Policy that controls what checks are enabled and what “penalties” are triggered can be set on a FragmentManager via the new setStrictModePolicy() method. That policy applies to that FragmentManager and transitively to any child fragment managers that do not set their own unique policy. ( #123 , #131 , #150 , b/143774122 )
-
detectFragmentReuse()detects whether a previously removedFragmentinstance is being re-added to aFragmentManager. You should never interact with or keep a reference to aFragmentinstance after it has been destroyed and removed from aFragmentManager. ( #142 , b/153738653 ) -
detectFragmentTagUsage()detects when you are using the<fragment>tag in your layout XML. You should always useFragmentContainerViewwhen inflating fragments as part of your layout. ( #141 , b/153738235 ) -
detectWrongFragmentContainer()detects when you add a fragment to a container that is not aFragmentContainerView. You should always useFragmentContainerViewas the container for fragments in your layout. ( #146 , b/181137036 ) -
detectRetainInstanceUsage()detects when you use the deprecatedsetRetainInstance()orgetRetainInstance()APIs. ( #140 , b/153737954 ) -
detectSetUserVisibleHint()detects when you use the deprecatedsetUserVisibleHint()API. ( #136 , b/153738974 ) -
detectTargetFragmentUsage()detects when you use the deprecatedsetTargetFragment(),getTargetFragment()orgetTargetRequestCode()APIs. ( #139 , b/153737745 )
Изменения в API
- The experimental API of
FragmentManager.enableNewStateManager(boolean)has been removed and the new state manager is now the only option available. ( I90036 , b/162776418 ) -
FragmentScenarionow implementsCloseable, allowing you to use it with Kotlin'susemethod or try-with-resources . ( #121 , b/143774122 )
New Lint checks
- The
UseGetLayoutInflaterLint check now warns when usingLayoutInflater.from(Context)within aDialogFragment- you should always use the dialog fragment'sgetLayoutInflater()method to get the appropriate forLayoutInflater. ( #156 , b/170781346 ) - The
DialogFragmentCallbacksDetectorLint check now warns when callingsetOnCancelListenerorsetOnDismissListenerin theonCreateDialog()method of aDialogFragment- these listeners are owned by theDialogFragmentitself and you should overrideonCancel()andonDismiss()to receive these callbacks. ( #171 , b/181780047 , b/187524311 )
Исправлены ошибки
- From Fragment 1.3.4 : Fixed a regression introduced in Fragment
1.3.3when using theViewTreeViewModelStoreOwner.get()API withViewModelProvideror the Jetpack Compose method ofviewModel()inside a Fragment. These use cases now correctly use theViewModelProvider.Factoryprovided by your Fragment if it overridesgetDefaultViewModelProviderFactory()(as@AndroidEntryPointannotated Fragments do when using Hilt). If you do not override that method, aSavedStateViewModelFactorythat saves and restores its state alongside the Fragment's view is created as the default factory. ( I5cbfa , b/186097368 ) - From Fragment 1.3.4 : When using
FragmentContainerViewon API 29, insets will no longer dispatch indefinitely, fixing issues withBottomNavigationBarandFloatingActionButtoninstances. ( I1bb78 , b/186012452 ) - From Fragment 1.3.4 : You can now retrieve your Parcelable from the fragment result bundle after process death. ( I65932 , b/187443158 )
- From Fragment 1.3.4 : When doing a shared element transition on a ViewGroup, if the ViewGroup has
transitionGroupset to false, it will now properly transition. ( I99675 )
Внешний вклад
- Thanks simonschiller for making
FragmentScenarioimplementCloseable. ( #121 , b/143774122 ) - Thanks simonschiller for adding the entirety of the
FragmentStrictModeAPI for this release! ( #123 , #131 , #150 , b/143774122 , #142 , b/153738653 , #141 , b/153738235 , #146 , b/181137036 , #140 , b/153737954 , #136 , b/153738974 , #139 , b/153737745 ) - Thanks tatocaster for adding the
UseGetLayoutInflaterLint check. ( #156 , b/170781346 ) - Thanks tatocaster for adding the
DialogFragmentCallbacksDetectorLint check. ( #171 , b/181780047 )
Версия 1.3
Version 1.3.6
21 июля 2021 г.
androidx.fragment:fragment:1.3.6 , androidx.fragment:fragment-ktx:1.3.6 , and androidx.fragment:fragment-testing:1.3.6 are released. Version 1.3.6 contains these commits.
Исправлены ошибки
- From Fragment
1.4.0-alpha03: TheFragmentManagerwill no longer crash when you attempt to hide a removing fragment. ( I573dd , b/183634730 ) - The Fragment's view is now properly set to
GONEwhen usinghide()when the root view hastransitionGroup=”true”set. ( aosp/1766655 , b/193603427 ) -
FragmentActivitynow always unlocks the saved state as its first operation in lifecycle callbacks it overrides. ( I6db7a )
Dependency update
- From Fragment
1.3.6: Fragments now depends on Activity1.2.4( I3a66c )
Версия 1.3.5
16 июня 2021 г.
androidx.fragment:fragment:1.3.5 , androidx.fragment:fragment-ktx:1.3.5 , and androidx.fragment:fragment-testing:1.3.5 are released. Version 1.3.5 contains these commits.
Исправлены ошибки
- Fixed a regression in shared element transitions introduced in Fragment
1.3.4by aosp/1679887 . Fragments now correctly handle transition groups (either set directly viatransitionGroup="true"or indirectly via atransitionNameorbackground) and shared elements will no longer throwIndexOutOfBoundsExceptions. ( I16484 , b/188679569 , b/188969304 )
Version 1.3.4
18 мая 2021 г.
androidx.fragment:fragment:1.3.4 , androidx.fragment:fragment-ktx:1.3.4 , and androidx.fragment:fragment-testing:1.3.4 are released. Version 1.3.4 contains these commits.
Исправлены ошибки
- Fixed a regression introduced in Fragment
1.3.3when using theViewTreeViewModelStoreOwner.get()API withViewModelProvideror the Jetpack Compose method ofviewModel()inside a Fragment when using Hilt. These use cases now correctly use theViewModelProvider.Factoryprovided by your Fragment if it overridesgetDefaultViewModelProviderFactory()(as@AndroidEntryPointannotated Fragments do). If you do not override that method, aSavedStateViewModelFactorythat saves and restores its state alongside the Fragment's view is created as the default factory. ( I5cbfa , b/186097368 ) - When using
FragmentContainerViewon API 29, insets will no longer dispatch indefinitely, fixing issues withBottomNavigationBarandFloatingActionButtoninstances. ( I1bb78 , b/186012452 ) - You can now retrieve your Parcelable from the fragment result bundle after process death. ( I65932 , b/187443158 )
- When doing a shared element transition on a ViewGroup, if the ViewGroup has
transitionGroupset to false, it will now properly transition. ( I99675 )
Версия 1.3.3
21 апреля 2021 г.
androidx.fragment:fragment:1.3.3 , androidx.fragment:fragment-ktx:1.3.3 , and androidx.fragment:fragment-testing:1.3.3 are released. Version 1.3.3 contains these commits.
Новые функции
- Using
SavedStateViewModelFactorynow works when used with theSavedStateRegistryOwnerreturned by usingViewTreeSavedStateRegistryOwner.get()with the Fragment's View. ( I21acf , b/181577191 )
Исправлены ошибки
- Fixed a regression introduced in Fragment
1.3.2which would causepopEnteranimations to not run when popping aFragmentTransactionthat included asetPrimaryNavFragmentoperation, such as those used byNavHostFragment. ( I38c87 , b/183877426 ) -
FragmentContainerViewnow ensures that everyFragmentis dispatched a new set ofWindowInsets, ensuring that each fragment can now independently consume the insets. ( I63f68 , b/172153900 ) -
DialogFragmentnow properly handles cases where a child fragment is added to a container that has the same ID as a container in your customDialogclass, fixing view hierarchy issues when reusing IDs that are used internally by dialogs such asBottomSheetDialog. ( Ie6279 , b/180021387 ) -
FragmentManager.dump()now properly indents the first fragment in the list of active fragments. ( If5c33 , b/183705451 )
New State Manager Bug Fixes
- The new fragment state manager now properly handles exit transitions with hide operations. ( I9e4de , b/184830265 )
Версия 1.3.2
24 марта 2021 г.
androidx.fragment:fragment:1.3.2 , androidx.fragment:fragment-ktx:1.3.2 , and androidx.fragment:fragment-testing:1.3.2 are released. Version 1.3.2 contains these commits.
New State Manager Bug Fixes
- When running both
popBackStack()andcommit()operations together, the last operation will now set the direction for all animations rather than running some pop animations and some enter animations. ( I7072e , b/181142246 ) - Views within in a shared element hierarchy will no longer have their transition name cleared when doing a shared element transition. ( I4d4a6 , b/179934757 )
Обновления зависимостей
- Fragment now depends on Activity 1.2.2 , fixing an issue with Activity's
InvalidFragmentVersionForActivityResultlint check when using Fragment 1.3.1 or higher. - Fragment now depends on Lifecycle 2.3.1 .
Версия 1.3.1
10 марта 2021 г.
androidx.fragment:fragment:1.3.1 , androidx.fragment:fragment-ktx:1.3.1 , and androidx.fragment:fragment-testing:1.3.1 are released. Version 1.3.1 contains these commits.
Новые функции
- Dialogs within a
DialogFragmentcan now get access to ViewTree owners through their DecorView, ensuring thatDialogFragmentcan be used withComposeView. ( Ib9290 , b/180691023 )
Исправлены ошибки
- Fragments inflated into an already
RESUMEDactivity using FragmentContainerView are now properly shown after a configuration change. ( Ie14c8 , b/180538371 ) - There is no longer an extra
}at the end of the fragmenttoString()( I54705 , b/177761088 ) - Overridden methods in FragmentActivity now properly inherit the base method javaDoc ( I736ce , b/139548782 )
- The docs for
setFragmentResultandsetFragmentResultListenerhave updated their parameters docs to reflect that they no longer accept nullables ( I990ba , b/178348386 )
New State Manager Bug Fixes
- Fixed a memory leak in fragments caused by
mFocusedView( Ib4e9e , b/179925887 ) - Fragments now properly call
onCreateOptionsMenuwhen using show/hide transactions ( I8bce8 , b/180255554 ) - Child fragments with transitions that start prior to the fragment being laid out will now properly reach
RESUMED( Ic11e6 , b/180825150 ) - Fragments inflated using the
<fragment>tag will now always make it toRESUMED( I452ac , ( I9fa49 )
Обновления зависимостей
- Fragment 1.3.1 depends on Activity
1.2.1. ( I557b9 )
Версия 1.3.0
10 февраля 2021 г.
androidx.fragment:fragment:1.3.0 , androidx.fragment:fragment-ktx:1.3.0 , and androidx.fragment:fragment-testing:1.3.0 are released. Version 1.3.0 contains these commits.
Major changes since 1.2.0
- New State Manager : A significant rewrite of the internals of
FragmentManagerhas fixed numerous issues around the dispatch of lifecycle events, animations and transitions, and how postponed fragments are handled. Activity Result API Integration : Added support for the
ActivityResultRegistryAPI introduced in Activity1.2.0to handlestartActivityForResult()+onActivityResult()as well asrequestPermissions()+onRequestPermissionsResult()flows without overriding methods in your Fragment in addition to providing hooks for testing these flows. See the updated Getting a Result from an Activity .- This release fixes a number of issues around invalid request codes and the dispatch of permission requests that prevent the Activity Result API from working on previous versions of
FragmentActivity. You must upgrade to Fragment 1.3.0 to use the Activity Result APIs in aFragmentActivityorAppCompatActivity.
- This release fixes a number of issues around invalid request codes and the dispatch of permission requests that prevent the Activity Result API from working on previous versions of
Fragment Result API : Added support for passing results between two Fragments via new APIs on
FragmentManager. This works for hierarchy fragments (parent/child), DialogFragments, and fragments in Navigation and ensures that results are only sent to your Fragment while it is at leastSTARTED. The target fragment APIs have been deprecated in favor of these new APIs. See Get Results using the Fragment Result API .FragmentOnAttachListener: TheonAttachFragment()callback onFragmentActivityandFragmenthave been deprecated. A newFragmentOnAttachListenerhas been added to provide a more flexible alternative, allowing delegation ofonAttachFragment()to separate, testable listeners and support for adding a listener to FragmentManagers other than your direct child FragmentManager.FragmentScenarioImprovements : TheFragmentScenarioclass from thefragment-testingartifact has been rewritten in Kotlin and has received a number of improvements:-
FragmentScenarionow usessetMaxLifecycle()to implementmoveToState(), ensuring consistent behavior on all API levels and decoupling the Fragment's state from the underlying Activity. -
FragmentScenarionow supports setting an initialLifecycle.Stateto support asserting the fragment's state before moving to eachLifecycle.Statefor the first time. - There is now an alternative to the
FragmentScenarioAPI ofonFragmentin the form of the Kotlin reified extension methodwithFragmentthat allows you to return a value. Notably, it rethrows exceptions raised in the given block.
-
ViewTreeSupport :Fragmentnow supports theViewTreeLifecycleOwner.get(View),ViewTreeViewModelStoreOwner.get(View), andViewTreeSavedStateRegistryOwnerAPIs added in Lifecycle2.3.0and SavedState1.1.0such that it will return the Fragment as theViewModelStoreOwner, and aSavedStateRegistryOwnerandLifecycleOwnertied to the fragment's view Lifecycle when using aViewwithin aFragment.TRANSIT_animation changes : The fragment default effects,TRANSIT_FRAGMENT_OPEN,TRANSIT_FRAGMENT_CLOSE, andTRANSIT_FRAGMENT_FADE, now useAnimatorinstead ofAnimation. The resources used to build these animators are now private.setRetainInstance()deprecation : ThesetRetainInstance()method on Fragments has been deprecated. With the introduction of ViewModels , developers have a specific API for retaining state that can be associated with Activities, Fragments, and Navigation graphs. This allows developers to use a normal, not retained Fragment and keep the specific state they want retained separate, avoiding a common source of leaks while maintaining the useful properties of a single creation and destruction of the retained state (namely, the constructor of theViewModeland theonCleared()callback it receives).ViewPager 1 adapter deprecation : With the release of ViewPager2
1.0.0, theFragmentPagerAdapterandFragmentStatePagerAdapterclasses for interacting withViewPagerhave been deprecated. See Migrate from ViewPager to ViewPager2 .
Version 1.3.0-rc02
27 января 2021 г.
androidx.fragment:fragment:1.3.0-rc02 , androidx.fragment:fragment-ktx:1.3.0-rc02 , and androidx.fragment:fragment-testing:1.3.0-rc02 are released. Version 1.3.0-rc02 contains these commits.
Исправлены ошибки
- Fixed an issue where a parent
DialogFragmentwould appear above a childDialogFragmentafter a configuration change; child dialog fragments now always appear above a parent dialog fragment. ( I30806 , b/177439520 ) - Fixed issue where doing a
hideoperation with anAnimationwould cause the hiding fragment to flash at the end of the animation. ( I57e22 , b/175417675 ) - Fragments with transitions added before the view hierarchy is attached now properly reach
RESUMED. ( I1fc1d , b/177154873 )
New State Manager Bug Fixes
- The Fragment's view
Lifecyclenow properly handles cases where the Fragment's view is destroyed before theLifecyclereachesCREATED, avoiding exceptions stating “no event down from INITIALIZED”. ( eda2bd , b/176138645 ) - Fragments that use an
Animatornow appear in the proper order when usingFragmentContainerView. ( Id9aa3 , b/176089197 )
Версия 1.3.0-rc01
16 декабря 2020 г.
androidx.fragment:fragment:1.3.0-rc01 , androidx.fragment:fragment-ktx:1.3.0-rc01 , and androidx.fragment:fragment-testing:1.3.0-rc01 are released. Version 1.3.0-rc01 contains these commits.
Исправлены ошибки
-
onPrepareOptionsMenu()now follows the same logic asonCreateOptionsMenu()and is no longer called when a parent fragment callssetMenuVisibility(false). ( Id7de8 , b/173203654 )
New State Manager Bug Fixes
- Fixed leak and visual artifact when adding a fragment with an
Animationto aFragmentContainerViewand then interrupting that addition with a pop operation. ( I952d8 ) - Fixed an issue where the fragment's view would remain in the view hierarchy if it was replaced during its
onCreate()oronViewCreated()methods. ( I8a7d5 ) - Focus is now properly restored to Fragment root views when they are resumed. ( Ifc84b )
- Combining pop and replace operations in the same fragment transaction will now show the proper animations ( Ifd4e4 , b/170328691 )
Версия 1.3.0-beta02
2 декабря 2020 г.
androidx.fragment:fragment:1.3.0-beta02 , androidx.fragment:fragment-ktx:1.3.0-beta02 , and androidx.fragment:fragment-testing:1.3.0-beta02 are released. Version 1.3.0-beta02 contains these commits.
Новые функции
-
FragmentScenariohas been fully converted to Kotlin while maintaining source and binary compatibility via usage of Kotlin 1.4's functional interfaces forFragmentAction. ( I19d31 )
Изменения в поведении
- FragmentContainerViews that do not inflate a fragment using the
classorandroid:nameattribute can now be used outside of aFragmentActivity. ( Id4397 , b/172266337 ) - Attempting to set the max lifecycle of a fragment to
DESTROYEDwill now throw anIllegalArgumentException( Ie7651 , b/170765622 ) - Initializing a FragmentScenario with a
DESTROYEDstate will now throw anIllegalArgumentException( I73590 , b/170765622 )
New State Manager Bug Fixes
- Fixed an issue where the view would not reach its final state if you interrupt a fragment transition that was using an
Animatoror one of theTRANSIT_FRAGMENT_options. ( I92426 , b/169874632 ) - Fixed an issue that prevented fragments with an exiting
Animationfrom being properly destroyed. ( I83d65 ) - Exiting fragments that have their effects reversed now correctly cancel and restart with the proper entering effect. ( I62226 , b/167092035 )
- Fixed an issue where the exit
Animatorof ahide()would not run. ( Id7ffe ) - Fragments now properly appear when postponed and then immediately started. ( Ie713b , b/170022857 )
- Fragments that remove their focused view during an animation will no longer attempt to restore the focus on the detached view once they reach
RESUMED( I38c65 , b/172925703 )
Внешний вклад
-
FragmentFactorynow caches fragment classes separately for differentClassLoaderinstances. Thanks Simon Schiller! ( #87 , b/113886460 )
Версия 1.3.0-beta01
1 октября 2020 г.
androidx.fragment:fragment:1.3.0-beta01 , androidx.fragment:fragment-ktx:1.3.0-beta01 , and androidx.fragment:fragment-testing:1.3.0-beta01 are released. Version 1.3.0-beta01 contains these commits.
Новые функции
-
setMaxLifecycle()now supports setting theLifecyclestate toINITIALIZINGas long as the fragment has not been moved toCREATED. ( b/159662173 )
Изменения в API
- Upgrade androidx to use Kotlin 1.4 ( Id6471 , b/165307851 , b/165300826 )
Изменения в поведении
- Fragment resource files have been correctly made private. ( aosp/1425237 )
Исправлены ошибки
- Fragments inflated using the
<fragment>tag will now properly wait until their views are added to a container before moving to STARTED ( I02f4c ) - Fragments that are visible and then
setMaxLifecycle()toCREATEDnow properly run their exit effects. ( b/165822335 ) - Removing a detached fragment that is not added to the back stack no longer causes a memory leak. Courtesy of Nicklas Ansman Giertz! ( b/166489383 )
- Active fragments will now always have a non-null
FragmentManagerand fragments with a non-nullFragmentManagerwill always be considered active. ( aosp/1422346 ) - The fragment default effects,
TRANSIT_FRAGMENT_OPEN,TRANSIT_FRAGMENT_CLOSE, andTRANSIT_FRAGMENT_FADE, now useAnimatorinstead ofAnimation. ( b/166155034 )
New State Manager Bug Fixes
- Fragments now properly restore their view focus state from right before they start their animation. ( Icc256 )
- Fragments that only have a shared element transition now properly complete their special effects meaning they actually move to their final state ( Iaebc7 , b/166658128 )
- Fragment views are now always removed from the container before being destroyed. ( Id5876 )
- The new state manager now consistently removes the exiting fragment view before adding the entering one. ( I41a6e )
- Explicit changes to a fragment view's visibility are now respected by the new state manager. This means that if you set an entering fragment's view to
INVISIBLEbefore the animation begins, it will actually stay invisible. ( b/164481490 ) - Fragments now prioritize
AnimatorsoverAnimations, meaning a fragment with both will only run theAnimatorand ignore theAnimation. ( b/167579557 ) - The new state manager no longer causes fragments to flash when using entering animations. ( b/163084315 )
Известная проблема
When using the new state manager, if you press back during an entering special effect instead of returning to the previous fragment, the old fragment is never re-added, resulting in a blank screen. ( b/167259187 , b/167092035 , b/168442830 )
Version 1.3.0-alpha08
19 августа 2020 г.
androidx.fragment:fragment:1.3.0-alpha08 , androidx.fragment:fragment-ktx:1.3.0-alpha08 , and androidx.fragment:fragment-testing:1.3.0-alpha08 are released. Version 1.3.0-alpha08 contains these commits.
New State Manager
This release includes a major refactoring of the internal state management of FragmentManager which affects the dispatch of lifecycle methods, animations and transitions, and how postponed transactions are handled. This is enabled by default. See the Fragments: Rebuilding the Internals blog post for more details. ( b/139536619 , b/147749580 )
- An experimental API in
FragmentManager.enableNewStateManager(boolean)can be used to control whether FragmentManager uses the new state manager. ( I7b6ee )
The following issues are fixed only when using the new state manager:
- The previous fragment of a
replaceoperation is now correctly stopped before the new fragment is started. ( b/161654580 ) - Fragments now prevent multiple competing animations on the same fragments, avoiding cases where an
Animationwould override allTransitioneffects or anAnimatorand aTransitionon an individual fragment would both run. ( b/149569323 ) - The
enterTransitionandexitTranstionof all fragments entering and exiting are now ran rather than only the last entering fragment and the first exiting fragment. ( b/149344150 ) - Postponed fragments no longer get stuck at the
CREATEDstate but instead move toSTARTEDwith other fragments. ( b/129035555 ) - Fixed an issue where
FragmentManagerwould execute operations out of order when mixing a postponed re-ordered transaction and a non-reordered transaction. ( b/147297731 ) - Popping multiple fragments simultaneously will no longer result in intermediate fragments being temporarily visible when postponing fragments. ( b/37140383 )
-
FragmentManagernow returns the correct fragments when callingfindFragmentById()orfindFragmentByTag()from within theonAttachFragment()callback. ( b/153082833 ) - Fragments no longer call
onCreateView()on fragments being destroyed when the fragment replacing them is postponed. ( b/143915710 ) - The error message when attempting to combine framework
Transitionand AndroidXTransitioninstances now mentions the fragment with the invalid transition. ( b/155574969 )
Изменения в поведении
- You can now call
launch()on anActivityResultLauncherin theonCreate()lifecycle method of a fragment. ( b/161464278 ) - Calling
registerForActivityResult()afteronCreate()now throws an exception indicating that this is not allowed rather than silently failing to deliver results after a configuration change. ( b/162255449 ) -
FragmentActivitynow uses theOnContextAvailableListenerAPI introduced in Activity1.2.0-alpha08to restore the state of theFragmentManager. Any listeners added to subclasses ofFragmentActivitywill run after this listener. ( I513da )
Исправлены ошибки
-
ActivityOptionspassed through when usingstartIntentSenderForResult()are now respected. ( b/162247961 )
Известная проблема
- When using the new state manager, directly setting the visibility of the fragment's root view after
onViewCreated()and beforeonResume()results in the visibility you set being overridden byFragmentManager, who controls the visibility of the root view. As a workaround, you should always use thehide()andshow()operations to change the visibility of your fragment. ( b/164481490 )
Version 1.3.0-alpha07
22 июля 2020 г.
androidx.fragment:fragment:1.3.0-alpha07 , androidx.fragment:fragment-ktx:1.3.0-alpha07 , and androidx.fragment:fragment-testing:1.3.0-alpha07 are released. Version 1.3.0-alpha07 contains these commits.
Новые функции
-
FragmentScenarionow supports setting an initial Lifecycle state ofCREATED,STARTED, orRESUMEDrather than always moving the Fragment to theRESUMEDstate. ( b/159662750 ) - Added an alternative to the
FragmentScenarioAPI ofonFragmentin the form of the Kotlin reified extension methodwithFragmentthat allows you to return a value. Notably, it rethrows exceptions raised in the given block. ( b/158697631 )
Изменения в поведении
-
FragmentScenarionow usessetMaxLifecycle()to implementmoveToState(), ensuring consistent behavior on all API levels and decoupling the Fragment's state from the underlying Activity. ( b/156527405 ) - The
SavedStateRegistryOwnerreturned byViewTreeSavedStateRegistryOwneris now tied to the fragment view's Lifecycle. This ensures that it has its state saved and restore at the same time as the fragment's view. ( b/158503763 )
Исправлены ошибки
- Fragments now wait for the fragment's view to be attached before calling
ViewCompat.requestApplyInsets(), avoiding cases where the inset request was being dropped. ( b/158095749 ) - Calling
clearFragmentResultListenernow properly clears the lifecycle observer. ( b/159274993 )
Version 1.3.0-alpha06
10 июня 2020 г.
androidx.fragment:fragment:1.3.0-alpha06 , androidx.fragment:fragment-ktx:1.3.0-alpha06 , and androidx.fragment:fragment-testing:1.3.0-alpha06 are released. Version 1.3.0-alpha06 contains these commits.
Новые функции
- The
onAttachFragment()callback onFragmentActivityandFragmenthave been deprecated. A newFragmentOnAttachListenerhas been added to provide a more flexible alternative, allowing delegation ofonAttachFragment()to separate, testable listeners and support for adding a listener to FragmentManagers other than your direct child FragmentManager. ( I06d3d )
Исправлены ошибки
- Parent fragments now have their view state restored before their child fragments, fixing a visual ordering issue after a configuration change when a
DialogFragmentwould show anotherDialogFragmentas a child fragment. ( b/157195715 ) - Fixed an issue where the
UseRequireInsteadOfGetLint check would not handle chained usages of the?.and!!operators correctly. ( b/157677616 )
Version 1.3.0-alpha05
20 мая 2020 г.
androidx.fragment:fragment:1.3.0-alpha05 , androidx.fragment:fragment-ktx:1.3.0-alpha05 , and androidx.fragment:fragment-testing:1.3.0-alpha05 are released. Version 1.3.0-alpha05 contains these commits.
Новые функции
- Added support for
ViewTreeViewModelStoreOwnerfrom Lifecycle2.3.0-alpha03, andViewTreeSavedStateRegistryOwnerfrom SavedState1.1.0-alpha01when using aViewwithin aFragment. ( aosp/1297993 , aosp/1300264 )
Изменения в API
- The
setFragmentResult()andsetFragmentResultListener()APIs now take a non-nullBundleandFragmentResultListener, respectively. To explicitly clear a previously set result or listener, use the newclearFragmentResult()andclearFragmentResultListener()methods. ( b/155416778 ) - The
setFragmentResultListener()Kotlin extensions that take a lambda are now marked asinline. ( b/155323404 )
Изменения в поведении
- The previously deprecated
startActivityForResult(),startIntentSenderForResult(), andrequestPermissionsonFragmentnow internally useActivityResultRegistry, thus removing the restriction on using only the lower bits (below0xFFFF) for your request codes when using those APIs. ( b/155518741 )
Documentation Updates
- Expanded the documentation on the
Fragment(@LayoutRes int)andDialogFragment(@LayoutRes int)constructors to clarify that they should be called from your subclasses' no argument constructor when using the defaultFragmentFactory. ( b/153042497 )
Version 1.3.0-alpha04
29 апреля 2020 г.
androidx.fragment:fragment:1.3.0-alpha04 , androidx.fragment:fragment-ktx:1.3.0-alpha04 , and androidx.fragment:fragment-testing:1.3.0-alpha04 are released. Version 1.3.0-alpha04 contains these commits.
Новые функции
- Added support for passing results between two Fragments via new APIs on
FragmentManager. This works for hierarchy fragments (parent/child), DialogFragments, and fragments in Navigation and ensures that results are only sent to your Fragment while it is at leastSTARTED. ( b/149787344 )
Изменения в API
- The target fragment APIs have been deprecated. To pass data between fragments the new Fragment Result APIs should be used instead. ( b/149787344 )
- The
startActivityForResult()/onActivityResult()andrequestPermissions()/onRequestPermissionsResult()APIs on Fragment have been deprecated. Please use the Activity Result APIs . ( aosp/1290887 ) - Breaking change from Activity
1.2.0-alpha04: theprepareCall()method has been renamed toregisterForActivityResult(). ( aosp/1278717 )
Исправлены ошибки
- The fragment's
getViewLifecycleOwner()is now stopped beforeonSaveInstanceState()is called, mirroring the behavior of the fragment's lifecycle. ( b/154645875 ) - Calling
setMenuVisibility(false)on a fragment now correctly changes the visibility of menus provided by its child fragments. ( b/153593580 ) - Fixed an
illegalStateExceptionwhen adding a fragment to aDialogFragment's view hierarchy withFragmentContainerView. ( b/154366601 ) - The
getDefaultViewModelProviderFactory()method on fragments no longer crashes when hosting your fragments outside of an activity. ( b/153762914 )
Version 1.3.0-alpha03
1 апреля 2020 г.
androidx.fragment:fragment:1.3.0-alpha03 , androidx.fragment:fragment-ktx:1.3.0-alpha03 , and androidx.fragment:fragment-testing:1.3.0-alpha03 are released. Version 1.3.0-alpha03 contains these commits.
Изменения в API
- The
prepareCallmethods onFragmentare nowfinal. ( b/152439361 )
Исправлены ошибки
- Fixed a regression introduced in Fragment
1.3.0-alpha02when usingBottomSheetDialogFragment. ( b/151652127 , aosp/1263328 , aosp/1265163 ) - Fixed a crash when using
prepareCallfrom a fragment after a configuration change. ( b/152137004 ) - Fixed an issue where shared element and exit transitions are ignored when using
setTargetFragment(). ( b/152023196 ) - From Fragment
1.2.4: Updated the Fragment ProGuard rules to allow obfuscation of kept fragments. ( b/151605338 ) - From Fragment
1.2.4: Disabled theFragmentLiveDataObserveLint rule onDialogFragmentclasses as their lifecycle and view lifecycle are always in sync, making it safe to use eitherthisorviewLifecycleOwnerwhen callingobserve. ( b/151765086 )
Dependency Changes
- Fragments depend on Activity
1.2.0-alpha03, which had significant improvements to the Activity Result API introduced in Activity1.2.0-alpha02.
Версия 1.3.0-alpha02
18 марта 2020 г.
androidx.fragment:fragment:1.3.0-alpha02 , androidx.fragment:fragment-ktx:1.3.0-alpha02 , and androidx.fragment:fragment-testing:1.3.0-alpha02 are released. Version 1.3.0-alpha02 contains these commits.
Новые функции
- Added support for the
ActivityResultRegistryAPI introduced in Activity1.2.0-alpha02to handle thestartActivityForResult()+onActivityResult()as well asrequestPermissions()+onRequestPermissionsResult()flows without overriding methods in your Fragment in addition to providing hooks for testing these flows. See the updated Getting a Result from an Activity . ( b/125158199 )
Изменения в API
-
DialogFragmentnow provides a constructor that takes a@LayoutResthat indicates the layout thatonCreateView()should inflate by default. ( b/150327080 ) - The
onActivityCreated()method is now deprecated. Code touching the fragment's view should be done inonViewCreated()(which is called immediately beforeonActivityCreated()) and other initialization code should be inonCreate(). To receive a callback specifically when the activity'sonCreate()is complete, aLifeCycleObservershould be registered on the activity'sLifecycleinonAttach(), and removed once theonCreate()callback is received. ( b/144309266 )
Исправлены ошибки
- From Fragment
1.2.3: Fixed a bug inDialogFragmentthat caused aStackOverflowErrorwhen callinggetLayoutInflater()from withinonCreateDialog(). ( b/117894767 , aosp/1258664 ) - From Fragment
1.2.3: Reduced the scope of Fragment's included ProGuard rules to ensure that unused Fragment classes can be stripped. ( b/149665169 ) - From Fragment
1.2.3: Fixed false positives in theUseRequireInsteadOfGetLint check when using a local variable name that shadowed the Kotlin property name. ( b/149891163 ) - From Fragment
1.2.3:FragmentContainerViewno longer throws anUnsupportedOperationExceptionfor using the incorrect constructor in layout preview. ( b/149707833 )
Известные проблемы
-
BottomSheetDialogFragmentno longer properly positions its dialog on the screen. ( b/151652127 )
Версия 1.3.0-alpha01
4 марта 2020 г.
androidx.fragment:fragment:1.3.0-alpha01 , androidx.fragment:fragment-ktx:1.3.0-alpha01 , and androidx.fragment:fragment-testing:1.3.0-alpha01 are released. Version 1.3.0-alpha01 contains these commits.
Новые функции
- Added support for the
ViewTreeLifecycleOwner.get(View)API added in Lifecycle2.3.0-alpha01such that it will return the Fragment'sviewLifecycleOwneras theLifecycleOwnerfor any Views returned byonCreateView(). ( aosp/1182955 )
Изменения в API
- The
setRetainInstance()method on Fragments has been deprecated. With the introduction of ViewModels , developers have a specific API for retaining state that can be associated with Activities, Fragments, and Navigation graphs. This allows developers to use a normal, not retained Fragment and keep the specific state they want retained separate, avoiding a common source of leaks while maintaining the useful properties of a single creation and destruction of the retained state (namely, the constructor of theViewModeland theonCleared()callback it receives). ( b/143911815 ) - With the release of ViewPager2
1.0.0, theFragmentPagerAdapterandFragmentStatePagerAdapterclasses for interacting withViewPagerhave been deprecated. See Migrate from ViewPager to ViewPager2 . ( b/145132715 )
Исправлены ошибки
- Fragment ProGuard rules now correctly only keep the default constructors
Fragmentclasses that are used rather than for allFragmentinstances, fixing a regression introduced in Fragment1.2.1. ( b/149665169 - The
require___()Lint rules added in Fragment1.2.2no longer false positive on local variables that share the same name as the shadowed Kotlin property names (ie,view). ( b/149891163 ) -
FragmentContainerViewno longer throws anUnsupportedOperationExceptionwhen using the layout preview in Android Studio. ( b/149707833 ) - Fixed an issue where retained fragments that were added after the state is saved would not be continually recreated and then destroyed after each configuration change. ( b/145832397 )
Версия 1.2.5
Версия 1.2.5
10 июня 2020 г.
androidx.fragment:fragment:1.2.5 , androidx.fragment:fragment-ktx:1.2.5 , and androidx.fragment:fragment-testing:1.2.5 are released. Version 1.2.5 contains these commits.
Исправлены ошибки
- The fragment's
getViewLifecycleOwner()is now stopped beforeonSaveInstanceState()is called, mirroring the behavior of the fragment's lifecycle. This was previously released in Fragment1.3.0-alpha04. ( b/154645875 ) - Calling
setMenuVisibility(false)on a fragment now correctly changes the visibility of menus provided by its child fragments. This was previously released in Fragment1.3.0-alpha04. ( b/153593580 )
Версия 1.2.4
Версия 1.2.4
1 апреля 2020 г.
androidx.fragment:fragment:1.2.4 , androidx.fragment:fragment-ktx:1.2.4 , and androidx.fragment:fragment-testing:1.2.4 are released. Version 1.2.4 contains these commits.
Исправлены ошибки
- Updated the Fragment ProGuard rules to allow obfuscation of kept fragments. ( b/151605338 )
- Disabled the
FragmentLiveDataObserveLint rule onDialogFragmentclasses as their lifecycle and view lifecycle are always in sync, making it safe to use eitherthisorviewLifecycleOwnerwhen callingobserve. ( b/151765086 )
Версия 1.2.3
Версия 1.2.3
18 марта 2020 г.
androidx.fragment:fragment:1.2.3 , androidx.fragment:fragment-ktx:1.2.3 , and androidx.fragment:fragment-testing:1.2.3 are released. Version 1.2.3 contains these commits.
Исправлены ошибки
- Fixed a bug in
DialogFragmentthat caused aStackOverflowErrorwhen callinggetLayoutInflater()from withinonCreateDialog(). ( b/117894767 , aosp/1258665 ) - Reduced the scope of Fragment's included ProGuard rules to ensure that unused Fragment classes can be stripped. ( b/149665169 )
- Fixed false positives in the
UseRequireInsteadOfGetLint check when using a local variable name that shadowed the Kotlin property name. ( b/149891163 ) -
FragmentContainerViewno longer throws anUnsupportedOperationExceptionfor using the incorrect constructor in layout preview. ( b/149707833 )
Версия 1.2.2
Версия 1.2.2
19 февраля 2020 г.
androidx.fragment:fragment:1.2.2 , androidx.fragment:fragment-ktx:1.2.2 , and androidx.fragment:fragment-testing:1.2.2 are released. Version 1.2.2 contains these commits.
New Lint checks
- Lint suggests using the
viewLifecycleOwneras theLifecycleOwnerto calls intoOnBackPressedDispatcherinonCreateView(),onViewCreated(), andonActivityCreated(). ( b/142117657 ) - Added a new Lint check that confirms that you are using the correct
debugImplementationwhen using thefragment-testingartifact. ( b/141500106 ) - Fragments now suggest using the associated
require___()methods for more descriptive error messages instead ofcheckNotNull(get___()),requireNonNull(get___()), orget___()!!for all of the Fragment APIs that include both agetandrequireequivalent. ( aosp/1202883 )
Исправлены ошибки
- Fixed the Fragment ProGuard files to avoid R8 warnings ( b/148963981 )
- Improved the existing Lint check suggesting using
viewLifecycleOwnerwhen usingobserveto also handle thelivedata-ktxextension method version ofobserve. ( b/148996309 ) - Fixed the formatting for many of the Lint checks ( aosp/1157012 )
Внешние вклады
- Thanks to Zac Sweers for contributing the
require___()Lint checks on behalf of Slack! ( aosp/1202883 )
Версия 1.2.1
Версия 1.2.1
5 февраля 2020 г.
androidx.fragment:fragment:1.2.1 , androidx.fragment:fragment-ktx:1.2.1 , and androidx.fragment:fragment-testing:1.2.1 are released. Version 1.2.1 contains these commits .
Исправлены ошибки
- Fragments added via the
addandreplacemethods that take aClassinstance (or the Kotlin reified versions) now have their default constructor kept by ProGuard. ( b/148181315 ) -
FragmentStatePagerAdapterandFragmentPagerAdapterno longer catch exceptions thrown byFragmentManagerwhen runningfinishUpdate(). ( aosp/1208711 ) - Fixed an issue where
FragmentManager.findFragment()did not work with fragments added via the<fragment>tag. ( b/147784323 ) - Fragments inflated using the
<fragment>tag now always receive a call toonInflate()beforeonCreate()when in the layout. ( aosp/1215856 ) - Calling
toString()on aFragmentManagerinstance no longer throws aNullPointerExceptionwhen the Activity is already destroyed. ( b/148189412 )
Dependency changes
- Fragments
1.2.1now depends on Lifecycle ViewModel SavedState2.2.0.
Версия 1.2.0
Версия 1.2.0
22 января 2020 г.
androidx.fragment:fragment:1.2.0 , androidx.fragment:fragment-ktx:1.2.0 , and androidx.fragment:fragment-testing:1.2.0 are released. Version 1.2.0 contains these commits .
Важные изменения по сравнению с версией 1.1.0
- FragmentContainerView : The
FragmentContainerViewis the strongly recommended container for dynamically added Fragments, replacing usage ofFrameLayoutor other layouts. It also supports the sameclass,android:name, and optionalandroid:tagas the<fragment>tag, but uses a normalFragmentTransactionto add this initial fragment, instead of the custom code path used by<fragment>. -
onDestroyView()timing : Fragments now wait for exit animations, exit framework transitions, and exit AndroidX transitions (when using Transition1.3.0) to complete before callingonDestroyView(). - Class based
add()andreplace(): Added new overloads ofadd()andreplace()onFragmentTransactionthat take aClass<? extends Fragment>and optionalBundleof arguments. These methods use yourFragmentFactoryto construct an instance of the Fragment to add. Kotlin extensions that use reified types (ie,fragmentTransaction.replace<YourFragment>(R.id.container)) have also been added tofragment-ktx. - Lifecycle ViewModel SavedState Integration :
SavedStateViewModelFactoryis now the default factory used when usingby viewModels(),by activityViewModels(), theViewModelProviderconstructor, orViewModelProviders.of()with a Fragment. - New Lint checks : Added a new Lint check that ensures you are using
getViewLifecycleOwner()when observingLiveDatafromonCreateView(),onViewCreated(), oronActivityCreated(). -
getFragmentManager()deprecation : ThegetFragmentManager()andrequireFragmentManager()methods on Fragment have been deprecated and replaced with a singlegetParentFragmentManager()method, which returns the non-nullFragmentManagerthe Fragment is added to (you can useisAdded()to determine if it is safe to call). -
FragmentManager.enableDebugLogging()deprecation : The staticFragmentManager.enableDebugLoggingmethod has been deprecated. FragmentManager now respectsLog.isLoggable()for the tagFragmentManager, allowing you to enable eitherDEBUGorVERBOSElogging without re-compiling your app.
Известные проблемы
- Fragments referenced only via the
classorandroid:nameattribute on aFragmentContainerVieware not kept by ProGuard automatically, requiring that you manually add a keep rule for each fragment class. ( b/142601969 ) - When adding a
NavHostFragmentusingclassorandroid:namein XML withFragmentContainerView, you cannot usefindNavController()inonCreate()of your Activity. ( b/142847973 )
Version 1.2.0-rc05
8 января 2020 г.
androidx.fragment:fragment:1.2.0-rc05 , androidx.fragment:fragment-ktx:1.2.0-rc05 , and androidx.fragment:fragment-testing:1.2.0-rc05 are released. Version 1.2.0-rc05 contains these commits .
Исправлены ошибки
- Fixed a regression in Fragment
1.2.0-rc04when using the<fragment>tag which causedonViewCreated()to be called incorrectly during activity destruction. ( b/146290333 ) - Fragments added with the
<fragment>tag now properly have their non-config cleared even when they are only sometimes in the layout (ie, only in your landscape layout). As a consequence, these Fragments are now correctly moved toCREATEDeven when not in your layout instead of being instantiated but never moving through any lifecycle methods. ( b/145769287 )
Version 1.2.0-rc04
18 декабря 2019 г.
androidx.fragment:fragment:1.2.0-rc04 , androidx.fragment:fragment-ktx:1.2.0-rc04 , and androidx.fragment:fragment-testing:1.2.0-rc04 are released. Version 1.2.0-rc04 contains these commits .
Исправлены ошибки
- Adjusted the animations for
TRANSIT_FRAGMENT_OPEN,TRANSIT_FRAGMENT_CLOSE, andTRANSIT_FRAGMENT_FADEto avoid visual issues. ( b/145468417 )
Version 1.2.0-rc03
4 декабря 2019 г.
androidx.fragment:fragment:1.2.0-rc03 , androidx.fragment:fragment-ktx:1.2.0-rc03 , and androidx.fragment:fragment-testing:1.2.0-rc03 are released. Version 1.2.0-rc03 contains these commits .
Исправлены ошибки
- Fixed an unintentional behavior change where Fragments who have been removed are still returned by
findFragmentById()/findFragmentByTag()while their exit animations/transitions run. ( b/143982969 , aosp/1167585 ) - Child fragments are now correctly stopped before their parents when the containing activity calls
onSaveInstanceState(). ( b/144380645 ) - Fixed an issue where Views were incorrectly marked
INVISIBLEafter popping a hidden Fragment. ( b/70793925 ) - Fragment shared element transitions now handle Views that have been rotated, scaled, etc. ( b/142835261 )
Documentation Updates
- Clarified the deprecation documentation around
setUserVisibleHint(). ( b/143897055 ) - Improved the documentation on
setFragmentFactory()andgetFragmentFactory()to better indicate that setting aFragmentFactorywill also affect child FragmentManagers. ( aosp/1170095 )
Dependency changes
- Fragments now depends on Lifecycle
2.2.0-rc03, Lifecycle ViewModel SavedState1.0.0-rc03, and Activity1.1.0-rc03.
Version 1.2.0-rc02
7 ноября 2019 г.
androidx.fragment:fragment:1.2.0-rc02 , androidx.fragment:fragment-ktx:1.2.0-rc02 , and androidx.fragment:fragment-testing:1.2.0-rc02 are released. Version 1.2.0-rc02 contains these commits .
Исправлены ошибки
- When in Kotlin, the LintFix for using
getViewLifecycleOwner()when observingLiveDatafromonCreateView(),onViewCreated(), oronActivityCreated()(introduced in Fragment1.2.0-rc01) now uses the Kotlin property access syntaxviewLifecycleOwnerinstead ofgetViewLifecycleOwner(). ( aosp/1143821 )
Версия 1.2.0-rc01
23 октября 2019 г.
androidx.fragment:fragment:1.2.0-rc01 , androidx.fragment:fragment-ktx:1.2.0-rc01 , and androidx.fragment:fragment-testing:1.2.0-rc01 are released. Version 1.2.0-rc01 contains these commits .
Новые функции
-
FragmentContainerViewnow supports theclassattribute in addition toandroid:name, mirroring the functionality of the<fragment>tag. ( b/142722242 ) - Added a new Lint check that ensures you are using
getViewLifecycleOwner()when observingLiveDatafromonCreateView(),onViewCreated(), oronActivityCreated(). ( b/137122478 )
Исправлены ошибки
- The
onDismissandonCancelcallbacks onDialogFragmentnow guarantee that theDialogInterfacepassed to them is non-null and thatgetDialog()returns non-null when they are executed. ( b/141974033 ) -
FragmentContainerViewnow adds the Fragment defined byclassorandroid:nameas part of inflation, ensuring thatfindFragmentById()andfindFragmentByTag()work immediately afterwards. ( b/142520327 ) - Fixed an
IllegalStateExceptioninFragmentContainerViewdue to the state being saved. ( b/142580713 ) - Fixed an
UnsupportedOperationExceptioninFragmentContainerViewwhen theFragmentContainerViewclass is obfuscated. ( b/142657034 )
Известные проблемы
- Fragments referenced only via the
classorandroid:nameattribute on aFragmentContainerVieware not kept by ProGuard automatically, requiring that you manually add a keep rule for each fragment class. We have disabled the Lint rule suggesting moving toFragmentContainerViewuntil this is fixed viaaapt2. ( b/142601969 )
Версия 1.2.0-beta02
11 октября 2019 г.
androidx.fragment:fragment:1.2.0-beta02 , androidx.fragment:fragment-ktx:1.2.0-beta02 , and androidx.fragment:fragment-testing:1.2.0-beta02 are released. Version 1.2.0-beta02 contains these commits .
Исправлены ошибки
- Fixed an issue where Fragment's
onInflate()did not receive proper attributes fromFragmentContainerView, breaking cases such asNavHostFragment. ( b/142421837 )
Версия 1.2.0-beta01
9 октября 2019 г.
androidx.fragment:fragment:1.2.0-beta01 , androidx.fragment:fragment-ktx:1.2.0-beta01 , and androidx.fragment:fragment-testing:1.2.0-beta01 are released. Version 1.2.0-beta01 contains these commits .
Новые функции
-
FragmentContainerViewadds support for adding an initial fragment with added support for theandroid:nameand optionalandroid:tagXML attributes. Unlike the<fragment>tag,FragmentContainerViewuses a normalFragmentTransactionunder the hood to add the initial fragment, allowing furtherFragmentTransactionoperations on theFragmentContainerViewand enables the usage of View Binding for the layout. ( b/139830628 , b/141177981 ) - Fragments now contains a Lint warning offering a quick fix to replace
<fragment>withFragmentContainerView. ( b/139830056 )
Исправлены ошибки
- Fixed a
ClassCastExceptionwhen usingandroidx.transition. ( b/140680619 ) - When using Transition
1.3.0-beta01, Fragments now wait forandroidx.transitiontransitions (in addition to framework transitions and animations, which were fixed in Fragment1.2.0-alpha03and Fragment1.2.0-alpha02, respectively) to finish before dispatchingonDestroyView(). ( aosp/1119841 ) - When using Transition
1.3.0-beta01, Fragments now properly cancelandroidx.transitiontransitions before starting new transitions / animations on the same container. ( aosp/1119841 ) - Fixed an issue on API 17 and lower when using
androidx.transitiontransitions on the root view of your Fragment when usingFragmentContainerView. ( b/140361893 ) - The
fragment-testingartifact now depends on AndroidX Test1.2.0, fixing an incompatibility with the latest Espresso 3.2.0. ( b/139100149 ) - Removed usage of
Log.win FragmentManager. ( aosp/1126468 )
Известные проблемы
- Fragment's
onInflate()do not receive proper attributes fromFragmentContainerView, breaking cases such asNavHostFragment. ( b/142421837 )
Версия 1.2.0-alpha04
18 сентября 2019 г.
androidx.fragment:fragment:1.2.0-alpha04 , androidx.fragment-ktx:example:1.2.0-alpha04 , and androidx.fragment:fragment-testing:1.2.0-alpha04 are released. Version 1.2.0-alpha04 contains these commits .
изменения API
- The
getFragmentManager()andrequireFragmentManager()methods onFragmenthave been deprecated and replaced with a singlegetParentFragmentManager()method, which returns the non-nullFragmentManagerthe Fragment is added to (you can useisAdded()to determine if it is safe to call). ( b/140574496 ) - The static
FragmentManager.enableDebugLoggingmethod has been deprecated. FragmentManager now respectsLog.isLoggable()for the tagFragmentManager, allowing you to enable eitherDEBUGorVERBOSElogging without re-compiling your app. ( aosp/1116591 )
Исправлены ошибки
- Fragments are now properly destroyed while exit animations on other fragments are running. ( b/140574199 )
- Fixed an issue where Fragments would call
Activity.findViewById()where before it did not. ( aosp/1116431 )
Версия 1.2.0-alpha03
5 сентября 2019 г.
androidx.fragment:fragment:1.2.0-alpha03 , androidx.fragment:fragment-ktx:1.2.0-alpha03 , and androidx.fragment:fragment-testing:1.2.0-alpha03 are released. The commits included in this version can be found here .
изменения API
-
FragmentContainerViewis nowfinal. ( b/140133091 )
Исправлены ошибки
-
FragmentContainerViewnow properly reverses the draw order when popping fragments off the back stack. ( b/139104187 ) - Fixed an issue where the wrong animation would run when both popping a fragment and adding a new fragment at the same time. ( b/111659726 )
- Fragments now wait for transitions (in addition to animations, which was fixed in Fragment
1.2.0-alpha02) to finish before dispatchingonDestroyView(). ( b/138741697 )
Версия 1.2.0-alpha02
7 августа 2019 г.
androidx.fragment:fragment:1.2.0-alpha02 , androidx.fragment:fragment-ktx:1.2.0-alpha02 , and androidx.fragment:fragment-testing:11.2.0-alpha02 is released. The commits included in this version can be found here .
Новые функции
-
SavedStateViewModelFactoryis now the default factory used when usingby viewModels(),by activityViewModels(), theViewModelProviderconstructor, orViewModelProviders.of()with aFragment. ( b/135716331 ) - The default animations when using
TRANSIT_FRAGMENT_OPEN,TRANSIT_FRAGMENT_CLOSE,TRANSIT_FRAGMENT_FADEwithsetTransitionon aFragmentTransactionhave been updated to match the animations used by activities on Android 10 devices. ( aosp/1012812 , aosp/1014730 )
изменения API
- Introduces
FragmentContainerViewas the strongly recommended container for dynamically added Fragments, replacing usage ofFrameLayout, etc. as it fixes animation z-ordering issues and window insets dispatching to Fragments. ( b/37036000 , aosp/985243 , b/136494650 ) - Added a static
FragmentManager.findFragment(View)method to retrieve the containing Fragment from a view inflated by a fragment. A Kotlin extension is also available infragment-ktx. ( aosp/1090757 ) - Added new overloads of
add()andreplace()onFragmentTransactionthat take aClass<? extends Fragment>and optionalBundleof arguments. These methods use yourFragmentFactoryto construct an instance of the Fragment to add. Kotlin extension that use reified types (ie,fragmentTransaction.replace<YourFragment>(R.id.container)) have also been added tofragment-ktx. ( b/126124987 ) -
@MainThreadannotations have been added toFragmentlifecycle callbacks. ( b/127272564 ) - The breadcrumb title related APIs on
FragmentTransactionandFragmentManager.BackStackEntryhave been deprecated. ( b/138252944 ) - The
setTransitionStylemethod onFragmentTransactionhas been deprecated. ( aosp/1011537 ) - Many of the methods in
FragmentManagerare no longerabstract.FragmentManageritself remainsabstractand should not be directly instantiated or extended; you should continue to only get an existing instance fromgetSupportFragmentManager(),getChildFragmentManager(), etc.
Исправлены ошибки
- From Fragment
1.1.0-rc04: Fragments now correctly cancel postponed transitions on Fragments have been popped. ( b/138251858 ) - From Fragment
1.1.0-rc03: Fixed an issue where callingpostponeEnterTransition()with a timeout more than once would not cancel previous timeouts. ( b/137797118 ) - From Fragment
1.1.0-rc02: Fixed a crash inFragmentPagerAdapterandFragmentStatePagerAdapterwhen removing the current item. ( b/137209870 ) - Fragments now wait for animations to finish before dispatching
onDestroyView(). ( b/136110528 ) - Fragment animations from child fragments and their descendants are now properly handled when animating the parent Fragment. ( b/116675313 )
- Fixed a
NullPointerExceptionwhen using shared element transitions and combining a pop and add operation. ( b/120507394 ) - Added a workaround to
IllegalStateExceptions when usingFragmentPagerAdapterandFragmentStatePagerAdapterin Robolectric tests. ( b/137201343 )
Версия 1.2.0-alpha01
2 июля 2019 г.
androidx.fragment:fragment:1.2.0-alpha01 , androidx.fragment:fragment-ktx:1.2.0-alpha01 , and androidx.fragment:fragment-testing:1.2.0-alpha01 are released. The commits included in this version can be found here .
Новые функции
- FragmentManager now calls
requestApplyInsets()after attaching the Fragment's view and directly before callingonViewCreated(), ensuring that your view always has the correct insets. ( b/135945162 )
Исправлены ошибки
- Fixed a
NullPointerExceptionwhen popping aFragmentTransactionthat usedsetPrimaryNavigationFragment()beforereplace(). ( b/134673465 )
Версия 1.1.0
Версия 1.1.0
5 сентября 2019 г.
androidx.fragment:fragment:1.1.0 , androidx.fragment:fragment-ktx:1.1.0 , and androidx.fragment:fragment-testing:1.1.0 are released. The commits included in this version can be found here .
Important Changes since 1.0.0
- fragment-testing : The
fragment-testingartifact provides aFragmentScenarioclass for testing a fragment in isolation. See Test your app's fragments documentation for more details. - FragmentFactory : You can now set a
FragmentFactoryon aFragmentManagerto manage the creation of fragment instances, removing the strict requirement to have a no-argument constructor. - Kotlin Property Delegates for ViewModels : The
fragment-ktxartifact now contains two Kotlin property delegates:by viewModels()for accessing ViewModels associated with the individual fragment andby activityViewModels()for accessing ViewModels scoped to the activity. - Max Lifecycle : You can now set a max Lifecycle state for a Fragment by calling
setMaxLifecycle()on aFragmentTransaction. This replaces the now deprecatedsetUserVisibleHint().FragmentPagerAdapterandFragmentStatePagerAdapterhave a new constructor that allows you to switch to the new behavior. - FragmentActivity LayoutId constructor : Subclasses of
FragmentActivitycan now optionally call into a constructor onFragmentActivitythat takes anR.layoutID, indicating the layout that should be set as the content view as an alternative to callingsetContentView()inonCreate(). This does not change the requirement that your subclass have a no-argument constructor. - Fragment LayoutId constructor : Subclasses of
Fragmentcan now optionally call into a constructor onFragmentthat takes anR.layoutID, indicating the layout that should be used for this fragment as an alternative to overridingonCreateView(). The inflated layout can be configured inonViewCreated(). - Postpone with a timeout : A new overload of
postponeEnterTransition()has been added that takes a timeout.
Version 1.1.0-rc04
7 августа 2019 г.
androidx.fragment:fragment:1.1.0-rc04 , androidx.fragment:fragment-ktx:1.1.0-rc04 , and androidx.fragment:fragment-testing:1.1.0-rc04 is released. The commits included in this version can be found here .
Исправлены ошибки
- Fragments now correctly cancel postponed transitions on Fragments have been popped. ( b/138251858 )
Version 1.1.0-rc03
19 июля 2019 г.
androidx.fragment:fragment:1.1.0-rc03 , androidx.fragment:fragment-ktx:1.1.0-rc03 , and androidx.fragment:fragment-testing:1.1.0-rc03 is released. The commits included in this version can be found here .
Исправлены ошибки
- Fixed an issue where calling
postponeEnterTransition()with a timeout more than once would not cancel previous timeouts. ( b/137797118 )
Version 1.1.0-rc02
17 июля 2019 г.
androidx.fragment:fragment:1.1.0-rc02 , androidx.fragment:fragment-ktx:1.1.0-rc02 , and androidx.fragment-testing:fragment:1.1.0-rc02 are released. The commits included in this version can be found here .
Исправлены ошибки
- Fixed a crash in
FragmentPagerAdapterandFragmentStatePagerAdapterwhen removing the current item. ( b/137209870 )
Версия 1.1.0-rc01
2 июля 2019 г.
androidx.fragment:fragment:1.1.0-rc01 , androidx.fragment:fragment-ktx:1.1.0-rc01 , and androidx.fragment:fragment-testing:1.1.0-rc01 are released. The commits included in this version can be found here .
Исправлены ошибки
- Fragments now properly update their visibility when using
show()orhide()operations while the transition is running. ( b/133385058 ) - Fixed a
NullPointerExceptionwhen popping aFragmentTransactionthat usedsetPrimaryNavigationFragment()beforereplace(). ( b/134673465 )
Версия 1.1.0-beta01
5 июня 2019 г.
androidx.fragment:fragment:1.1.0-beta01 , androidx.fragment:fragment-ktx:1.1.0-beta01 , and androidx.fragment:fragment-testing:1.1.0-beta01 are released. The commits included in this version can be found here .
Исправлены ошибки
-
androidx.lifecycle.Lifecyclecallbacks (specifically related toSTARTED,RESUMED,PAUSED,STOPPED, andDESTROYED) for nested Fragments are now properly nested. ( b/133497591 ) -
OnBackPressedCallbackinstances registered in a Fragment'sonCreate()now properly take precedence over the child FragmentManager. ( b/133175997 ) - Child fragments are no longer animated when their parent fragment is being replaced. ( b/121017790 )
- Fragments animations and transitions are now ignored when using
animateLayoutChanges="true", fixing an issue where Fragments were not properly destroyed. ( b/116257087 )
Version 1.1.0-alpha09
16 мая 2019 г.
androidx.fragment:fragment:1.1.0-alpha09 , androidx.fragment:fragment-ktx:1.1.0-alpha09 , and androidx.fragment:fragment-testing:1.1.0-alpha09 are released. The commits included in this version can be found here .
изменения API
- Fragments now receive a callback to a new
onPrimaryNavigationFragmentChanged(boolean)method when the primary navigation fragment changes. aosp/960857
Исправлены ошибки
- Menu Items inflated by a child Fragment are now correctly removed when the Parent Fragment is removed. b/131581013
Version 1.1.0-alpha08
7 мая 2019 г.
androidx.fragment:fragment:1.1.0-alpha08 , androidx.fragment:fragment-ktx:1.1.0-alpha08 , and androidx.fragment:fragment-testing:1.1.0-alpha08 are released. The commits included in this version can be found here .
This release is incompatible with Preferences 1.1.0-alpha01 through 1.1.0-alpha04. Please upgrade to Preferences 1.1.0-alpha05 when using this version of Fragments.
Новые функции
- Added a new overload of
postponeEnterTransition()that takes a timeout, after which the Fragment will automatically callstartPostponedEnterTransition()b/120803208
изменения API
- Breaking change: the previously deprecated
FragmentFactoryinstantiatemethod that took aBundlehas been removed. aosp/953856 - Breaking change: The
RESUME_ONLY_CURRENT_FRAGMENTandUSE_SET_USER_VISIBLE_HINTconstants inFragmentPagerAdapterandFragmentStatePagerAdapterhave been renamed toBEHAVIOR_RESUME_ONLY_CURRENT_FRAGMENTandBEHAVIOR_SET_USER_VISIBLE_HINT, respectively. aosp/954782
Исправлены ошибки
- Fragments that have had their lifecycle capped via
setMaxLifecycle()no longer get resumed before reaching their final state. b/131557151 - When using
setMaxLifecycle(Lifecycle.State.CREATED), Fragments will properly have their view destroyed. aosp/954180
Version 1.1.0-alpha07
25 апреля 2019 г.
androidx.fragment:fragment:1.1.0-alpha07 , androidx.fragment:fragment-ktx:1.1.0-alpha07 , and androidx.fragment:fragment-testing:1.1.0-alpha07 are released. The commits included in this version can be found here .
Новые функции
- You can now set a max Lifecycle state for a Fragment by calling
setMaxLifecycle()on aFragmentTransaction. This replaces the now deprecatedsetUserVisibleHint().FragmentPagerAdapterandFragmentStatePagerAdapterhave a new constructor that allows you to switch to the new behavior. ( b/129780800 )
Изменения в API
-
moveToState(STARTED)onFragmentScenariocan now only be called on API 24+ devices. ( b/129880016 )
Изменения в поведении
- As a consequence of ( b/129907905 ), fragments on the back stack will not get a callback to
onCreateView()when the hosting activity is recreated.onCreateView()will now only be called when the fragment becomes visible (ie, the back stack is popped).
Исправлены ошибки
- Fixed an issue when using a
<fragment>tag in XML and thecontentLayoutIdconstructor ofFragmentActivityorAppCompatActivity. ( b/129907905 ) - Corrected an issue where fragments on the back stack would not be moved to at least
CREATEDafter a configuration change, causing ViewModels and child retained fragments to not be properly disposed. ( b/129593351 ) - Fixed a crash in
restoreSaveStatecaused by a desync of the retained fragments after the instance state is saved. ( b/130433793 ) ( aosp/947824 ) - Fixed issues where an
OnBackPressedCallbackadded with a fragment lifecycle would not be called if theFragmentManagerhad a back stack. See androidx.activity 1.0.0-alpha07 for more details. ( aosp/948209 ) - Fragments no longer enforce
LAYER_TYPE_HARDWAREfor animations. If you specifically need a hardware layer animation, please set it as part of your animation. ( b/129486478 )
Версия 1.1.0-alpha06
3 апреля 2019 г.
androidx.fragment:fragment:1.1.0-alpha06 , androidx.fragment:fragment-ktx:1.1.0-alpha06 , and androidx.fragment:fragment-testing:1.1.0-alpha06 are released. The commits included in this version can be found here .
Новые функции
- Exceptions thrown by FragmentManager now include the Fragment's name in the message. ( b/67759402 )
Изменения в API
-
FragmentandFragmentActivitynow contain a second constructor that takes a@LayoutRes int, which replaces the previous behavior of annotating your class with@ContentView. This approach works in both app and library modules. ( b/128352521 ) - FragmentActivity's
onActivityResult()is now properly marked as@CallSuper. ( b/127971684 ) - The FragmentFactory's
instantiatemethod that takes an argument Bundle has been deprecated and apps should use the newinstantiateoverload that does not take a Bundle. ( b/128836103 ) -
FragmentScenariomethods are now properly annotated with@StyleRes. ( aosp/924193 ) -
FragmentTabHosthas been deprecated. ( b/127971835 ) - FragmentActivity's
getThemedContext()has been removed. ( aosp/934078 )
Исправлены ошибки
- Fixed a regression in 1.1.0-alpha05 that caused the incoming Fragment to flash on the screen. ( b/129405432 )
- Fixed an issue where the primary navigation fragment would be lost after a popBackStack+replace+popBackStack series of operations. ( b/124332597 )
- Fixed an issue when using
@ContentViewconstructors on your Activity when restoring Fragment state. ( b/127313094 ) - Corrected the logic of
setTargetFragment()when replacing an existing target Fragment with a Fragment not yet attached to the FragmentManager. ( aosp/932156 )
Версия 1.1.0-alpha05
March 13, 2019
androidx.fragment:fragment:1.1.0-alpha05 , androidx.fragment:fragment-ktx:1.1.0-alpha05 , and androidx.fragment:fragment-testing:1.1.0-alpha05 are released. The full list of commits included in this version can be found here .
Новые функции
-
@ContentViewannotation lookups are now cached ( b/123709449 )
Behavior changes
- Calling
remove(),hide(),show(),detach(), andsetPrimaryNavigationFragment()with a Fragment attached to a different FragmentManager now throws anIllegalStateExceptionrather than silently failing ( aosp/904301 )
Исправлены ошибки
-
onNewIntentforFragmentActivityis now correctly marked with@CallSuper( b/124120586 ) - Fixed an issue where
DialogFragment'sonDismiss()could be called twice when usinggetDialog().dismiss()orgetDialog().cancel()( b/126563750 )
Версия 1.1.0-alpha04
7 февраля 2019 г.
androidx.fragment:fragment 1.1.0-alpha04 , androidx.fragment:fragment-ktx 1.1.0-alpha04 , and androidx.fragment:fragment-testing 1.1.0-alpha04 are released.
Новые функции
- Added support for the
@ContentViewclass annotation that allows you to indicate which layout XML file should be inflated as an alternative to overridingonCreateView(). It is recommended to do view related work inonViewCreated(). ( aosp/837619 ) -
fragment-testingnow depends onandroidx.test:core-ktx1.1.0 stable ( b/121209673 ) - You can now use
openActionBarOverflowOrOptionsMenuwithFragmentScenarioto test Fragment hosted options menus ( b/121126668 )
изменения API
- Added a
requireArguments()method which returns a@NonNull Bundleor throws anIllegalStateException( b/121196360 ) - Added a note that
getLifecycle(),getViewLifecycleOwner(), andgetViewLifecycleOwnerLiveData()should not be overridden and will be made final in a future release. Please file a feature request if you are currently overriding this method. ( aosp/880714 ) - Added a note that
getViewModelStore()should not be overridden and will be made final in a future release. Please file a feature request if you are currently overriding this method. ( aosp/880713 ) - Fixed an issue with binary compatibility with previous releases of Fragments. ( aosp/887877 ) ( aosp/889834 )
Исправлены ошибки
- Target fragments are correctly cleared out when you pass
nulltosetTargetFragment(). ( aosp/849969 ) - Fixed an issue where target Fragments were sometimes unavailable in or after
onDestroy(). ( b/122312935 ) - DialogFragment's onDismiss() is now called before
onDestroy(). ( aosp/874133 ) ( aosp/890734 )
Версия 1.1.0-alpha03
17 декабря 2018 г.
Новые функции
- Fragment now implements
BundleSavedStateRegistryOwnerand depends on the newly released SavedState library [ aosp/824380 ] - A
by activityViewModelsKotlin property delegate has been added to retrieve ViewModels associated with the containing Activity [ b/119050253 ] - The
by viewModelsKotlin property delegate has been expanded to take an optional lambda method for getting theViewModelStoreOwner, allowing you to pass in the parent Fragment or other customViewModelStoreOwnerwith code such asval viewModel: MyViewModel by viewModels(::requireParentFragment)[ b/119050253 ]
изменения API
-
FragmentScenarionow allows you to specify a theme such asTheme.AppCompat[ b/119054431 ]. This is a breaking change. - Added a
requireView()method which returns a@NonNull Viewor throws anIllegalStateException[ b/120241368 ] - Added a
requireParentFragment()method which returns a@NonNull Fragmentor throws anIllegalStateException[ b/112103783 ]
Исправлены ошибки
- Fixed IllegalStateException: Failure saving state b/120814739
- Fragments being restored from saved instance state will now always receive a non-null
Bundle[ b/119794496 ] - Removed Fragments no longer reuse their
Lifecycleobject if re-added [ b/118880674 ]
Версия 1.1.0-alpha02
3 декабря 2018 г.
Новые функции
- FragmentScenario's Kotlin extensions now let you use a lambda for Fragment construction as an alternative to passing in a
FragmentFactoryinstance. ( aosp/812913 )
Исправлены ошибки
- Fixed an IllegalStateException when using nested Fragments on the back stack ( b/119256498 )
- Fixed crash when using
FragmentScenario.recreate()with aFragmentFactory( aosp/820540 ) - Fixed an issue where target Fragments were not accessible after the Fragment was removed ( aosp/807634 )
Версия 1.1.0-alpha01
November 5, 2018
This is the first release of the fragment-testing artifact and FragmentScenario which is built on top of the androidx.test:core APIs. See the Fragment testing documentation for more details.
Новые функции
- New FragmentScenario class for testing Fragments in isolation.
- You can now set a
FragmentFactoryon anyFragmentManagerto control how new Fragment instances are instantiated. - Added a new
by viewModels()Kotlin property delegate for retrieving ViewModels from a Fragment. - Pending input events (such as clicks) are now canceled in a Fragment's
onStop().
изменения API
- Significantly expanded the nullability annotations across the Fragment API surface.
Исправлены ошибки
- Fix an issue which caused Fragment operations to fail from within LiveData (b/77944637)
Известные проблемы
- Target Fragments cannot be accessed after a Fragment has been removed from the FragmentManager.
-
fragment-testingdepends onandroidx.test:core:1.0.0-beta01instead of the correctandroidx.test:core:1.0.0.