《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。

相关推荐
陆业聪2 小时前
AI编码提效实战:Skill、Rule与上下文工程
android·ai编程·claude code
imuliuliang2 小时前
Laravel 9.x核心特性全解析
android
赏金术士2 小时前
Kotlin 从入门到进阶 之异常与标准库(八)
android·开发语言·kotlin
我这一生如履薄冰~2 小时前
flutter开发适配底部导航条样式
android·flutter
神探小白牙2 小时前
echarts环形图自定义
android·前端·echarts
Front思2 小时前
安卓证书申请 + iOS 证书申请(含 Windows 无 Mac 方案)+ HBuilderX 云打包配置
android·macos·ios
ii_best2 小时前
ios/安卓脚本工具开发按键精灵脚本常见运行时错误与解决方法
android·ios·自动化
张风捷特烈2 小时前
状态管理大乱斗#07 | Signals 源码评析 - 暗流涌动
android·前端·flutter