- Jetpack Compose это отдельный набор инструментов разработанный для упрощения разработки UI. Он соединяет модель реактивного программирования с лакончностью и лёгкостью использования языка программирования Kotlin
- ПРИМЕЧАНИЕ: Jetpack Compose в настоящее время находится в стадии ранних исследований, пре-альфа. Его API ещё не завершено и поэтому не следует использовать его в продакшене
- от переводчика: внизу статьи ссылка на видео с докладом о Jetpack Compose на конференции "Google I/O'19"
Основные принципы
Краткость и стиль Kotlin
- использует преимущества Kotlin — краткий, безопасный, и полностью совместимый с Java. Разработан для существенного уменьшения количества стандартного кода, что позволяет сфокусироваться на вашем коде, и помогает избежать внутренних ошибок классов
Декларативный
- полностью декларативное определение компонентов UI, включая отрисовку и создание собственных размещений. Просто описывает ваш UI как набор компонуемых функций, а платформа управляет оптимизацией UI и автоматически обновляет виджет-иерархию
Совместимый
- совместим с существующими виджетами так что можно смешивать и комбинировать, а также адаптироваться так как вам нужно имея прямой доступ ко всем API Android и Jetpack
Позволяет создавать красивые приложения
- поддерживает Material Design из коробки, а так же анимацию, так что позволяет легко создавать красивые приложения наполненные движением
Ускоряет разработку
- ускорьте разработку через написание меньшего количества кода и использование инструментов на подобие Apply Changes и через просмотр изменений в реальном времени
Быстрый обзор
- Jetpack Compose разработан на базе Android Open Source Project. Он содержит два главных компонента:
- UI-библиотеку Compose, которая содержит основной набор инструментов UI т.е. разметку, поля ввода, текстовые поля, анимации, стили, виджеты и графику
- компилятор Compose, собственный Kotlin-компилируемый плагин содержащий функции компоновки и автоматически обновляющий UI-иерархию
- Compose-приложение состоит из компонуемых функций которые трансформируют данные приложения в UI-иерархию. Функции это все что вам необходимо для создания нового UI-компонента
-
для создания компонуемой функции, просто добавьте аннотацию @Composable к имени функции. Под капотом, Compose использует собственный Kotlin-компилируемый плагин так что когда изменяются фоновые данные, компонуемые функции могут быть вызваны повторно для генерации обновлений UI-иерархии. Простой пример ниже печатает строку на экране:
import androidx.compose.* import androidx.ui.core.* @Composable fun Greeting(name: String) { Text ("Hello $name!") }
- API библиотеки располагается в AOSP-директории по адресу frameworks/support/ui. Compose-компилятор и runtime-код доступен по следующей ссылке frameworks/support/compose
Библиотека Compose UI
- библиотека Jetpack Compose UI содержит следующие модули:
- android-text/ — специфические для Android имплементации работы с текстом
- android-view/ — обёртки и адаптеры для существующих виджетов Android
- animation/ — компоненты анимации
- animation-core/ — внутренние компоненты системы анимации
- core/ — базовые классы системы включающие примитивы, графику и рисование
- framework/ — базовые компоненты предоставляемые системой, используемые как строительные блоки. Содержит классы Draw, Layout, Text и др.
- layout/ — базовые компоненты разметки
- material/ — набор UI-компонентов созданных с учётом спецификации Material Design
- platform/ — внутренние имплементации позволяющие отделить Android-имплементацию от тестов на стороне хоста
- test/ — тестирование фреймворка
- text/ — текстовый движок
От переводчика
Видео доклада с рассказом о Jetpack Compose на "Google I/O'19"
Автор: ssurrokk