MultipleStatusView: 一个支持多种状态的自定义View,可以方便的切换到:加载中视图、错误视图、空数据视图、网络异常视图、内容视图。

jopen 9年前

一个支持多种状态的自定义View,可以方便的切换到:加载中视图、错误视图、空数据视图、网络异常视图、内容视图。

apk下载

使用

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

感谢

LoadingLayout @大头鬼

示例

<com.classic.common.MultipleStatusView      android:id="@+id/main_multiplestatusview"      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.main_multiplestatusview);  //显示加载中视图  multipleStatusView.showLoading();  //显示空视图  multipleStatusView.showEmpty();  //显示错误视图  multipleStatusView.showError();  //显示无网络视图  multipleStatusView.showNoNetwork();  //显示内容视图  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/main_multiplestatusview"      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"      >        <TextView          android:id="@+id/content_view"          android:text="内容视图"          android:layout_width="wrap_content"          android:layout_height="wrap_content"          android:layout_centerInParent="true"          android:textSize="20sp"          />    </com.classic.common.MultipleStatusView>

注意事项

  • 加载中视图的id必须为:loading_view
  • 空视图的id必须为:empty_view
  • 错误视图的id必须为:error_view
  • 无网络视图的id必须为:no_network_view
  • 内容视图的id必须为:content_view
<RelativeLayout      android:id="@+id/loading_view"      android:layout_width="match_parent"      android:layout_height="match_parent">        ...    </RelativeLayout>

如果需要点击某个view进行重试,可以设置如下id:

  • 空视图内对应的view id:empty_retry_view
  • 错误视图内对应的view id:error_retry_view
  • 无网络视图内对应的view id:no_network_retry_view
<RelativeLayout      android:id="@+id/error_view"      android:layout_width="match_parent"      android:layout_height="match_parent">        <ImageView          android:id="@+id/error_retry_view"          android:layout_width="wrap_content"          android:layout_height="wrap_content"          android:layout_centerInParent="true"          android:src="@mipmap/ic_error"          />        <TextView          style="@style/MultipleStatusView.Content"          android:layout_below="@id/error_retry_view"          android:text="@string/error_view_hint"/>  </RelativeLayout>

详细使用见demo示例。

关于

项目地址: https://github.com/qyxxjd/MultipleStatusView