`

LoadMoreListView+SwipeRefreshLayout(分页下拉)基本结构

阅读更多
一切为了快速迭代



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
分享到:
评论

相关推荐

    listview可以分页滚动刷新的

    一种常见的方法是使用“无限滚动”或者“下拉刷新”(Pull-to-Refresh)库,如SwipeRefreshLayout和LoadMoreListView。SwipeRefreshLayout提供了一个可滑动刷新的容器,通常包含一个列表视图,当用户从顶部向下拉动...

    安卓可下拉刷新、加载更多数据的listview

    实现这两个功能通常需要结合使用ListView和一些第三方库,例如SwipeRefreshLayout和LoadMoreListView。SwipeRefreshLayout是Android官方提供的一个组件,用于实现下拉刷新效果。它可以包裹一个子View,当用户下拉这...

    listview下拉刷新+侧滑+上拉加载(改进版)

    实现这一功能的关键是使用SwipeRefreshLayout组件,它提供了一个内置的刷新指示器和回调接口,以便在用户执行下拉操作时触发数据刷新逻辑。 2. **侧滑删除**: 侧滑删除允许用户通过在列表项上向左或向右滑动来...

    安卓下拉上拉刷新相关-listview下拉刷新仿最新版美团外卖.rar

    在旧版本的Android SDK中,实现下拉刷新通常需要借助第三方库,如SwipeRefreshLayout。该库允许开发者添加一个可滑动的刷新布局,当用户从顶部向下滑动时,显示一个刷新指示器。在最新版的美团外卖应用中,这种下拉...

    listViewLoadMore

    为了实现这两个功能,开发者还可以使用现成的库,如SwipeRefreshLayout(内置下拉刷新)和EndlessScrollListener(支持上拉加载更多)。这些库简化了开发过程,提供了预设的动画和交互效果,使开发者可以快速集成到...

    ListView GridView和ScrollView下拉刷新 上拉加载更多

    下拉刷新和上拉加载更多在ListView中通常通过SwipeRefreshLayout和LoadMoreListView库来实现。SwipeRefreshLayout包裹ListView,当用户在顶部滑动时,会触发刷新动画,并调用相关接口更新数据。而LoadMoreListView则...

    下拉刷新 上拉更多 支持ListView GridView WebView

    在实际应用中,为了提高开发效率和用户体验,许多开发者选择使用像SwipeRefreshLayout这样的原生组件,或是诸如PullToRefreshLayout、LoadMoreListView等第三方库。这些库提供了预设的动画效果和易于集成的API,使得...

    listview 下拉刷新 样式

    其中,`SwipeRefreshLayout`是Android官方提供的一个便捷的下拉刷新组件,它可以包裹一个子视图,如ListView,当用户下拉时,子视图的顶部会显示一个刷新指示器。 接下来,我们来谈谈如何实现自定义的下拉刷新样式...

    Android完美的ListView下拉刷新 上拉更多源码

    - 使用第三方库,如SwipeRefreshLayout(Android官方库)或Volley、SmartRefreshLayout等,它们提供了更完善的API和丰富的自定义选项,能快速集成下拉刷新和上拉加载更多功能。 - 注意性能优化,避免频繁触发刷新...

    ListView下拉刷新

    在实际项目中,开发者可能会使用第三方库,如SwipeRefreshLayout与LoadMoreView结合,或者使用诸如PullToRefreshLayout、LoadMoreListView等专门针对此类需求的库,以简化开发过程,提高代码的可维护性。对于...

    下拉刷新,上拉加载的实现

    4. **第三方库**:虽然可以手动实现这一功能,但很多开发者会选择使用第三方库,如SwipeRefreshLayout(适用于Android Support Library)和LoadMoreListView(适用于开源社区)。这些库已经封装好了下拉刷新和上拉...

    Android ListView实例源码

    - 如SwipeRefreshLayout实现下拉刷新,LoadMoreListView实现上拉加载更多,这两种功能在列表内容动态更新时很常见。 9. **ListView动画**: - 可以添加动画效果,如item的滑动进入、淡入淡出等,提升用户体验。 ...

    RefreshListView

    在Java中实现`RefreshListView`,通常会使用第三方库,如SwipeRefreshLayout和LoadMoreListView等。SwipeRefreshLayout是Android SDK中自带的一个布局容器,它可以包裹一个子视图,如`ListView`或`RecyclerView`,当...

    listview文件夹

    1. **ListView基本结构**:ListView由多个ListView项(ListView Item)组成,每个Item通常是一个View或一个自定义的布局。通过Adapter将数据绑定到这些Items上。 2. **Adapter原理**:Adapter是连接ListView与数据...

    Android应用源码之ListViewSample.zip

    1. **ListView基本结构** ListView由Adapter驱动,Adapter负责为ListView提供数据和视图。在ListViewSample中,我们可能会看到一个自定义的Adapter类,如`MyListAdapter`,它继承自`BaseAdapter`或`ArrayAdapter`,...

    Android ListView

    现在流行的下拉刷新和上拉加载功能,可以通过SwipeRefreshLayout和LoadMoreListView等库实现。SwipeRefreshLayout包裹ListView,提供手指滑动顶部触发刷新的功能;LoadMoreListView则支持在列表底部显示加载更多提示...

    android listview

    要实现这样的效果,可以使用SwipeRefreshLayout包裹ListView,提供下拉刷新功能;同时,使用LoadMoreListView或者自定义Footer,实现上拉加载更多数据。此外,为了保持顶部头像和昵称的固定,可以使用HeaderView。 ...

    ListView安卓基础

    SwipeRefreshLayout可以实现下拉刷新功能,当用户从顶部向下拖动ListView时,会显示刷新指示器。LoadMoreListView或者FooterView可以用来实现上拉加载更多,当用户滚动到列表底部时加载更多数据。 为了进一步优化...

Global site tag (gtag.js) - Google Analytics