QMUI_Android使用(四)QMUIPullRefreshLayout

下拉刷新是一个布局,需要在布局文件中添加,我的灯泡控制项目的该部分布局如下

1. 布局

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/fragment_connect_scan"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.wifi.main.MainActivity">

    <LinearLayout
        android:id="@+id/connect_content"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <RelativeLayout style="@style/button_wrapper_style"
            android:paddingTop="8dp"
            android:paddingBottom="8dp">

            <TextView
                android:id="@+id/down_refresh"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_centerHorizontal="true"
                android:layout_centerVertical="true"
                android:gravity="center"
                android:text="@string/down_refresh"
                android:textColor="@color/qmui_config_color_gray_5"
                android:textSize="18dp"
                tools:layout_editor_absoluteX="135dp"
                tools:layout_editor_absoluteY="353dp" />


        </RelativeLayout>

        <RelativeLayout style="@style/button_wrapper_style"
            android:paddingTop="0dp"
            android:paddingBottom="0dp">
            <com.qmuiteam.qmui.widget.pullRefreshLayout.QMUIPullRefreshLayout
                android:id="@+id/pull_to_refresh"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:background="?attr/qmui_config_color_background">

                <ListView
                    android:id="@+id/mdns_list"
                    android:paddingLeft="8dp"
                    android:paddingRight="8dp"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent">
                </ListView>

            </com.qmuiteam.qmui.widget.pullRefreshLayout.QMUIPullRefreshLayout>
        </RelativeLayout>

    </LinearLayout>

</FrameLayout>
2.使用

private QMUIPullRefreshLayout mPullRefreshLayout; 
mPullRefreshLayout = (QMUIPullRefreshLayout)view.findViewById(R.id.pull_to_refresh);
 
mPullRefreshLayout.setOnPullListener(new QMUIPullRefreshLayout.OnPullListener() {
   @Override
   public void onMoveTarget(int offset) {

   }

   @Override
   public void onMoveRefreshView(int offset) {

   }

   @Override
   public void onRefresh() {
      mPullRefreshLayout.postDelayed(new Runnable() {

         @Override
         public void run() {
            //扫描时间
            long scanTime = 0;
            final QMUITipDialog tipDialog;

            openBroadcast(getContext());

            //加载扫描到的服务
            ConfigWifi configWifi = ConfigWifi.init();
            configWifi.scanMDNS();
            mdnsList = configWifi.getMdnsList();
            flag = true;

            while(flag) {
               if (mdnsList.size() > 0) {
              /*ListAdapter mAdapter = new MyAdapter(getContext(), mdnsList);
              mlistView.setAdapter(mAdapter);
              new WifiUtils.Utility().setListViewHeightBasedOnChildren(mlistView);
              flag=false;*/
                    //显示服务信息
                  initListView(mdnsList);
                  flag = false;
               }
               if ((System.currentTimeMillis() - scanTime) > 10000) {
                  scanTime = System.currentTimeMillis();
               } else {
                  //超时退出
                  flag = false;
               }
            }
            if (!flag){
               tipDialog = new QMUITipDialog.Builder(getContext())
                     .setIconType(QMUITipDialog.Builder.ICON_TYPE_FAIL)
                     .setTipWord("扫描超时,请稍候重试")
                     .create();
               tipDialog.show();

               //显示两秒关闭
               mListView.postDelayed(new Runnable() {
               @Override
               public void run() {
                  tipDialog.dismiss();
               }
            },2000);

            }
            mPullRefreshLayout.finishRefresh();


         }
      }, 12000);
   }
});
效果如下所示:
 


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先吐槽一下现在流行的刷新库,一个字大,包涵个人很多集成到项目中不需要的类,也很难找到很满意的效果,所以自己自己动手丰衣足食,撸一个。1.概述对所有基础控件(包括,嵌套滑动例如RecyclerView、NestedScrollView,普通的TextView、ListView、ScrollerView、LinearLayout等)提供下拉刷新、上拉加载的支持,处理了横向滑动冲突(例如:顶部banner的情况) ,且实现无痕过度。gradle (改用bintray-release,2017-7-8 16:00上传,以下暂时不会生效)compile 'com.yan:pullrefreshlayout:1.1.2'2.说明支持所有基础控件 loading 出现效果默认(STATE_FOLLOW、STATE_PLACEHOLDER_FOLLOW、STATE_CENTER、STATE_PLACEHOLDER_CENTER、STATE_FOLLOW_CENTER、STATE_CENTER_FOLLOW)  //-控件设置-     refreshLayout.autoRefresh();// 自动刷新     refreshLayout.setOverScrollDampingRatio(0.2f);//  值越大overscroll越短 default 0.2     refreshLayout.setAdjustTwinkDuring(3);// 值越大overscroll越慢 default 3     refreshLayout.setScrollInterpolator(interpolator);// 设置scroller的插值器     refreshLayout.setLoadMoreEnable(true);// 上拉加载是否可用 default false     refreshLayout.setDuringAdjustValue(10f);// 动画执行时间调节,越大动画执行越慢 default 10f     // 刷新或加载完成后回复动画执行时间,为-1时,根据setDuringAdjustValue()方法实现 default 300     refreshLayout.setRefreshBackTime(300);     refreshLayout.setDragDampingRatio(0.6f);// 阻尼系数 default 0.6     refreshLayout.setPullFlowHeight(400);// 拖拽最大范围,为-1时拖拽范围不受限制 default -1     refreshLayout.setRefreshEnable(false);// 下拉刷新是否可用 default false     refreshLayout.setPullTwinkEnable(true);// 回弹是否可用 default true      refreshLayout.setAutoLoadingEnable(true);// 自动加载是否可用 default false          // headerView和footerView需实现PullRefreshLayout.OnPullListener接口调整状态     refreshLayout.setHeaderView(headerView);// 设置headerView     refreshLayout.setFooterView(footerView);// 设置footerView          /**     * 设置header或者footer的的出现方式,默认7种方式     * STATE_FOLLOW, STATE_PLACEHOLDER_FOLLOW, STATE_PLACEHOLDER_CENTER     * , STATE_CENTER, STATE_CENTER_FOLLOW, STATE_FOLLOW_CENTER     * ,STATE_PLACEHOLDER     */     refreshLayout.setRefreshShowGravity(RefreshShowHelper.STATE_CENTER,RefreshShowHelper.STATE_CENTER);     refreshLayout.setHeaderShowGravity(RefreshShowHelper.STATE_CENTER)// header出现动画     refreshLayout.setFooterShowGravity(RefreshShowHelper.STATE_CENTER)// footer出现动画     // PullRefreshLayout.OnPullListener         public interface OnPullListener {             // 刷新或加载过程中位置相刷新或加载触发位置的百分比,时刻调用             void onPullChange(float percent);             void onPullReset();// 数据重置调用             void onPullHoldTrigger();// 拖拽超过触发位置调用             void onPullHoldUnTrigger();// 拖拽回到触发位置之前调用             void onPullHolding(); // 正在刷新             void onPullFinish();// 刷新完成         }3.demo用到的库loading 动画 AVLoadingIndicatorView(https://github.com/81813780/AVLoadingIndicatorView)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值