小言_互联网的博客

Android Jetpack Compose学习(一)—— Jetpack compose入门

374人阅读  评论(0)

Jetpack compose简介

Jetpack compose是Google推出的用于构建原生Android UI的一个工具包,它使用了大量的Kotlin语言特性,其开发方式与Flutter很类似,可以在很大程度上简化Android UI的开发。

目前(2021年5月31日)Jetpack compose的版本为Beta版,还未发布1.0正式版。

需要注意的是:只能使用Kotlin语言来做基于Jetpack compose的开发

Jetpack compose起步

目前(2021年5月31日),要在Android项目中使用Jetpack compose来开发原生UI,必须使用Android Studio Canary版本,在这里可以下载到Canary版本。

要想在Android项目中使用Jetpack compose,需要如下两个步骤(确保已经创建了基于Kotlin的Android工程):

  1. 在项目根目录下的build.gradle文件中定义compose版本:
buildscript {
    ext.kotlin_version = '1.4.31'
    ext.compose_version = '1.0.0-beta03'

    ...
}
  1. 在module根目录下的build.gradle文件中加入如下配置(注意应用的最低API级别为21):
plugins {
    id 'com.android.application'
    id 'kotlin-android'
    id 'org.jetbrains.kotlin.android'     // 1
}


android {
	
	...

	defaultConfig {
		...
        minSdkVersion 21 
    }
    
	buildFeatures {           // 2
        compose true
    }

    composeOptions {        // 3
        kotlinCompilerVersion kotlin_version
        kotlinCompilerExtensionVersion compose_version
    }
}

dependencies {    // 4 引入Jetpack compose相关依赖库
	implementation "androidx.compose.ui:ui:$compose_version"
    // Tooling support (Previews, etc.)
    implementation "androidx.compose.ui:ui-tooling:$compose_version"
    // Foundation (Border, Background, Box, Image, Scroll, shapes, animations, etc.)
    implementation "androidx.compose.foundation:foundation:$compose_version"
    // Material Design
    implementation "androidx.compose.material:material:$compose_version"
    // Material design icons
    implementation "androidx.compose.material:material-icons-core:$compose_version"
    implementation "androidx.compose.material:material-icons-extended:$compose_version"
    // Integration with observables
    implementation "androidx.compose.runtime:runtime-livedata:$compose_version"
    implementation "androidx.compose.runtime:runtime-rxjava2:$compose_version"

    // UI Tests
    androidTestImplementation "androidx.compose.ui:ui-test-junit4:$compose_version"
	
	implementation "androidx.activity:activity-compose:1.3.0-alpha05"
}

一个最简单的Jetpack compose程序

下面的代码展示了一个最简单的使用Jetpack compose开发的UI界面:

import android.os.Bundle
import androidx.activity.compose.setContent
import androidx.appcompat.app.AppCompatActivity
import androidx.compose.material.Text

class MainActivity : AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            Text("hello world")
        }
    }
}

上面的代码运行在手机上如下图所示:

可以看到Jetpack compose完全抛弃了之前我们使用的XML开发布局的那一套,完全使用Kotlin代码即可开发UI了。

本篇暂时记录到此,后续会继续记录更多关于Jetpack compose的知识点。


转载:https://blog.csdn.net/yubo_725/article/details/117416004
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场