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...

相关推荐
IT枫斗者4 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
AI自动化工坊8 小时前
Late框架技术深度解析:5GB VRAM实现10倍AI编码效率的工程架构
人工智能·5g·架构·ai编程·late
空中海8 小时前
第六篇:架构篇 — 微服务、部署、高并发与专家级能力
微服务·云原生·架构
Wave8458 小时前
基于 STM32 + ESP8266 + W25Q64 的双核 OTA 底层架构总结
stm32·嵌入式硬件·架构
yongyoudayee9 小时前
CRM架构演进:从记录系统到执行引擎的技术解析
架构
源码宝10 小时前
基于 SpringBoot + Vue 的医院随访系统:技术架构与功能实现
java·vue.js·spring boot·架构·源码·随访系统·随访管理
有马贵将10 小时前
【5】微前端知识点总结
前端·架构
饭小猿人11 小时前
Android 腾讯X5WebView如何禁止系统自带剪切板和自定义剪切板视图
android·java
_李小白11 小时前
【android opencv学习笔记】Day 8: remap(像素位置重映射)
android·opencv·学习
美狐美颜SDK开放平台11 小时前
多场景美颜SDK解决方案:直播APP(iOS/安卓)开发接入详解
android·人工智能·ios·音视频·美颜sdk·第三方美颜sdk·短视频美颜sdk