自定义多状态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