- 浏览: 386339 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
longxishui12:
这个一定要顶得高高的。
[Android UI界面] android中仿iphone实现listview的反弹效果 -
klower.jiang:
Good job, Thank you so much!
能够兼容ViewPager的ScrollView -
ZSRTFAT:
...
file size 的大小计算
滚动加载:
转载:http://2528.iteye.com/blog/1440077
package com.yangguangfu.listview; import android.app.ListActivity; import android.os.Bundle; import android.util.Log; import android.view.Gravity; import android.view.View; import android.view.ViewGroup; import android.widget.AbsListView; import android.widget.BaseAdapter; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.ProgressBar; import android.widget.TextView; import android.widget.AbsListView.OnScrollListener; import android.widget.LinearLayout.LayoutParams; /** * * @author 阿福 * */ public class MainActivity extends ListActivity implements OnScrollListener { private static final String TAG = "MainActivity"; private listViewAdapter adapter = new listViewAdapter(); private int lastItem = 0; /** * 设置布局显示为目标有多大就多大 */ private LayoutParams WClayoutParams =new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.WRAP_CONTENT); /** * 设置布局显示目标最大化 */ private LayoutParams FFlayoutParams =new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT,LinearLayout.LayoutParams.FILL_PARENT); private ProgressBar progressBar; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Log.i(TAG, "onCreate(Bundle savedInstanceState)" ); //线性布局 LinearLayout layout = new LinearLayout(this); //设置布局 水平方向 layout.setOrientation(LinearLayout.HORIZONTAL); //进度条 progressBar = new ProgressBar(this); //进度条显示位置 progressBar.setPadding(0, 0, 15, 0); layout.addView(progressBar, WClayoutParams); TextView textView = new TextView(this); textView.setText("加载中..."); textView.setGravity(Gravity.CENTER_VERTICAL); layout.addView(textView, FFlayoutParams); layout.setGravity(Gravity.CENTER); LinearLayout loadingLayout = new LinearLayout(this); loadingLayout.addView(layout, WClayoutParams); loadingLayout.setGravity(Gravity.CENTER); //得到一个ListView用来显示条目 ListView listView = getListView(); //添加到脚页显示 listView.addFooterView(loadingLayout); // registerForContextMenu(listView); // setListAdapter(adapter); listView.setOnScrollListener(this); } public void onScroll(AbsListView v, int firstVisibleItem, int visibleItemCount, int totalItemCount) { lastItem = firstVisibleItem + visibleItemCount - 1; System.out.println("lastItem:" + lastItem); Log.i(TAG, "lastItem:" + lastItem); } public void onScrollStateChanged(AbsListView v, int state) { if (lastItem == adapter.count && state == OnScrollListener.SCROLL_STATE_IDLE) { adapter.count += 10; adapter.notifyDataSetChanged(); Log.i(TAG, "lastItem:" + lastItem); } } /** * 要用用于生成显示数据 * @author 阿福 * */ class listViewAdapter extends BaseAdapter { int count = 10; public int getCount() { Log.i(TAG, "count:" + count); return count; } public Object getItem(int pos) { Log.i(TAG, "pos:" + pos); return pos; } public long getItemId(int pos) { return pos; } public View getView(int pos, View v, ViewGroup p) { TextView view = new TextView(MainActivity.this); view.setText("阿福播放器 " + pos); Log.i(TAG, "entry: " + pos); view.setTextSize(20f); view.setHeight(80); return view; } } }
按钮加载:
package com.yangguangfu.listview; import android.app.ListActivity; import android.os.Bundle; import android.util.Log; import android.view.Gravity; import android.view.View; import android.view.ViewGroup; import android.widget.AbsListView; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.TextView; import android.widget.LinearLayout.LayoutParams; /** * * @author 阿福 * */ public class ButtonLoadingActivity extends ListActivity { private static final String TAG = "ButtonLoadingActivity"; private listViewAdapter adapter = new listViewAdapter(); /** * 设置布局显示为目标有多大就多大 */ private LayoutParams WClayoutParams =new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT,LinearLayout.LayoutParams.WRAP_CONTENT); /** * 设置布局显示目标最大化 */ private LayoutParams FFlayoutParams =new LinearLayout.LayoutParams(LinearLayout.LayoutParams.FILL_PARENT,LinearLayout.LayoutParams.FILL_PARENT); protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); Log.i(TAG, "onCreate(Bundle savedInstanceState):" ); LinearLayout layout = new LinearLayout(this); layout.setOrientation(LinearLayout.HORIZONTAL); Button button = new Button(this); button.setText("点击加载下五条..."); button.setGravity(Gravity.CENTER_VERTICAL); layout.addView(button,FFlayoutParams); layout.setGravity(Gravity.CENTER); LinearLayout loadingLayout = new LinearLayout(this); loadingLayout.addView(layout,WClayoutParams); loadingLayout.setGravity(Gravity.CENTER); ListView listView = getListView(); listView.addFooterView(loadingLayout); button.setOnClickListener(new Button.OnClickListener() { @Override public void onClick(View v) { adapter.count += 5; Log.i(TAG, "setOnClickListener:" + adapter.count); adapter.notifyDataSetChanged(); } }); setListAdapter(adapter); } public void onScrollStateChanged(AbsListView v, int s) { Log.i(TAG, "onScrollStateChanged(AbsListView v, int s)"); } class listViewAdapter extends BaseAdapter { int count = 10; /* starting amount */ public int getCount() { return count; } public Object getItem(int pos) { return pos; } public long getItemId(int pos) { return pos; } public View getView(int pos, View v, ViewGroup p) { TextView textView = new TextView(ButtonLoadingActivity.this); textView.setHeight(80); textView.setTextSize(20); textView.setText("阿福播放器 " + pos); Log.i(TAG, "getView:pos:" + pos); return textView; } } }
- ListViewLoading.zip (52.4 KB)
- 下载次数: 7
发表评论
-
如何控制ScrollView的滚动条,让滚动条停在指定位置
2012-08-30 14:04 2209myScrollView.post(new Runnable( ... -
Android中ListView和ScrollView总结
2012-08-29 18:31 817快速滚动的解决问题: http://www.2cto. ... -
Android ListView滚动提示等待框
2012-08-28 21:49 920转载: http://www.cnblogs.com/ ... -
[Android UI界面] android中仿iphone实现listview的反弹效果
2012-08-22 11:32 4414public class PullToRefreshListV ... -
锁屏界面
2012-07-02 19:00 703http://blog.csdn.net/qinjuning/ ... -
activity切换动画效果
2012-05-30 16:59 1026转载: http://my.oschina.net/chen ... -
索引DEMO
2012-05-15 22:47 834listview的索引 -
android listview ScrollView冲突 listview checkbox
2012-05-15 22:42 13291、解决问题: 加了checkbox之后,就会影响 ... -
popup
2012-05-15 14:11 917public class PopupWindowActivit ... -
ListView 隔行重复选中的问题
2012-05-09 15:07 1420转载; http://blog.sina.com.cn ... -
解决scrollview不滑动的问题
2012-04-11 13:57 3347scrollview 使用setOnTouchListener ...
相关推荐
"android listview滚动到底自动加载,下拉刷新"是常见的功能需求,通常应用于新闻、社交媒体等应用中,为用户提供无缝的数据加载体验。本篇将详细介绍如何实现这一功能。 首先,我们需要了解ListView的基本用法。...
在用户滚动到ListView的底部时,为了提供更好的用户体验并加载更多的数据,开发者通常会实现“加载更多”功能。本教程将详细介绍如何在ListView中实现底部加载更多的入门方法。 1. **ListView基本使用** - `...
1. **ListView的适配器(Adapter)**:适配器需要处理新数据的添加,通常会有一个专门的方法用于加载更多数据,如`loadMoreData()`。 2. **滚动监听器(OnScrollListener)**:实现`AbsListView.OnScrollListener`...
分页加载通常指的是在用户滚动到列表底部时动态加载更多的数据,这样可以减少初始化时的数据量,提高应用响应速度。 一、实现ListView分页加载的基本步骤 1. 数据源管理:首先,你需要一个数据源来存储已加载和未...
因此,"ListView延迟加载"(也称为惰性加载)是一种优化策略,它只在用户滚动到可视区域时才加载必要的数据。这种技术可以显著提升应用的响应速度,减少内存消耗,并提高用户体验。 **1. 懒加载原理** 懒加载的基本...
滚动加载(Infinite Scrolling或Load More)是指当用户滚动到ListView底部时,自动加载更多数据。这种设计减少了用户手动翻页的麻烦,提高了使用体验。实现滚动加载的方法包括: 1. **监听滚动事件**:通过ListView...
- **判断是否达到加载条件**:在滚动事件中,通过比较ListView的最后一个可见项的位置和总项数,如果两者接近,表示已经到达底部,可以触发加载更多操作。 - **加载更多数据**:调用后台服务或异步任务加载新的...
ListView是Android平台中一个常用的控件,用于展示大量的数据列表,尤其在数据量大到无法一次性加载全部内容时,动态加载listitem(也称为“懒加载”)就显得尤为重要。这种技术可以显著提高应用的性能,减少内存...
"ListView加载更多"功能是用户滚动到列表底部时自动加载新数据的一种交互模式,它提升了用户体验,减少了用户手动刷新的操作。本教程将深入讲解如何实现ListView的上拉加载更多功能。 1. **基础概念** - `ListView...
下拉加载更多则让用户能够在ListView滚动到顶部时加载更多的数据。这对于处理无限滚动列表非常有用,避免一次性加载大量数据导致的性能问题。实现这一功能,开发者需要在ListView的OnScrollListener中监听滚动事件...
`loadMoreData()`方法中,你需要实现加载新数据的逻辑,并在加载完成后更新ListView的数据源。最后,记得更新isLoadingMore变量为false,以便下次滚动时可以再次触发加载。 三、自定义ListView 在提供的`...
上拉加载(Load More)则是指当用户将ListView滑动到接近底部时,自动加载更多的数据。这有助于分页加载数据,减少一次性加载大量数据对内存的影响,同时保持界面流畅。实现上拉加载通常需要自定义ListView的Footer...
在Android中,开发者需要监听ListView的滚动事件,当检测到用户到达底部时,调用加载更多数据的方法。 3. **代码实现** - `OnScrollListener`: ListView提供了`OnScrollListener`接口,可以通过重写`...
"下拉加载"功能,又称"Infinite Scrolling"或"Load More",是ListView的一个重要特性,它允许用户滚动到列表底部时自动加载更多数据,提升用户体验。下面将详细阐述这种功能的实现原理和步骤。 1. **下拉加载原理**...
通过这个源码示例,开发者可以学习到如何结合SwipeRefreshLayout实现下拉刷新,以及如何监听ListView滚动事件来实现加载更多。同时,对数据适配器的使用、UI优化和性能监控也是Android开发中的重要技能。
总之,“Listview分页加载数据.zip”可能包含了一个完整的实现ListView分页加载功能的Android项目,包括数据模型、适配器、数据源管理、滚动监听、网络请求和错误处理等模块。开发者可以通过研究源码,了解并学习...
综上所述,“一个非常强大的上下加载ListView”是通过监听用户滚动、自定义Adapter、扩展数据加载逻辑等方式实现的。这种设计使得数据加载变得无缝且智能,极大地提升了应用的交互性和实用性。在实际开发中,开发者...
"ListView上拉加载更多"功能是提升用户体验的重要特性,它允许用户在滚动到底部时自动加载更多的数据,而无需手动翻页。本篇文章将深入探讨如何实现ListView的上拉加载更多功能,并结合给定的标签"listview 上拉 ...
在Android开发中,ListView是一种常用的组件,用于...通过结合SwipeRefreshLayout、ListView滚动事件监听以及自定义Adapter,我们可以创建出具有动态加载和刷新功能的ListView,为用户提供更加流畅和便捷的交互体验。
2. 监听事件:监听ListView的OnScrollListener,当用户滚动到底部时触发加载更多数据的逻辑。 3. 加载更多数据:在底部加载更多的实现中,通常会调用后台服务(如AsyncTask或Retrofit)获取新的数据,然后更新适配器...