【亲测免费】 Compose Collapsing Toolbar 开源项目教程
2026-01-18 09:45:29作者:袁立春Spencer
1. 项目的目录结构及介绍
compose-collapsing-toolbar/
├── README.md
├── build.gradle
├── settings.gradle
├── app/
│ ├── build.gradle
│ ├── src/
│ │ ├── main/
│ │ │ ├── java/
│ │ │ │ └── com/
│ │ │ │ └── onebone/
│ │ │ │ └── collapsingtoolbar/
│ │ │ │ ├── MainActivity.kt
│ │ │ │ ├── CollapsingToolbar.kt
│ │ │ │ └── ...
│ │ │ └── res/
│ │ │ ├── drawable/
│ │ │ ├── layout/
│ │ │ ├── mipmap/
│ │ │ └── values/
│ │ └── test/
│ │ └── ...
│ └── ...
└── ...
目录结构介绍
- README.md: 项目说明文件,包含项目的基本介绍和使用说明。
- build.gradle: 项目的根构建文件,包含项目级别的配置。
- settings.gradle: 项目的设置文件,包含模块的配置。
- app/: 应用模块目录。
- build.gradle: 应用模块的构建文件,包含模块级别的配置。
- src/main/java/com/onebone/collapsingtoolbar/: 应用的主要代码目录,包含主要的Kotlin文件。
- MainActivity.kt: 应用的主活动文件。
- CollapsingToolbar.kt: 实现折叠工具栏的主要文件。
- src/main/res/: 应用的资源目录,包含布局、图片和字符串等资源。
2. 项目的启动文件介绍
MainActivity.kt
package com.onebone.collapsingtoolbar
import android.os.Bundle
import androidx.activity.ComponentActivity
import androidx.activity.compose.setContent
import androidx.compose.material.MaterialTheme
import androidx.compose.material.Surface
import androidx.compose.material.Text
import androidx.compose.runtime.Composable
import androidx.compose.ui.tooling.preview.Preview
import com.onebone.collapsingtoolbar.ui.theme.ComposeCollapsingToolbarTheme
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
ComposeCollapsingToolbarTheme {
// A surface container using the 'background' color from the theme
Surface(color = MaterialTheme.colors.background) {
Greeting("Android")
}
}
}
}
}
@Composable
fun Greeting(name: String) {
Text(text = "Hello $name!")
}
@Preview(showBackground = true)
@Composable
fun DefaultPreview() {
ComposeCollapsingToolbarTheme {
Greeting("Android")
}
}
文件介绍
- MainActivity.kt: 这是应用的主活动文件,继承自
ComponentActivity。在onCreate方法中,设置了应用的内容视图,并应用了主题。Greeting是一个简单的 Composable 函数,用于显示文本。
3. 项目的配置文件介绍
build.gradle (项目根目录)
// 根目录的 build.gradle 文件
buildscript {
ext.kotlin_version = "1.5.21"
repositories {
google()
mavenCentral()
}
dependencies {
classpath "com.android.tools.build:gradle:7.0.0"
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
}
}
allprojects {
repositories {
google()
mavenCentral()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
build.gradle (app 模块)
// app 模块的 build.gradle 文件
plugins {
id 'com.android.application'
id 'kotlin-android'
}
android {
登录后查看全文
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
514
3.69 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
873
532
Ascend Extension for PyTorch
Python
315
358
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
333
152
暂无简介
Dart
756
181
React Native鸿蒙化仓库
JavaScript
298
347
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
110
126
仓颉编译器源码及 cjdb 调试工具。
C++
152
885