《Jetpack Compose vs 传统 XML:一个纯色+渐变色背景的直观对比》

《Jetpack Compose vs 传统 XML:一个纯色+渐变色背景的直观对比》

引言

Android UI 开发正经历从 传统 XML + View 系统 到 Jetpack Compose 声明式 UI 的转型。

本文通过一个极简示例------展示一个纯色红色方块和一个垂直渐变(红→黄→白)方块,并排显示------来直观对比两种方式的代码结构、可读性、动态性和维护成本。

需求与最终效果

两个 50dp×50dp 的方块,水平排列,间距 10dp。

左侧:纯红色背景,白色文字"纯色"。

右侧:垂直渐变背景(红→黄→白),黑色文字"渐变色"。

整体距离顶部 48dp。

XML 实现(传统方式)

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"
    android:orientation="vertical"
    android:paddingTop="48dp">

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:gravity="center_vertical">

        <!-- 纯色背景方块 -->
        <FrameLayout
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:background="@android:color/holo_red_dark">

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:text="纯色"
                android:textColor="@android:color/white" />
        </FrameLayout>

        <!-- 间隔 -->
        <View
            android:layout_width="10dp"
            android:layout_height="0dp" />

        <!-- 渐变色背景方块 -->
        <FrameLayout
            android:layout_width="50dp"
            android:layout_height="50dp"
            android:background="@drawable/gradient_vertical">

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:text="渐变色"
                android:textColor="@android:color/black" />
        </FrameLayout>

    </LinearLayout>

</LinearLayout>

gradient_vertical.xml

xml 复制代码
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <gradient
        android:type="linear"
        android:angle="90"
        android:startColor="#FF0000"
        android:centerColor="#FFFF00"
        android:endColor="#FFFFFF" />
</shape>

Jetpack Compose 实现(现代方式)

kotlin 复制代码
package com.example.myapplication

import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.ui.Modifier
import androidx.compose.ui.unit.dp

import androidx.compose.foundation.background
import androidx.compose.foundation.layout.width
import androidx.compose.material3.Text
import androidx.compose.ui.Alignment
import androidx.compose.ui.graphics.Brush
import androidx.compose.ui.graphics.Color

class MainActivity : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            Column(modifier = Modifier.padding(top = 48.dp)) {
                // 纯色与渐变色背景示例
                Row {
                    // 纯色背景
                    Box(
                        modifier = Modifier
                            .size(50.dp)
                            .background(color = Color.Red)
                    ) {
                        Text("纯色", modifier = Modifier.align(Alignment.Center))
                    }
                    Spacer(modifier = Modifier.width(10.dp))
                    // 渐变色背景(垂直渐变)
                    val verticalGradientBrush = Brush.verticalGradient(
                        colors = listOf(
                            Color.Red,
                            Color.Yellow,
                            Color.White
                        )
                    )
                    Box(
                        modifier = Modifier
                            .size(50.dp)
                            .background(brush = verticalGradientBrush)
                    ) {
                        Text("渐变色", modifier = Modifier.align(Alignment.Center))
                    }
                }
            }
        }
    }
}

代码简洁,无需额外资源文件,渐变色可动态计算。

声明式编程,状态变化自动更新 UI。

场景化建议

新项目:首选 Compose ------ 现代化、高效、省去大量样板代码。

已有 XML 大型项目:渐进式引入 Compose(通过 ComposeView 混合使用),不必全量迁移。

对动画或复杂自定义布局:Compose 提供更直观的 API;XML 则更依赖 Canvas 或自定义 View。

总结

相同的 UI,两种完全不同的表达方式。XML 代表"过去十年"的稳定与成熟,而 Compose 代表"未来五年"的效率与革新。掌握两者,能让你在任何 Android 项目里游刃有余。强烈建议所有 Android 开发者开始学习 Compose,即使你现在仍在使用 XML。

相关推荐
帅次11 分钟前
Android 17 开发者实战:核心更新与应用场景落地指南
android·java·ios·android studio·iphone·android jetpack·webview
大鹏说大话23 分钟前
SQL 排序与分组实战:解决“分组后取最新数据“
android·java·数据库
搜狐技术产品小编20233 小时前
破局与重构:纯端侧 Android 自动化引擎的尝试与未来推演
android·运维·重构·自动化
码云骑士4 小时前
Android SystemServer启动过程
android·systemserver
weiggle5 小时前
第三篇:可组合函数(Composable)——Compose 的基石
android·前端
独隅5 小时前
Android Studio 接入多种不同 AI 大模型进行开发的全面详细指南(Android Studio+AI)
android·人工智能·android studio
夜微凉46 小时前
三、MySQL
android·数据库·mysql
我命由我123456 小时前
Android 开发问题:项目同时引入了两个包含相同类文件的库(AndroidX 库、旧版本支持库),导致了重复类错误
android·java·java-ee·android studio·android-studio·androidx·android runtime
anthonyzhu6 小时前
安卓Android studio panda run无法应用更新的问题
android·ide·android studio
jingling5557 小时前
Flutter | Dio网络请求实战
android·开发语言·前端·flutter