亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android JetpackCompose使用教程講解

 更新時間:2022年10月10日 09:45:24   作者:知奕奕  
在今年的Google/IO大會上,亮相了一個全新的 Android 原生 UI 開發(fā)框架-Jetpack Compose, 與蘋果的SwiftIUI一樣,Jetpack Compose是一個聲明式的UI框架

概況

compose 摒棄了原生開發(fā)模式中的 xml,代碼結(jié)構(gòu)類似于 flutter

compose 僅支持 kotlin,雖然這玩意語法糖多但是也不難學

compose 可以通過極短的代碼行數(shù)構(gòu)建完善頁面

開啟新工程

首先請去 android 官網(wǎng)下載 android studio;

官網(wǎng)下載速度是正常的,別擔心;

之后根據(jù)提示安裝 android sdk 以及 ndk,如果必須的話你還可以裝一個模擬器;

把手機直接連接到電腦上就可以進行真機調(diào)試了(記得把手機的調(diào)試模式打開);

一切就緒,打開 android studio,點擊 file->new->new project->empty compose activity

稍等一會,工程很快構(gòu)建完畢

文件結(jié)構(gòu)

創(chuàng)建新工程后,默認會打開 MainActivity.kt 文件,這是我們的主頁面

根結(jié)構(gòu)

class MainActivity2 : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            ComposeDemoTheme {
                // A surface container using the 'background' color from the theme
                Surface(
                    modifier = Modifier.fillMaxSize(),
                    color = MaterialTheme.colors.background
                ) {
                    Greeting("Android")
                }
            }
        }
    }
}

setContent 在這里寫入頁面內(nèi)容,通過一個個組件逐步構(gòu)造

ComposeDemoTheme 表示根據(jù)默認主題包中的內(nèi)容進行設(shè)置(默認主題包就在和 mainactivity 同級別的 themes 文件夾)

Surface 構(gòu)建頁面表面的一個組件

拆分方法

為了避免組件過度嵌套導致產(chǎn)生”死亡三角”,務(wù)必記得把必要的組件拆出來作為一個單獨的方法寫!

方法寫在本 activity 的 class 內(nèi)部,那么同文件夾內(nèi)的其他 kotlin 文件的方法都不會沖突;

若寫在 class 外(默認),則不同文件夾將可能會發(fā)生名稱重復(fù)的沖突;

@Composable
fun Greeting(name: String) {
    Text(text = "Hello $name!")
}

加了 @Composable 注解的方法,表示這是一個組件,該注解必須添加!

該組件方法內(nèi)使用了 text

@Preview(showBackground = true)
@Composable
fun DefaultPreview() {
    ComposeDemoTheme {
        Greeting("Android")
    }
}

compose 內(nèi)置了一個臨時預(yù)覽機制,即 preview;

加了@Preview 注解的代碼表示該代碼將作為臨時預(yù)覽而展示;

臨時預(yù)覽的方法不會對最終編譯生成的結(jié)果產(chǎn)生任何影響?。?!

點擊代碼框右上角的 split,即可拆分為 代碼+預(yù)覽 布局

一切就緒后點擊 build,即可渲染預(yù)覽頁面

官方四節(jié)課教程細節(jié)剖析

官方教程地址:https://developer.android.google.cn/jetpack/compose/tutorial

data class

data class 類似于 typescript 的 interface,可以理解為定義了一個對象;

msg: Message 直接將 Message 作為一個類型來使用;

之后直接在 setContent 里面調(diào)用組件即可!

class MainActivity : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            MessageCard(Message("Android", "Jetpack Compose"))
        }
    }
}
data class Message(val author: String, val body: String)
@Composable
fun MessageCard(msg: Message) {
    Text(text = msg.author)
    Text(text = msg.body)
}

組件代碼翻譯

@Composable
fun MessageCard(msg: Message) {
    // 使用padding內(nèi)部撐開,all表示四周撐開
    Row(modifier = Modifier.padding(all = 8.dp)) {
        Image(
            painter = painterResource(R.drawable.profile_picture),
            contentDescription = "Contact profile picture",
            modifier = Modifier
                // 設(shè)置該組件的大小為40dp
                .size(40.dp)
                // 把圖片變成圓形的
                .clip(CircleShape)
        )
        // 在image和column之間添加一個水平空格!
        Spacer(modifier = Modifier.width(8.dp))
        Column {
            Text(text = msg.author)
            // 這里添加的是一個垂直空格!
            Spacer(modifier = Modifier.height(4.dp))
            Text(text = msg.body)
        }
    }
}

單例類

教程中我們用到了 SampleData,然而由于外網(wǎng)無法訪問,數(shù)據(jù)集自然下載不了,但是我們可以簡單的模擬一個數(shù)據(jù)集:

object 創(chuàng)建單例類;

listOf 模擬列表!

object SampleData {
    val conversationData = listOf(
        Message(
            "jack",
            "test name"
        ),
        Message(
            "fakeman",
            "idaofihoeqh iodhoe hfqow " +
                    "ehfsdla hfioeh fowh fldsah lfhoqei hfo" +
                    " hod hsafohewqgjlfjdsnvc,mxbg kjwfhw" +
                    " hoe hfsdhf kwejashd has jhdqwo oiadhf oiha " +
                    "oi dosi awqi jiojagakfjk ladfi jslkf h" +
                    "lwkeh flkadsh flah fioewhfoadshlfhsa"
        ),
    )
}

適配器的替代品

// by表示使用委托,設(shè)置一個針對于本compose的全局狀態(tài)
// 可以理解為isExpanded是一個全局變量!
var isExpanded by remember { mutableStateOf(false) }
// clickable設(shè)置column中項目是否可以點擊,以及點擊后執(zhí)行的代碼
// 代碼和vue類似,點一下就反轉(zhuǎn)一下,達到開啟和收回的效果
Column(modifier = Modifier.clickable { isExpanded = !isExpanded }) {
    ...
    Surface(
        shape = MaterialTheme.shapes.medium,
        elevation = 1.dp,
    ) {
        Text(
            text = msg.body,
            modifier = Modifier.padding(all = 4.dp),
            // 判斷全局狀態(tài)isExpanded值
            // 如果isExpanded為true,那么顯示所有行(即展開)
            // 如果isExpanded為false,那么僅顯示一行(即收縮)
            maxLines = if (isExpanded) Int.MAX_VALUE else 1,
            style = MaterialTheme.typography.body2
        )
    }
}

簡單小動畫

// 同樣的委托,注冊全局動畫狀態(tài)
// 由于內(nèi)容過于龐雜,后續(xù)將會詳細介紹動畫狀態(tài)是個什么東西!
val surfaceColor by animateColorAsState(
    if (isExpanded) MaterialTheme.colors.primary else MaterialTheme.colors.surface,
)

到此這篇關(guān)于Android JetpackCompose使用教程講解的文章就介紹到這了,更多相關(guān)Android JetpackCompose內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論