- 浏览: 5825353 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (890)
- WindowsPhone (0)
- android (88)
- android快速迭代 (17)
- android基础 (34)
- android进阶 (172)
- android高级 (0)
- android拾遗 (85)
- android动画&效果 (68)
- Material Design (13)
- LUA (5)
- j2me (32)
- jQuery (39)
- spring (26)
- hibernate (20)
- struts (26)
- tomcat (9)
- javascript+css+html (62)
- jsp+servlet+javabean (14)
- java (37)
- velocity+FCKeditor (13)
- linux+批处理 (9)
- mysql (19)
- MyEclipse (9)
- ajax (7)
- wap (8)
- j2ee+apache (24)
- 其他 (13)
- phonegap (35)
最新评论
-
Memories_NC:
本地lua脚本终于执行成功了,虽然不是通过redis
java中调用lua脚本语言1 -
ZHOU452840622:
大神://处理返回的接收状态 这个好像没有监听到 遇 ...
android 发送短信的两种方式 -
PXY:
拦截部分地址,怎么写的for(int i=0;i<lis ...
判断是否登录的拦截器SessionFilter -
maotou1988:
Android控件之带清空按钮(功能)的AutoComplet ...
自定义AutoCompleteTextView -
yangmaolinpl:
希望有表例子更好。。。,不过也看明白了。
浅谈onInterceptTouchEvent、onTouchEvent与onTouch
一切为了快速迭代
布局
https://github.com/android-cjj/Android-MaterialRefreshLayout
import java.util.ArrayList; import org.json.JSONObject; import android.animation.ObjectAnimator; import android.os.Bundle; import android.support.v4.widget.SwipeRefreshLayout; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.ImageView; import android.widget.LinearLayout; import com.android.volley.Response.Listener; import com.widget.view.LoadMoreListView.OnLoadMoreListener; import com.yirui.youbao.CommonAdapter; import com.yirui.youbao.ViewHolder; import com.yirui.youbao.ViewWrapper; import com.yirui.youbao.app.R; import com.yirui.youbao.model.Pagination; import com.yirui.youbao.model.Parking; import com.yirui.youbao.net.Commands; import com.yirui.youbao.net.VolleyHelper; import com.yirui.youbao.util.Json; /** * * * @author pythoner * */ public class ParkingPayedListFragment extends BaseFragment { private com.widget.view.LoadMoreListView listView; private CommonAdapter<Parking> adapter; private Pagination pagination = new Pagination(); private ArrayList<Parking> parkings = new ArrayList<Parking>(); private SwipeRefreshLayout swipeRefreshLayout; public static ParkingPayedListFragment newInstance(/*KeyValue kv*/) { ParkingPayedListFragment fragment = new ParkingPayedListFragment(); Bundle bundle = new Bundle(); // bundle.putParcelable("KeyValue", kv); fragment.setArguments(bundle); return fragment; } public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Bundle args = getArguments(); if (args != null) { // curKeyValue = args.getParcelable("KeyValue"); } } public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { super.onCreateView(inflater, container, savedInstanceState); View view = inflater.inflate(R.layout.fragment_list_comm, container,false); listView = (com.widget.view.LoadMoreListView) view.findViewById(R.id.listView); listView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { // TODO Auto-generated method stub // } }); listView.setOnLoadMoreListener(new OnLoadMoreListener() { @Override public void onLoadMore() { pagination.page++; doDefaultParkingQuery(); } }); swipeRefreshLayout = (SwipeRefreshLayout) view.findViewById(R.id.swipeRefreshLayout); swipeRefreshLayout.setColorScheme(R.color.scheme_green,R.color.scheme_yellow, R.color.scheme_gray, R.color.scheme_red); swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { @Override public void onRefresh() { // TODO Auto-generated method stub refreshListView(); // doDefaultParkingQuery(); } }); doDefaultParkingQuery(); return view; } private void doDefaultParkingQuery() { doCommandParkingQuery("潍坊路", pagination); } private void doCommandParkingQuery(String keyword, Pagination pagination) { Commands.doCommandParkingQuery(context, keyword, pagination, new Listener<JSONObject>() { @Override public void onResponse(JSONObject response) { // TODO Auto-generated method stub // Log.i("tag", response.toString()); if (context.isSuccess(response)) { updateViews(Json.parseParkings(response)); } } }); } private void refreshListView() { listView.resetLoadMoreListener(); pagination.page = 1; parkings.clear(); // notifyDataSetChanged(); } private void closeRefreshing() { if (swipeRefreshLayout != null && swipeRefreshLayout.isRefreshing()) { swipeRefreshLayout.setRefreshing(false); } } private void updateViews(Object obj) { closeRefreshing(); if (obj == null) { return; } ArrayList<Parking> list = (ArrayList<Parking>) obj; // Log.i("tag", "list.size==="+list.size()); listView.onLoadMoreComplete(); if (list.size() == 0) { listView.removeLoadMoreListener(); return; } parkings.addAll(list); notifyDataSetChanged(); } private void notifyDataSetChanged() { if (adapter == null) { listView.setAdapter(adapter = new CommonAdapter<Parking>(context, parkings, R.layout.item_for_parkings) { @Override public void setValues(ViewHolder helper, Parking item, int position) { createItem(helper, item, position); } }); } else { adapter.notifyDataSetChanged(); } } //打开关闭下滑面板用,本例并不关心,可忽略 private View lastContainer = null; private Parking lastItem = null; private void createItem(ViewHolder helper, final Parking item, final int position) { ImageView item_0 = helper.getView(R.id.item_0); VolleyHelper.loadImageByVolley(item.getImage(), item_0, R.drawable.default_face); helper.setText(R.id.item_1, item.getName()); helper.setText(R.id.item_2, item.getPrice()); // helper.setText(R.id.item_3, item.getName()); final View container = helper.getView(R.id.container); final int maxHeight = 140;// 菜单的高 if (item.isOpen()) { container.setLayoutParams(new LinearLayout.LayoutParams( LinearLayout.LayoutParams.MATCH_PARENT, maxHeight)); } else { container.setLayoutParams(new LinearLayout.LayoutParams( LinearLayout.LayoutParams.MATCH_PARENT, 0)); } helper.getView(R.id.item_4).setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub if (container == lastContainer) { doSliding(container, maxHeight); item.setOpen(!item.isOpen()); } else { doSliding(container, maxHeight); item.setOpen(true); if (lastContainer != null) { doSliding(lastContainer, 0); lastItem.setOpen(false); } lastContainer = container; lastItem = item; } } }); helper.getView(R.id.btn_0).setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Log.i("tag", "btn_0[" + position + "]"); } }); helper.getView(R.id.btn_1).setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Log.i("tag", "btn_1[" + position + "]"); } }); helper.getView(R.id.btn_2).setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Log.i("tag", "btn_2[" + position + "]"); } }); helper.getView(R.id.btn_3).setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Log.i("tag", "btn_3[" + position + "]"); } }); helper.getView(R.id.btn_4).setOnClickListener( new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub Log.i("tag", "btn_4[" + position + "]"); } }); } private void doSliding(View view, int maxHeight) { ViewWrapper wrapper = new ViewWrapper(view); if (view.getHeight() == 0) { ObjectAnimator.ofInt(wrapper, "height", maxHeight).setDuration(400) .start(); } else { ObjectAnimator.ofInt(wrapper, "height", 0).setDuration(400).start(); } } @Override public void onResume() { super.onResume(); } @Override public void onPause() { super.onPause(); } @Override public void onDestroy() { super.onDestroy(); } @Override public void onDestroyView() { // TODO Auto-generated method stub super.onDestroyView(); } }
布局
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/swipeRefreshLayout" android:layout_width="match_parent" android:layout_height="match_parent" > <com.widget.view.LoadMoreListView android:id="@+id/listView" android:layout_width="match_parent" android:layout_height="match_parent" android:footerDividersEnabled="false" android:headerDividersEnabled="false" android:cacheColorHint="@android:color/transparent" /> </android.support.v4.widget.SwipeRefreshLayout>
/* * 分页 */ public class Pagination { public int page=1; public int size=10; public void reset(){ page=1; size=10; } public int nextPage(){ return page++; } }
https://github.com/android-cjj/Android-MaterialRefreshLayout
发表评论
-
工具类之FragmentUtils
2017-04-01 11:37 1732fragment应该是广大Android开发者都用到过的一个v ... -
左中右结构的行布局
2016-12-19 21:35 1186最近项目要开发一个新版本,发现项目中许多布局大致都相同改动不大 ... -
RecyclerView:带header&footer&加载更多
2015-09-09 16:24 2970接上一篇 由简到繁,循序渐进 实现了: 0,点击&长按 ... -
RecyclerView:带header和footer的grid
2015-09-09 13:47 3047知道原理后,为RecyclerView实现同时带header和 ... -
RecyclerView:带header的grid
2015-09-09 13:01 2433RecyclerView是一个高度可定制性的View 本文将使 ... -
iconify使用文本替换icon测试
2015-08-28 17:12 1694源项目地址 https://github.com/JoanZa ... -
快速上传头像到服务端工具类FaceUtil
2015-07-12 14:22 3081快速迭代用 import java.io.DataOut ... -
HorizontalScrollView+RadioGroup+ViewPager+FragmentPagerAdapter基本结构
2015-07-12 13:56 3298快速迭代用 import java.util.Arr ... -
RadioButton+ViewPager+FragmentPagerAdapter快速搭建页面结构
2015-07-12 11:08 2565一切为了快速开发 开发类似界面 import and ... -
为ViewPager设置CirclePageIndicator(小圆点)
2015-07-03 16:54 15336一切为了快速迭代! import android.con ... -
简单实现可以多选的ProductListDialog<T>
2015-06-25 22:33 1260只是一个范例,是为了代码快速迭代而写的 使用了listView ... -
基于上一篇写的SimplePairListPopupWindow<F,S>
2015-06-19 11:15 1539这次使用Pair<F,S>实现一个简单的Simpl ... -
基于上一篇实现的SimpleListPopupWindow<T>
2015-06-19 11:11 1521这次是个简单的PopupWindow,快速迭代用。 imp ... -
实现一个快速简单的SimpleListDialog<T>
2015-06-19 10:59 1750我写这样的文章都是为了快速迭代,所以都写的比较简单,谅解 此 ... -
为ViewPager设置SimpleViewPagerIndicator
2015-02-14 13:45 4729说到ViewPagerIndicator,网上有很多专门的开源 ... -
一个典型的从下部弹上来的Dialog
2014-12-05 14:47 6078典型的看图 import android.app ...
相关推荐
一种常见的方法是使用“无限滚动”或者“下拉刷新”(Pull-to-Refresh)库,如SwipeRefreshLayout和LoadMoreListView。SwipeRefreshLayout提供了一个可滑动刷新的容器,通常包含一个列表视图,当用户从顶部向下拉动...
实现这两个功能通常需要结合使用ListView和一些第三方库,例如SwipeRefreshLayout和LoadMoreListView。SwipeRefreshLayout是Android官方提供的一个组件,用于实现下拉刷新效果。它可以包裹一个子View,当用户下拉这...
实现这一功能的关键是使用SwipeRefreshLayout组件,它提供了一个内置的刷新指示器和回调接口,以便在用户执行下拉操作时触发数据刷新逻辑。 2. **侧滑删除**: 侧滑删除允许用户通过在列表项上向左或向右滑动来...
在旧版本的Android SDK中,实现下拉刷新通常需要借助第三方库,如SwipeRefreshLayout。该库允许开发者添加一个可滑动的刷新布局,当用户从顶部向下滑动时,显示一个刷新指示器。在最新版的美团外卖应用中,这种下拉...
为了实现这两个功能,开发者还可以使用现成的库,如SwipeRefreshLayout(内置下拉刷新)和EndlessScrollListener(支持上拉加载更多)。这些库简化了开发过程,提供了预设的动画和交互效果,使开发者可以快速集成到...
下拉刷新和上拉加载更多在ListView中通常通过SwipeRefreshLayout和LoadMoreListView库来实现。SwipeRefreshLayout包裹ListView,当用户在顶部滑动时,会触发刷新动画,并调用相关接口更新数据。而LoadMoreListView则...
在实际应用中,为了提高开发效率和用户体验,许多开发者选择使用像SwipeRefreshLayout这样的原生组件,或是诸如PullToRefreshLayout、LoadMoreListView等第三方库。这些库提供了预设的动画效果和易于集成的API,使得...
其中,`SwipeRefreshLayout`是Android官方提供的一个便捷的下拉刷新组件,它可以包裹一个子视图,如ListView,当用户下拉时,子视图的顶部会显示一个刷新指示器。 接下来,我们来谈谈如何实现自定义的下拉刷新样式...
- 使用第三方库,如SwipeRefreshLayout(Android官方库)或Volley、SmartRefreshLayout等,它们提供了更完善的API和丰富的自定义选项,能快速集成下拉刷新和上拉加载更多功能。 - 注意性能优化,避免频繁触发刷新...
在实际项目中,开发者可能会使用第三方库,如SwipeRefreshLayout与LoadMoreView结合,或者使用诸如PullToRefreshLayout、LoadMoreListView等专门针对此类需求的库,以简化开发过程,提高代码的可维护性。对于...
4. **第三方库**:虽然可以手动实现这一功能,但很多开发者会选择使用第三方库,如SwipeRefreshLayout(适用于Android Support Library)和LoadMoreListView(适用于开源社区)。这些库已经封装好了下拉刷新和上拉...
- 如SwipeRefreshLayout实现下拉刷新,LoadMoreListView实现上拉加载更多,这两种功能在列表内容动态更新时很常见。 9. **ListView动画**: - 可以添加动画效果,如item的滑动进入、淡入淡出等,提升用户体验。 ...
在Java中实现`RefreshListView`,通常会使用第三方库,如SwipeRefreshLayout和LoadMoreListView等。SwipeRefreshLayout是Android SDK中自带的一个布局容器,它可以包裹一个子视图,如`ListView`或`RecyclerView`,当...
1. **ListView基本结构**:ListView由多个ListView项(ListView Item)组成,每个Item通常是一个View或一个自定义的布局。通过Adapter将数据绑定到这些Items上。 2. **Adapter原理**:Adapter是连接ListView与数据...
1. **ListView基本结构** ListView由Adapter驱动,Adapter负责为ListView提供数据和视图。在ListViewSample中,我们可能会看到一个自定义的Adapter类,如`MyListAdapter`,它继承自`BaseAdapter`或`ArrayAdapter`,...
现在流行的下拉刷新和上拉加载功能,可以通过SwipeRefreshLayout和LoadMoreListView等库实现。SwipeRefreshLayout包裹ListView,提供手指滑动顶部触发刷新的功能;LoadMoreListView则支持在列表底部显示加载更多提示...
要实现这样的效果,可以使用SwipeRefreshLayout包裹ListView,提供下拉刷新功能;同时,使用LoadMoreListView或者自定义Footer,实现上拉加载更多数据。此外,为了保持顶部头像和昵称的固定,可以使用HeaderView。 ...
SwipeRefreshLayout可以实现下拉刷新功能,当用户从顶部向下拖动ListView时,会显示刷新指示器。LoadMoreListView或者FooterView可以用来实现上拉加载更多,当用户滚动到列表底部时加载更多数据。 为了进一步优化...