- 浏览: 5777049 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (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 1649fragment应该是广大Android开发者都用到过的一个v ... -
左中右结构的行布局
2016-12-19 21:35 1141最近项目要开发一个新版本,发现项目中许多布局大致都相同改动不大 ... -
RecyclerView:带header&footer&加载更多
2015-09-09 16:24 2918接上一篇 由简到繁,循序渐进 实现了: 0,点击&长按 ... -
RecyclerView:带header和footer的grid
2015-09-09 13:47 3000知道原理后,为RecyclerView实现同时带header和 ... -
RecyclerView:带header的grid
2015-09-09 13:01 2391RecyclerView是一个高度可定制性的View 本文将使 ... -
iconify使用文本替换icon测试
2015-08-28 17:12 1654源项目地址 https://github.com/JoanZa ... -
快速上传头像到服务端工具类FaceUtil
2015-07-12 14:22 3018快速迭代用 import java.io.DataOut ... -
HorizontalScrollView+RadioGroup+ViewPager+FragmentPagerAdapter基本结构
2015-07-12 13:56 3248快速迭代用 import java.util.Arr ... -
RadioButton+ViewPager+FragmentPagerAdapter快速搭建页面结构
2015-07-12 11:08 2516一切为了快速开发 开发类似界面 import and ... -
为ViewPager设置CirclePageIndicator(小圆点)
2015-07-03 16:54 15248一切为了快速迭代! import android.con ... -
简单实现可以多选的ProductListDialog<T>
2015-06-25 22:33 1214只是一个范例,是为了代码快速迭代而写的 使用了listView ... -
基于上一篇写的SimplePairListPopupWindow<F,S>
2015-06-19 11:15 1494这次使用Pair<F,S>实现一个简单的Simpl ... -
基于上一篇实现的SimpleListPopupWindow<T>
2015-06-19 11:11 1479这次是个简单的PopupWindow,快速迭代用。 imp ... -
实现一个快速简单的SimpleListDialog<T>
2015-06-19 10:59 1703我写这样的文章都是为了快速迭代,所以都写的比较简单,谅解 此 ... -
为ViewPager设置SimpleViewPagerIndicator
2015-02-14 13:45 4678说到ViewPagerIndicator,网上有很多专门的开源 ... -
一个典型的从下部弹上来的Dialog
2014-12-05 14:47 6007典型的看图 import android.app ...
相关推荐
php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax分页php+ajax...
项目主体结构是dao+db+filter+pojo+servlet, 使用技术Servlet转发,代码中有注释帮助学者理解,数据库为MySQL资源内含数据库的sql。实现的数据库内容分页,查询分页,对初学者难点是根据get请求的中的url地址进行...
JavaWeb+JSP+Servlet+JDBC分页查询和查询后分页界面优化最终版
struts2 +mysql 分页显示 源码struts2 +mysql 分页显示 源码
PHP+MySql分页显示示例分析 PHP+MySql分页显示示例分析
spring+hibernate 分页 +mysql 可以当做模板用。
前端html分页逻辑是手写的,用的是Thymeleaf模板引擎,后端用的是mybatis plus的内置分页功能
不错的struts2+MySQL分页 struts2+MySQL分页
jsp+javabean 分页程序jsp+javabean 分页程序jsp+javabean 分页程序jsp+javabean 分页程序jsp+javabean 分页程序jsp+javabean 分页程序jsp+javabean 分页程序 简单实用供初学者参考
SwipeRefreshLayout 下拉刷新、加载更多、分页索引功能; SwipeRefreshLayout 下拉刷新、加载更多、分页索引功能;
MVC4+三层架构+EF+Linq+bootstrap分页效果,带数据库执行脚本
Struts + DAO分页Struts + DAO分页Struts + DAO分页Struts + DAO分页Struts + DAO分页Struts + DAO分页Struts + DAO分页Struts + DAO分页
ASP.NET+AJAX分页ASP.NET+AJAX分页ASP.NET+AJAX分页ASP.NET+AJAX分页
自己写的一个javabean+jsp分页查询和插入操作
ssh+dwr分页。。ssh+dwr分页。。ssh+dwr分页。。ssh+dwr分页。。ssh+dwr分页。。ssh+dwr分页。。ssh+dwr分页。。ssh+dwr分页。。
C#+EF+MVC+LINQ+分页+存储过程+增删改。
springboot + mybatis + pagehelper分页插件 + druid连接池 + generator逆向插件
通过JS和HTML实现的分页功能代码,有首页,前页,后页,尾页和分页页号等功能,
Struts + DAO分页笔记Struts + DAO分页笔记Struts + DAO分页笔记Struts + DAO分页笔记Struts + DAO分页笔记
四种jQuery+bootstrap分页效果插件.rar