list下拉刷新库Android,Android巧用XListView实现万能下拉刷新控件

本文介绍了一种巧妙的方法,通过利用XListView的addHeaderView方法,将自定义布局添加到列表视图头部,从而实现对各种控件的下拉刷新功能。文章详细讲解了如何重写onMeasure和dispatchTouchEvent方法来适配不同手机的滑动效果,并提供了在MainActivity中的具体实现代码。这种方法避免了使用多种第三方下拉刷新控件,简化了开发流程。
摘要由CSDN通过智能技术生成

摘要:想必大家做开发的时候都会用到下拉刷新的控件,现在各种第三方的下拉刷新控件不胜枚举。当然最NB的还是XListView。其他也有针对GridView,ScrollView,LinearLayout进行重写的下拉刷新控件。本文针对xListView采取一种巧用办法,可以实现各种控件的下拉刷新。

这种巧用思路有人可能已经想到,因为ListView本身就有addHeaderView方法,用该方法我们可以添加任何布局的View。因此本文的思路就是往xListView的头部添加我们自定义写的布局文件。

但是这里需要注意的是,如果头部自定义的布局文件含有ListView、GridView等这种控件,应该重写其onMeasure方法(PS,大家在ScrollView中嵌套ListView会经常看到这种重写)。

@Override

public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {

int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2,

MeasureSpec.AT_MOST);

super.onMeasure(widthMeasureSpec, expandSpec);

}

但是Android机型众多,有些手机厂商会把ListView,ScrollView等控件强制加入回弹效果,类似IOS的弹性效果,例如魅族。所以,最好也重写其dispatchTouchEvent方法,禁止其滑动。

@Override

public boolean dispatchTouchEvent(MotionEvent ev) {

// TODO Auto-generated method stub

if (ev.getAction() == MotionEvent.ACTION_MOVE) {

return true;

}

return super.dispatchTouchEvent(ev);

}

新建一个Android程序,在其MainActivity中写下xListView的相关操作,代码如下:

public class MainActivity extends Activity implements Callback{

private XListView mXListView;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mXListView = (XListView)findViewById(R.id.main_xlv);

View header = LayoutInflater.from(this).inflate(R.layout.view_header, null);

TextView headerTv = (TextView)header.findViewById(R.id.tv);

headerTv.setTextSize(28);

mXListView.setAdapter(new EmptyAdapter());

mXListView.addHeaderView(header);

mXListView.setOverScrollMode(View.OVER_SCROLL_NEVER);

mXListView.showHeader(true);

mXListView.setIsAutoLoadMore(false);

mXListView.setCallback(this);

}

/**

* @see com.dighammer.xlistview.XListView.Callback#onHeaderTriggerd()

*/

@Override

public void onHeaderTriggerd() {

// TODO Auto-generated method stub

mXListView.headerFinished();

}

/**

* @see com.dighammer.xlistview.XListView.Callback#onFooterTriggerd()

*/

@Override

public void onFooterTriggerd() {

// TODO Auto-generated method stub

}

}

重点代码部分就是onCreate方法的XListView相关操作。其中一定要写一个空的BaseAdapter,不然UI无法显示。

有了这种办法,以后就不用导入各种下拉刷新的第三方控件,只要有了XListView,我们可以做很多事。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值