# StateFrameLayout
**Repository Path**: SY1925/StateFrameLayout
## Basic Information
- **Project Name**: StateFrameLayout
- **Description**: Android 状态切换布局,可自定义Loading、Empty、NetError、Success四种状态样式,自带状态恢复
- **Primary Language**: Android
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 11
- **Created**: 2018-01-17
- **Last Updated**: 2020-12-19
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# StateFrameLayout
## 简介
项目中经常遇到这样一种情况,新打开的界面需要加载数据,存在多种状态的结果,需要根据不同结果展示界面,这个过程归纳起来可以分为五种状态:**初始状态、请求状态、空数据状态、网络错误状态、成功请求状态。** 如果多个界面都存在这个流程,那么封装整个过程的调用就很有必要了,既可以简化调用过程,又可以很方便的管理整个流程。
`StateFrameLayout` 继承自`FrameLayout`,内部实现了一句代码切换各种状态的功能(各状态的布局均需要在xml指定,具有高度定制性),并且内部实现了状态缓存,无需担心内存回收后重新打开界面会导致状态被重置(可打开手机开发者选项中的“不保留活动”来验证)。
## 使用
Gradle中引用
```
compile 'com.lwkandroid:StateFrameLayout:1.0.1'
```
### xml中定义
```
```
**备注:** 此外,对于空数据和网络错误的状态提供了**重试**接口,需要在空数据或网络错误布局中指定触发的view对应的id:`android:id="@id/id_sfl_empty_retry"`或`android:id="@id/id_sfl_net_error_retry"`
### 代码中使用
**五种状态:**
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);
//设置网络错误重试监听
mStateFrameLayout.setOnNetErrorRetryListener(new StateFrameLayout.OnNetErrorRetryListener()
{
@Override
public void onNetErrorRetry()
{
//TODO 在这里相应重试操作
}
});
//设置空数据重试监听
mStateFrameLayout.setOnEmptyRetryListener(new StateFrameLayout.OnEmptyRetryListener()
{
@Override
public void onEmptyRetry()
{
//TODO 在这里相应重试操作
}
});
```
## 效果图




### 参考
MaterialPageStateLayout: https://github.com/Syehunter/MaterialPageStateLayout
感谢所有为开源做出贡献的人们!