package hbq.android.myapp.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.BaseAdapter;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.LinearLayout.LayoutParams;
/**
*
* @author huangbq
*
*/
public class ButtonLoadingActivity extends ListActivity {
private static final String TAG = "ButtonLoadingActivity";
private listViewAdapter adapter = new listViewAdapter();
private ListView listView ;
/**
* 设置布局显示的属性
*/
private LayoutParams mLayoutParams =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("点击加载下10条...");
button.setGravity(Gravity.CENTER_VERTICAL);
layout.addView(button,FFlayoutParams);
layout.setGravity(Gravity.CENTER);
LinearLayout loadingLayout = new LinearLayout(this);
loadingLayout.addView(layout,mLayoutParams);
loadingLayout.setGravity(Gravity.CENTER);
listView = getListView();
listView.addFooterView(loadingLayout);
button.setOnClickListener(new Button.OnClickListener()
{ @Override
public void onClick(View v)
{
adapter.count += 10;
Log.i(TAG, "setOnClickListener:" + adapter.count);
adapter.notifyDataSetChanged();
int currentPage=adapter.count/10;
Toast.makeText(getApplicationContext(), "第"+currentPage+"页", Toast.LENGTH_LONG).show();
}
});
setListAdapter(adapter);
}
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) {
Log.i(TAG, "getView>>>pos:" + pos);
TextView view;
if (v==null) {
view = new TextView(ButtonLoadingActivity.this);
}
else {
view=(TextView)v;
}
view.setText("ListItem " + pos);
view.setTextSize(20f);
view.setGravity(Gravity.CENTER);
view.setHeight(60);
return view;
}
}
}
2.用OnScrollListener来监听是不是最后一条项目来加载
package hbq.android.myapp.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.view.View.OnClickListener;
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.Toast;
import android.widget.AbsListView.OnScrollListener;
import android.widget.LinearLayout.LayoutParams;
/**
*
* @author huangbq
*
*/
public class MainActivity extends ListActivity implements OnScrollListener {
private static final String TAG = "MainActivity";
private listViewAdapter adapter = new listViewAdapter();
ListView listView ;
private int lastItem = 0;
LinearLayout loadingLayout;
/**
* 设置布局显示属性
*/
private LayoutParams mLayoutParams =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;
@Override
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中
layout.addView(progressBar, mLayoutParams);
//文本内容
TextView textView = new TextView(this);
textView.setText("加载中...");
textView.setGravity(Gravity.CENTER_VERTICAL);
//把文本加入到layout中
layout.addView(textView, FFlayoutParams);
//设置layout的重力方向,即对齐方式是
layout.setGravity(Gravity.CENTER);
//设置ListView的页脚layout
loadingLayout = new LinearLayout(this);
loadingLayout.addView(layout, mLayoutParams);
loadingLayout.setGravity(Gravity.CENTER);
loadingLayout.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
if (adapter.count<=41) {
adapter.count += 10;
adapter.notifyDataSetChanged();
}else{
listView.removeFooterView(loadingLayout);
}
}
});
//得到一个ListView用来显示条目
listView = getListView();
//添加到脚页显示
listView.addFooterView(loadingLayout);
//给ListView添加适配器
setListAdapter(adapter);
//给ListView注册滚动监听
listView.setOnScrollListener(this);
}
@Override
public void onScroll(AbsListView v, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
Log.i(TAG , "Scroll>>>first: " + firstVisibleItem + ", visible: " + visibleItemCount + ", total: " + totalItemCount);
lastItem = firstVisibleItem + visibleItemCount - 1;
Log.i(TAG , "Scroll>>>lastItem:" + lastItem);
//显示50条ListItem,即0-49,因为onScroll是在“滑动”执行过之后才触发,所以用adapter.count<=41作条件
/*if (adapter.count<=41) {
if (firstVisibleItem+visibleItemCount==totalItemCount) {
adapter.count += 10;
adapter.notifyDataSetChanged();
listView.setSelection(lastItem);
int currentPage=adapter.count/10;
Toast.makeText(getApplicationContext(), "第"+currentPage+"页", Toast.LENGTH_LONG).show();
}
}
else {
listView.removeFooterView(loadingLayout);
}
*/
}
@Override
public void onScrollStateChanged(AbsListView v, int state) {
if (lastItem == adapter.count && state == OnScrollListener.SCROLL_STATE_IDLE) {
/* Log.i(TAG,"ScrollStateChanged>>>state:"+state+"lastItem:" + lastItem);
//显示50条ListItem,即0-49,因为onScrollStateChanged是在“拖动滑动”执行过之后才触发,所以用adapter.count<=41作条件
if (adapter.count<=41) {
adapter.count += 10;
adapter.notifyDataSetChanged();
}else{
listView.removeFooterView(loadingLayout);
}
*/
}
}
/**
* 要用用于生成显示数据
* @author huangbq
*
*/
class listViewAdapter extends BaseAdapter {
int count = 10;
public int getCount() {
Log.i(TAG, "getCount>>>count:" + count);
return count;
}
public Object getItem(int pos) {
Log.i(TAG, "getItem>>>pos:" + pos);
return pos;
}
public long getItemId(int pos) {
Log.i(TAG, "getItemId>>>ItemId:" + pos);
return pos;
}
public View getView(int pos, View v, ViewGroup p) {
Log.i(TAG, "getView>>>pos:" + pos);
TextView view;
if (v==null) {
view = new TextView(MainActivity.this);
}
else {
view=(TextView)v;
}
view.setText("ListItem " + pos);
view.setTextSize(20f);
view.setGravity(Gravity.CENTER);
view.setHeight(60);
return view;
}
}
}
分享到:
相关推荐
这篇博客“ListView中加上加FootView和自动加载listview条目”就详细讲解了如何实现这一功能。 首先,我们需要了解`FootView`的概念。`FootView`是附加在`ListView`底部的一个视图,它可以是一个按钮,提示用户有更...
在Android开发中,ListView是一...综上,"ListView实现动态加载"涵盖了Android开发中的数据适配、视图复用、异步加载、滚动监听、内存优化等多个重要知识点。熟练掌握这些技巧,对于构建流畅、高效的列表界面至关重要。
6. 在事件处理程序中编写按钮点击后的逻辑,如打开新窗口、执行操作或调用服务接口。 注意,对于自定义的按钮列,需要特别关注的是UI的响应性和易用性。确保按钮的大小适中,点击区域合理,以及在各种主题和高DPI...
本文将深入探讨如何使用Handler+线程和AsyncTask两种方法来实现ListView的动态加载分页。 首先,我们来看看Handler+线程的实现方式。在主线程中,我们不能直接进行耗时操作,如网络请求或数据库查询,因为这会导致...
在本文中,我们将深入探讨ListView的动态加载以及如何实现点击底部加载更多的功能。 一、ListView的基本概念 ListView是Android SDK中的一个视图容器,它可以显示多行数据,每一行对应一个数据项。通过适配器...
本文将深入探讨如何在ListView中添加图片和按钮,并实现它们以及ListView的双监听,以便按钮点击时能触发Activity的跳转。 首先,我们需要创建一个自定义的ListView适配器,通常会继承自BaseAdapter。在这个适配器...
动态加载ListView是指在用户触发特定事件(如点击Button)时,程序按需加载数据到ListView中,而不是一次性加载所有数据,这样可以提高应用的性能和用户体验。本文将详细讲解如何实现“点击button动态加载listView”...
2. **创建自定义BaseAdapter**:重写其中的`getCount()`方法返回数据项总数,`getView()`方法负责将数据项转化为ListView中的View。 3. **监听ListView滚动事件**:通过设置OnScrollListener,当用户滚动到ListView...
在ListView中,不是一次性加载所有数据,而是只加载屏幕可见的部分,当用户滚动时,再按需加载更多数据。这样可以减少内存消耗,提高应用启动速度,尤其是处理大数据集时。 实现ListView动态加载通常有两种方法: ...
将Switch嵌套在ListView中,可以实现用户通过点击列表条目来切换Switch的状态,从而提供更丰富的交互体验。以下是关于这个主题的详细知识点: 1. **ListView的使用**: - ListView是Android中的一个视图容器,主要...
5. **动态添加和移除FootView**: 在数据加载过程中,可能需要显示加载指示器,当数据加载完成或出错时,需要更新FootView的状态。这可以通过调用Adapter的`addFooterView()`和`removeFooterView()`方法来实现。 6. ...
需求如题目:Android listview中item部分区域添加点击事件,在一个界面显示了listview,但显示的内容分为上下两部分,分别是白色的背景和蓝色的背景,现在需要只点击蓝色的背景,才能跳转到其他界面,解决方式如下:...
通过以上步骤和注意事项,我们可以有效地在ListView中实现动态加载和滑动加载功能,为用户提供流畅的滚动体验。在实际项目中,还可以根据需求进行优化,如使用RecyclerView替代ListView,或者采用更高效的加载策略。
友们在使用ListView的过程中,是否考虑过加载大量的数据时,如何提高显示速度? 朋友你是不是也想对其优化,形成动态加载? 如果你也有过这样的想法,那么我们是同路人! 通过查看ListView的API,我们似乎找不...
`ListView中的头尾按钮`这个主题指的是如何在ListView的顶部和底部添加额外的按钮,以提供更多的交互功能。这种设计通常用于实现如加载更多、刷新等功能。下面将详细讲解如何在ListView中实现头尾按钮,并探讨相关...
本教程将重点讲解如何在ListView中实现下拉刷新和动态加载数据的功能,同时处理图文混排的问题。 首先,我们要引入SwipeRefreshLayout库,它是Android SDK提供的一个下拉刷新框架。在`build.gradle`文件中添加以下...
ListView是Android平台中一个常用的控件,用于展示大量数据列表,尤其在数据量较大时,动态加载和刷新功能显得尤为重要。动态加载,也称为无限滚动或懒加载,是指当用户滚动到列表底部时,ListView自动加载更多的...
// 在这里处理按钮点击事件,例如获取点击的位置 int clickedPosition = (int) v.getTag(); // 获取点击的Item位置 String clickedData = data.get(clickedPosition); // 获取对应的数据 // 执行相应的方法,...
在本文中,我们将深入探讨如何在ListView中加载多幅图片,并且讨论图片的存储策略,以及如何利用ImageList组件进行有效的管理。 首先,ListView控件本身并不直接支持加载图像。为了在ListView中显示图片,我们需要...