自定义多状态View

作者: 续写经典 | 来源:发表于2016-01-18 12:31 被阅读1400次

一个支持多种状态的自定义View,可以方便的切换到:

  • 加载中视图
  • 错误视图
  • 空数据视图
  • 网络异常视图
  • 内容视图

GitHub源码地址

示例apk下载

使用

dependencies {
    compile 'com.classic.common:multiple-status-view:1.4'
}

示例

<com.classic.common.MultipleStatusView
    android:id="@+id/multiple_status_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:loadingView="@layout/custom_loading_view"
    app:emptyView="@layout/custom_empty_view"
    app:errorView="@layout/custom_error_view"
    app:noNetworkView="@layout/custom_no_network_view"
    app:contentView="@layout/main_content"/>
MultipleStatusView multipleStatusView = (MultipleStatusView) findViewById(R.id.multiple_status_view);

//显示加载中视图
multipleStatusView.showLoading();
// multipleStatusView.showLoading(R.layout.xxx, layoutParams);
// multipleStatusView.showLoading(customView, layoutParams);

//显示空视图
multipleStatusView.showEmpty();
// multipleStatusView.showEmpty(R.layout.xxx, layoutParams);
// multipleStatusView.showEmpty(customView, layoutParams);

//显示错误视图
multipleStatusView.showError();
// multipleStatusView.showError(R.layout.xxx, layoutParams);
// multipleStatusView.showError(customView, layoutParams);

//显示无网络视图
multipleStatusView.showNoNetwork();
// multipleStatusView.showNoNetwork(R.layout.xxx, layoutParams);
// multipleStatusView.showNoNetwork(customView, layoutParams);

//显示内容视图
multipleStatusView.showContent();

//设置重试视图点击事件
multipleStatusView.setOnRetryClickListener(onRetryClickListener);

/**
* 获取当前view的状态
*      MultipleStatusView.STATUS_LOADING   //当前为加载中视图
*      MultipleStatusView.STATUS_EMPTY     //当前为空视图
*      MultipleStatusView.STATUS_ERROR     //当前为错误视图
*      MultipleStatusView.STATUS_NO_NETWORK//当前为无网络视图
*      MultipleStatusView.STATUS_CONTENT   //当前为内容视图
*/
int viewStatus = multipleStatusView.getViewStatus();

MultipleStatusView 继承自 RelativeLayout,所以内容视图也可以直接写在 MultipleStatusView 内部

<com.classic.common.MultipleStatusView
    android:id="@+id/multiple_status_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:emptyView="@layout/custom_empty_view"
    app:errorView="@layout/custom_error_view"
    app:loadingView="@layout/custom_loading_view"
    app:noNetworkView="@layout/custom_no_network_view">

    <ImageView
        android:id="@+id/image"
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:layout_centerVertical="true"
        android:layout_marginLeft="24dp"
        android:layout_marginRight="16dp"
        android:src="@drawable/test"/>

    <TextView
        android:id="@+id/text1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignTop="@id/image"
        android:layout_toRightOf="@id/image"
        android:text="内容视图111111"/>

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBottom="@id/image"
        android:layout_toRightOf="@id/image"
        android:text="内容视图222222"/>

</com.classic.common.MultipleStatusView>

注意事项

1. 如果使用自定义属性

app:emptyView="@layout/..."
app:errorView="@layout/..."
app:loadingView="@layout/..."
app:noNetworkView="@layout/..."

需要设置:

  • 加载中视图的id必须为:loading_view
  • 空视图的id必须为:empty_view
  • 错误视图的id必须为:error_view
  • 无网络视图的id必须为:no_network_view

2. 如果需要点击某个 view 进行重试, 需要设置:

  • 空视图内对应的view id:empty_retry_view
  • 错误视图内对应的view id:error_retry_view
  • 无网络视图内对应的view id:no_network_retry_view

3. 使用 new 关键字创建自定义视图时,请设置 id

TextView tv = new TextView(getApplicationContext());
tv.setId(Utils.generateViewId());
tv.setText(text);

更多使用方法详见 demo 示例:

相关文章

网友评论

  • _cxcc:作者你好,我也出现了跟8楼同样的情况,我是1.2版本,之前没有问题,最近出现大量空指针把崩溃; 全部都是在Fragment里面;java.lang.NullPointerException

    Attempt to invoke virtual method 'void com.classic.common.MultipleStatusView.showContent()' on a null object reference
    爱生活的小水缸:你好 我也是1.2版本的 也是出现大量崩溃的情况 请问你现在解决了吗?
  • 心事重重啦啦啦啦:if (resultBeans!=null&&resultBeans.size() > 0) {
    multipleStatusView.showContent();
    otherWallerAdapter = new OtherWallerAdapter(EOSActivity.this, R.layout.eos_item, resultBeans);
    rcyeos.setAdapter(eosAdapter);
    otherWallerAdapter.notifyDataSetChanged();
    } else {
    multipleStatusView.showEmpty();
    }
  • 心事重重啦啦啦啦:你好,我在加载接口消息的时候,在转圈状态我就直接退出当前界面,然后产生了闪退,报错是MultipleStatusView.showEmpty()' on a null object reference 。这是怎么解决呢
    心事重重啦啦啦啦:@续写经典 1.5.1
    续写经典:哪个版本出现的?
    试一下新版本:https://github.com/qyxxjd/MultipleStatusView
  • 捡淑:马克
  • f7e1c1dc13c5:感觉很好,但是还是 不他清楚怎么使用,还是得在每个xml的布局里写吗?我是小彩笔。。。
    续写经典:@s凯华 如果是在子类里使用确实是这样的。建议业务逻辑相似的可以封装一个BaseActivity,这样只需要在这里添加一次就可以了
  • HelloVass:谢谢分享,确实在 初始化 的时候 inflate 如此多的 view 感觉有点问题呢
    HelloVass:棒棒哒,更新之后记得找我们这几位“好事”的盆友帮你 review 哦,哈哈
    续写经典: @HelloVass 谢谢指正!昨天也有朋友反馈这个问题,今天空闲的时间就在改进,改进好就马上更新。
    HelloVass:@HelloVass 我觉得最好能 lazy load,需要哪个 view 的时候再 inflate,这样会更好
  • Champion是冠军:感谢分享
  • 泥阿布_Abner:最后的show不要用遍历如何?把直接view都find出来先 然后保存起来。感觉每次遍历不太好。
    续写经典:@泥阿布_Abner 好的,明天改进下。这会在加班改需求

本文标题:自定义多状态View

本文链接:https://www.haomeiwen.com/subject/skskkttx.html