PullRefreshLayout--高度自定义headview

引言

下拉刷新控件是非常常用的控件,但是github上少有可以自定义headview的开源库,所以这里自己造下轮子,以便应对不同下拉刷新的需求。

PullRefreshLayout,项目地址Github:https://github.com/FengJiaCheng/PullRefreshLayout,欢迎star。

PullRefreshLayout--高度自定义headview_第1张图片
演示

使用

布局


    

        

        
    

设置自己的headview,不设置则会使用默认的DefaultHeadView

 pullRefreshLayout.setHeadView(new MyHeadView(this));
 pullRefreshLayout.setOnRefreshListener(new PullRefreshLayout.OnRefreshListener() {
            @Override
            public void onRefresh() {

                ...

            }
        });

使用setRefreshing(boolean refreshing)开启/关闭刷新。

自定义headview

headview接口

 ....

    /**
     * 初始布局
     * @param context
     */
    protected abstract void init(Context context);

    /**
     * 下拉偏移量
     *
     * @param offset
     */
    public abstract void onPositionChange(int offset);

    /**
     * 下拉的百分比进度
     *
     * @param percent : 0~2
     */
    public abstract void onPercent(float percent);

    /**
     * 开始刷新
     */
    public abstract void onStart();


    /**
     * 刷新完毕
     */
    public abstract void onStop();

自定义MyHeadview继承headview

 @Override
    protected void init(Context context) {
        View view= LayoutInflater.from(context).inflate(R.layout.headview,this,false);
        progressBar= (ProgressBar) view.findViewById(R.id.progressBar);
        textView= (TextView) view.findViewById(R.id.text);
        addView(view,0);
    }


    @Override
    public void onPositionChange(int offset) {

    }

    @Override
    public void onPercent(float percent) {
        progressBar.setVisibility(GONE);
        if(percent>=1.0){
            textView.setText("松开刷新");
        }else {
            textView.setText("下拉刷新");
        }

    }

    @Override
    public void onStart() {
        textView.setText("正在加载...");
        progressBar.setVisibility(VISIBLE);
    }

    @Override
    public void onStop() {
        progressBar.setVisibility(GONE);
        textView.setText("加载完毕");
    }

你可能感兴趣的:(PullRefreshLayout--高度自定义headview)