Kotlin
Kotlin Android Extensions
Поиск…
Вступление
У Kotlin есть встроенная вставка для Android, позволяющая пропускать ручную привязку или необходимость в таких фреймворках, как ButterKnife. Некоторые из преимуществ - более хороший синтаксис, более статическая типизация и, следовательно, менее подверженная ошибкам.
конфигурация
Начните с правильно настроенного проекта градиента .
В своем проекте-локальном (а не на верхнем уровне) build.gradle
добавьте объявление плагина расширения под вашим плагином Kotlin на уровне отступа верхнего уровня.
buildscript {
...
}
apply plugin: "com.android.application"
...
apply plugin: "kotlin-android"
apply plugin: "kotlin-android-extensions"
...
Использование представлений
Предполагая, что у нас есть активность с примером макета под названием activity_main.xml
:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/my_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="My button"/>
</LinearLayout>
Мы можем использовать расширения Kotlin для вызова кнопки без дополнительной привязки, например:
import kotlinx.android.synthetic.main.activity_main.my_button
class MainActivity: Activity() {
override fun onCreate(savedInstanceBundle: Bundle?) {
super.onCreate(savedInstanceBundle)
setContentView(R.layout.activity_main)
// my_button is already casted to a proper type of "Button"
// instead of being a "View"
my_button.setText("Kotlin rocks!")
}
}
Вы также можете импортировать все идентификаторы, появляющиеся в макете, с помощью *
нотации
// my_button can be used the same way as before
import kotlinx.android.synthetic.main.activity_main.*
Синтетические представления нельзя использовать за пределами Работы / Фрагменты / Представления с раздутым макетом:
import kotlinx.android.synthetic.main.activity_main.my_button
class NotAView {
init {
// This sample won't compile!
my_button.setText("Kotlin rocks!")
}
}
Ароматизаторы продуктов
Расширения Android также работают с несколькими продуктами Android Product Flavors. Например, если у нас есть build.gradle
в build.gradle
вот так:
android {
productFlavors {
paid {
...
}
free {
...
}
}
}
И, например, только бесплатный вкус имеет кнопку покупки:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<Button
android:id="@+id/buy_button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Buy full version"/>
</LinearLayout>
Мы можем напрямую связываться с ароматом:
import kotlinx.android.synthetic.free.main_activity.buy_button
Болезненный слушатель для получения уведомления, когда представление полностью нарисовано сейчас, настолько просто и удивительно с расширением Котлина
mView.afterMeasured {
// inside this block the view is completely drawn
// you can get view's height/width, it.height / it.width
}
Под капотом
inline fun View.afterMeasured(crossinline f: View.() -> Unit) {
viewTreeObserver.addOnGlobalLayoutListener(object : ViewTreeObserver.OnGlobalLayoutListener {
override fun onGlobalLayout() {
if (measuredHeight > 0 && measuredWidth > 0) {
viewTreeObserver.removeOnGlobalLayoutListener(this)
f()
}
}
})
}