Compose + Mvi 架构的玩android 项目,请尝鲜

文章目录

  • 前言
  • 玩android项目的介绍
  • 效果截图
  • 总结

一、前言

记得拉倒底看效果图。

android 这些年的发展是很快的,特别是架构层面的转变,从mvc 到 mvp 到 mvvm 再到现在的mvi。

这些转变呢,核心目的就是一个提高开发效率,现在对于一个成熟的开发人员,如果使用好的架构,再加上ai,如虎添翼,至少能节省60%的开发时间,甚至更多。

这里就将用最新的mvi 架构,通过 compose + okhttp3 + retrofit2 + stateFlow + viewModel + flow + navigation 来实现一个玩android 项目,整个项目只有一个Activity,其他子页面都是用 Compose实现页面

最后呢,我会把应用上传到github上,大家可以下载学习。另外最后有页面的效果截图,看完再看代码,这样会更加直观。

二、介绍整个项目

1、开发工具
cpp 复制代码
Android Studio Otter | 2025.2.1
2、整个项目的组成部分
cpp 复制代码
1、欢迎页面
2、注册登录模块
3、主页面
4、首页
5、广场
6、导航
7、我的
8、设置
9、退出登录
10、动画等
3、网络请求
kotlin 复制代码
这块就是鸿洋提供的接口,也就是玩android对应的开放接口。

/**
 * 玩Android API服务
 */
interface ApiService {
    /**
     * 用户注册
     * @param username 用户名
     * @param password 密码
     * @param repassword 确认密码
     */
    @FormUrlEncoded
    @POST("user/register")
    suspend fun register(
        @Field("username") username: String,
        @Field("password") password: String,
        @Field("repassword") repassword: String
    ): BaseResponse<Any>
    
    /**
     * 用户登录
     * @param username 用户名
     * @param password 密码
     */
    @FormUrlEncoded
    @POST("user/login")
    suspend fun login(
        @Field("username") username: String,
        @Field("password") password: String
    ): BaseResponse<Any>
    ...
 }
4、第三方库
kotlin 复制代码
    // Coil for image loading
    implementation(libs.coil.compose)
    // WebView support
    implementation("androidx.webkit:webkit:1.9.0")
    // Retrofit
    implementation(libs.retrofit)
    implementation(libs.converter.gson)
    // OkHttp
    implementation(libs.okhttp)
    implementation(libs.logging.interceptor)
    // Kotlin Coroutines
    implementation(libs.kotlinx.coroutines.android)
    //其他都是 androidx 的就不一一列举
cpp 复制代码
核心点:
1、PullRefreshLazyColumn 是居于pullrefresh 封装来的,
   因为要进行下拉刷新和上拉加载更多。

2、路由主要是使用 androidx-navigation-compose,
   实现单Activity多Compose页面的跳转与参数传递。

3、网络请求下来的数据,主要是通过flow 来进行发射和接收。

4、页面数据主要是通过ViewModel里面的 StateFlow 来存储,
   并使用 Intent 驱动 ViewModel 中的 StateFlow 状态变化,确保UI状态可预测。

5、图片加载主要是通过Coil。

三、效果截图

视频演示:live.csdn.net/v/506678. 因为是as录制的,只是看个大概,有些细节还是自己运行一下,看得更清晰。

整个项目开发过程中遇到不合理的地方,也进行了优化重构,然后再整理成文章实属不易哈。不过写完还是挺欣慰的。

以上就是全部,我将整项目放到github上,后面有新增,也会一并上传。

最后献上我的个人v,解答关于 android 相关的东西,包括项目中的问题,还有最新的技术点。hmssz1

技术的道路很长,与同行者一起探讨,往往能事半功倍。

以上代码地址:github.com/shenshizhon...

总结

1、介绍玩 android 整个项目

2、项目中的重点内容

3、效果截图

如果对你有一点点帮助,那是值得高兴的事情。:)

我的csdn:blog.csdn.net/shenshizhon...

我的掘金:juejin.cn/user/428855...

相关推荐
小程故事多_806 分钟前
深度搜索Agent架构全解析:从入门到进阶,解锁复杂问题求解密码
人工智能·架构·aigc
晚霞的不甘25 分钟前
Flutter for OpenHarmony从零到一:构建《冰火人》双人合作闯关游戏
android·flutter·游戏·前端框架·全文检索·交互
2601_9498333928 分钟前
flutter_for_openharmony口腔护理app实战+饮食记录实现
android·javascript·flutter
独自破碎E31 分钟前
【滑动窗口+字符计数数组】LCR_014_字符串的排列
android·java·开发语言
stevenzqzq37 分钟前
compose 中 align和Arrangement的区别
android·compose
VincentWei951 小时前
Compose:MutableState 和 mutableStateOf
android
jian110581 小时前
Android studio配置flutter,mac Android studio 发现苹果手机设备
android·flutter·android studio
●VON1 小时前
React Native for OpenHarmony:项目目录结构与跨平台构建流程详解
javascript·学习·react native·react.js·架构·跨平台·von
Gary董1 小时前
高并发的微服务架构如何设计
微服务·云原生·架构
ujainu1 小时前
Flutter + OpenHarmony 实战:《圆环跳跃》——完整游戏架构与视觉优化
flutter·游戏·架构·openharmony