Yes, there is documentation and tons of sample apps out there. But they are all in a top down approach, meaning they give you the final result of how to use it first, and never tells you why and what is behind the scenes.
I will fix that in this article, and present a bottom up approach which leads to much better and deeper understanding.
First, at the bottom of things, we need to define what is ViewModel.
It is quite common in Android that we need some expandable widget to show and hide information. This is my first attempt, note that this is only a “sketch”, and I intentionally leave some room for improvement.
One interesting detail worth mentioning is how the animation is done. I used the reverse() function to play animation backwards in order to achieve a smooth and continuous feel.
Here is the code:
by lazy is implemented by using the “property delegation” in Kotlin. But if you look into the source code and trying to understand what is going on, it can be confusing, because it is full of locks and generics and where’s the `getValue()`` function they say that the delegation must implement??
In the handmade spirit (best way to learn is by doing it yourself), let’s do a stripped down version ourselves.
Compile time constant const val NAME = "Guowei" fun main() { tv.text = NAME } After compile it will (almost) look like this:
// Imaginary code fun main() { tv.text = "Guowei" } inline function We can do similar things to functions, by adding keyword inline.
inline fun hello() { println("hello") } fun main() { hello() } So at compile time, the hello() function will be copied to the calling place:
I was bored at night so decided to peek into the guts of how Android’s View Binding works. To my suprise the generated code is extremely simple.
Imagine you have a list_item.xml file and it looks like this:
<LinearLayout> <ImageView android:id="@+id/icon" /> <TextView android:id="@+id/name" /> </LinearLayout> Then the generated class will be like this:
public final class ListItemBinding implements ViewBinding { private final LinearLayout rootView; public final ImageView icon; public final TextView name; // Notice: private constructor private ListItemBinding(LinearLayout rootView, ImageView icon, TextView name) { this.