位置: 编程技术 - 正文
推荐整理分享Android 自定义ListView 实现下拉刷新 上拉加载功能(android 自定义linearlayout 宽度计算不对),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:Android 自定义控件,Android 自定义view,Android 自定义view,android 自定义livedata监听,android 自定义linker,android 自定义linearlayout移动换行,android 自定义livedata监听,android 自定义linker,内容如对您有帮助,希望把文章链接给更多的朋友!
思考Listview是viewGroup的子类,它本身提供了方法addHeaderView(View view),addFooterView(View view)去添加头布局和底布局,所以我们只要监听它的onTouchEvent方法,判断头布局 底布局的显示状态。头布局(headerView)
默认的话,得隐藏。先获取到头布局的高度int headerViewHeight = headerView.getMeasuredHeight();通过设置它的padding(0, -headerViewHeight, 0, 0); 这里要注意:获取头布局高度之前,需要等头布局完全加载上来后,才获取得到,否则为0。可以通过measure()方法主动通知系统去测量该view,也可以通过获取视图树的观察者去增加一个全局的布局监听器。重写onTouchEvent(MotionEvent event); 手指按下时 获取该view的Y方向的坐标downY。 手指移动时 获取移动的Y方向的距离deltY = (int) (event.getY() - downY); 将移动的距离deltY+(-headerViewHeight)就是头布局的位置paddingTop。 当然这个paddingTop需要限制,比如你上滑时,如果已经到了-headerViewHeight,就不要继续将头布局往上设置了;而且下拉时,如果不是第一个条目,就用listview本身的滑动事件,限制代码:paddingTop > -headerViewHeight && getFirstVisiblePosition() == 0 在此条件下,继续判断:如果paddingTop>0 && currentState==下拉刷新状态,就将currentState设置为松开立即刷新状态并更新头布局内容;如果paddingTop<0 && currentState==松开立即刷新状态,就将currentState设置为下拉刷新状态并更新头布局内容。 手指抬起时 如果是下拉刷新状态,则隐藏头布局 如果是松开立即刷新状态,则显示头布局,将当前状态设置为正在刷新状态并更新头布局内容。同时在这里设置暴露一个接口方法,让用户在该方法中去加载要刷新出来的数据。
类中还应该提供刷新完成重置headerView的方法,由用户在获取完数据并更新完adapter之后,去在UI线程中调用该方法。
底布局(footerView) 默认隐藏。方法同头布局一样在初始化的时候,为listview设置一个滑动监听。当滑动状态为OnScrollListener.SCROLL_STATE_IDLE (即手指松开) && 是滑动listview最后一个条目 && 不是加载更多,这时,将footerView显示出来,同时在这里设置暴露一个接口方法,让用户在该方法中去加载更多要加载出来的数据。提供加载完成重置footerView的方法步骤1.headerView布局
2.footerView布局
3.自定义listview的代码
4.主函数调用的布局
5.主函数调用的代码
androidのLinearLayout中组件右对齐 androidのLinearLayout中组件右对齐在LinearLayout中,如果将其定位方向设为横向排列:android:orientation=horizontal,那么这个布局中的控件将自左向右排列。但有
Android学习 - Android最佳性能实践 (一)合理管理内存怎样才能写出高性能的应用程序,如何避免程序出现OOM,或者当程序内存占用过高的时候该怎么样去排查。确实,一个优秀的应用程序
Android-->回调(interface/abstract)的用法(通俗易懂) 使用场景小明想要问小红借块钱,小红答应借.但是小红很关心小明还钱,因为小红想要在小明还钱之后,去买好吃的蛋糕.这个时候,小红又不能时时刻刻催
标签: android 自定义linearlayout 宽度计算不对
本文链接地址:https://www.jiuchutong.com/biancheng/384221.html 转载请保留说明!友情链接: 武汉网站建设