“Android’s modern toolkit for building native UI”
Jetpack Compose simplifies and accelerates UI development on Android. Quickly bring your app to life with less code, powerful tools, and intuitive Kotlin APIs.
While compose is concentrated on a UI Toolkit for Android, there was a mysterious commit in AOSP gerrit , mentioned “Desktop UI work - basic infra.” This creates a lot of attention among developers, since this is one the most popular feature for mobile developers, which is Multi Platform, writing the code once and run it everywhere. Flutter was launched in May 2017, which is one of the modern framework that supports Multi Platform.
Trying the mysterious commit Link to heading
So I was interested to experiment this commit made in AOSP gerrit, which includes sample for running desktop app via Compose. Compose was developed as part of framework/base repo in the gerrit.
compose-desktop is backed up by skia.
Skia is an open source 2D graphics library which provides common APIs that work across a variety of hardware and software platforms. It serves as the graphics engine for Google Chrome and Chrome OS, Android, Flutter, Mozilla Firefox and Firefox OS, and many other products.
Also, using skija on top of skia
A modern graphic toolkit allows you to build all sorts of graphical UIs without being constrained by existing frameworks
The problem was skija currently supports only MacOS. Since I don’t have a machine running MacOS, this experiment was on hold for some time. Later on June 27th jetbrains released a new library skiko, which provides KMP(KotlinMultiPlatform) support for skija.
So with a little hack (Using skiko lib instead of skija) , I was able to run the compose-desktop samples, and below is screencast of it,
Note : Created a new Android project and copy pasted the same compose fun to run in Android.
Setup Link to heading
- Start by setting up repository using a this guide.
- Once the
repo sync
is over, runcd frameworks/support/ui/
- Here, it is recommended to run custom build of Android Studio provided within this repository. Run
./studiow
to start custom build of Android Studio. - Let Android Studio sync the project.
Using skiko lib instead of skija Link to heading
- Build and publish skiko to local maven using the instructions here
- Include skiko as dependency in
buiild.gradle(ui-desktop)
asapi("org.jetbrains.skiko:skiko-jvm-runtime-linux:0.1-SNAPSHOT")
- Modify
androidx/ui/desktop/ComposeInit.kt
fromLibrary.load("/", "skija")
toLibrary.load("/", "skiko")
Run Link to heading
- Run the gradle task
run
in compose-desktop-sample