# StateFrameLayout **Repository Path**: huluhong/StateFrameLayout ## Basic Information - **Project Name**: StateFrameLayout - **Description**: Android 状态切换布局,可自定义Loading、Empty、NetError、Success四种状态样式,自带状态恢复 - **Primary Language**: Android - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 11 - **Created**: 2019-03-06 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # StateFrameLayout ## 简介 项目中经常遇到这样一种情况,新打开的界面需要加载数据,存在多种状态的结果,需要根据不同结果展示界面,这个过程归纳起来可以分为五种状态:**初始状态、请求状态、空数据状态、网络错误状态、成功请求状态。** 如果多个界面都存在这个流程,那么封装整个过程的调用就很有必要了,既可以简化调用过程,又可以很方便的管理整个流程。 `StateFrameLayout` 继承自`FrameLayout`,内部实现了一句代码切换各种状态的功能(除了最终请求成功的视图需要在xml中指定,其余各状态的视图可在xml或代码中指定,具有高度定制性),并且内部实现了状态缓存,无需担心内存回收后重新打开界面会导致状态被重置(可打开手机开发者选项中的“不保留活动”来验证)。 ## 使用 【最新版本号以[这里](https://github.com/Vanish136/StateFrameLayout/releases)为准】 Gradle中引用 ``` #last-version请查看上面的最新版本号 #AndroidStudio3.0以下 compile 'com.lwkandroid:StateFrameLayout:last-version' #AndroidStudio3.0以上 implemetation 'com.lwkandroid:StateFrameLayout:last-version' ``` ### xml中定义 ``` ```
### 代码中使用 **五种状态:**
1. `StateFrameLayout.INIT`:初始状态,所有布局隐藏,默认切换的状态
2. `StateFrameLayout.LOADING`:只显示请求Loading布局
3. `StateFrameLayout.EMPTY`:只显示空数据布局
4. `StateFrameLayout.NET_ERROR`:只显示网络错误布局
5. `StateFrameLayout.SUCCESS`:只显示请求成功后的内容布局
``` StateFrameLayout mStateFrameLayout = (StateFrameLayout) findViewById(R.id.stateLayout); //切换各种状态 mStateFrameLayout.changeState(上面五种状态中任何一个); //是否在展示内容布局的时候开启动画(200ms的Alpha动画) mStateFrameLayout.enableContentAnim(true); //设置网络错误重试监听【不传netRetryId的话需要在对应布局中设置触发控件的id为android:id="@id/id_sfl_net_error_retry"】 mStateFrameLayout.setOnNetErrorRetryListener(int netRetryId,new StateFrameLayout.OnNetErrorRetryListener() { @Override public void onNetErrorRetry() { //TODO 在这里相应重试操作 } }); //设置空数据重试监听【不传emptyRetryId的话需要在对应布局中设置触发控件的id为android:id="@id/id_sfl_empty_retry"】 mStateFrameLayout.setOnEmptyRetryListener(int emptyRetryId,new StateFrameLayout.OnEmptyRetryListener() { @Override public void onEmptyRetry() { //TODO 在这里相应重试操作 } }); ```
## 效果图 ![](https://github.com/Vanish136/StateFrameLayout/raw/master/pics/sample01.png) ![](https://github.com/Vanish136/StateFrameLayout/raw/master/pics/sample02.png) ![](https://github.com/Vanish136/StateFrameLayout/raw/master/pics/sample03.png) ![](https://github.com/Vanish136/StateFrameLayout/raw/master/pics/sample04.png)
### 混淆配置 ``` -dontwarn com.lwkandroid.widget.stateframelayout.** -keep class com.lwkandroid.widget.stateframelayout.**{*;} ```
### 参考 MaterialPageStateLayout: https://github.com/Syehunter/MaterialPageStateLayout
感谢所有为开源做出贡献的人们!