android listview scroll滑屏显示sqlite分页,类似聊天记录,listview动态添加sqlite分页数据

前言:最近做基于openfire聊天(仿QQ、微信)翻页查看聊天记录,为此做了根据时间倒序查看聊天记录,先声明这demo是根据id来倒序(原理和时间倒序一样)

1,主界面MainActivity.class
public class MainActivity extends Activity implements OnScrollListener{
	private ProgressBar loadInfo;
	private ListView listView;
	private LinearLayout loadLayout;
	private ArrayList<String> items;
	private DatabaseService service;
	private int currentPage = 1; //默认在第一页
	private static final int lineSize =10;    //每次显示数 
	private int allRecorders = 0;  //全部记录数
	private int pageSize = 1;  //默认共一页
	private Aleph0 baseAdapter;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		listView = (ListView) findViewById(R.id.listview);
		service = new DatabaseService(this);
		//创建一个角标线性布局用来显示"正在加载"
		loadLayout = new LinearLayout(this);
		loadLayout.setGravity(Gravity.CENTER);
		//定义一个ProgressBar表示“正在加载”
		loadInfo = new ProgressBar(this,null,android.R.attr.progressBarStyleSmall);
		//增加组件 
		loadLayout.addView(loadInfo, new LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT));
		//增加到listView头部
		listView.addHeaderView(loadLayout);
		listView.setOnScrollListener(this);
		
		showAllData();
		
		
	}
	
	/**
	 * 读取全部数据
	 */
	public void showAllData(){
		
		allRecorders = service.getCount();
		//计算总页数
		pageSize = (allRecorders + lineSize -1) / lineSize;  
		items = service.getAllItems(currentPage, lineSize);
		Collections.reverse(items);  //倒序
		baseAdapter = new Aleph0();
		listView.setAdapter(baseAdapter);
		listView.setSelection(items.size());//直接定位到最底部
	}
	int firstItem=-1;

	@Override
	public void onScroll(AbsListView absView, int firstVisibleItem,
			int visibleItemCount, int totalItemCount) {
		firstItem=firstVisibleItem;
	}
	@Override
	public void onScrollStateChanged(AbsListView view, int scorllState) {
		if (firstItem==0&& currentPage < pageSize&& scorllState == OnScrollListener.SCROLL_STATE_IDLE) {// 不再滚动
			Log.e("log", "滑到第一位");
			currentPage++;
			// 增加数据
			appendDate();
		}
	}
	
	/**
	 * 增加数据
	 */
	private void appendDate(){
		final ArrayList<String> additems = service.getAllItems(currentPage, lineSize);
		Collections.reverse(additems);
		baseAdapter.setCount(baseAdapter.getCount() + additems.size());
		//判断,如果到了最末尾则去掉“正在加载”
		if(allRecorders == baseAdapter.getCount()){
			listView.removeHeaderView(loadLayout);
		}
		items.addAll(0, additems);
		
		baseAdapter.notifyDataSetChanged();
		listView.setSelection(additems.size());
		
	}
	
	class Aleph0 extends BaseAdapter {
		int count = lineSize; 

		public int getCount() {
			return count;
		} 
		
		public void setCount(int count){
			this.count = 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 view = new TextView(MainActivity.this);
			view.setTextSize(60);
			if(items != null){
				view.setText(items.get(pos));
			}else{
				view.setText(pos);
			}
			return view;
		}
	}
	
	

}
2,主界面布局文件activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <ListView
        android:id="@+id/listview"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" />


</LinearLayout>
3,数据库操作类
public class DatabaseService { 

	private Context mContext;
	private MyDBOpenHelper dbHelper;
	

	public DatabaseService(Context context) {
		mContext = context;
		dbHelper = new MyDBOpenHelper(mContext);
	}

	// 添加
	public void insert(String title) {
		SQLiteDatabase db = dbHelper.getWritableDatabase();
		String sql = "insert into database(title) values(?)";
		db.execSQL(sql, new String[] { title });
	}

	// 删除
	public void delete(String title) {
		SQLiteDatabase db = dbHelper.getWritableDatabase();
		String sql = "delete from database where title = ?";
		db.execSQL(sql, new String[] { title });
	}

	// 查找
	public ArrayList<String> find(int id) {
		SQLiteDatabase db = dbHelper.getWritableDatabase();
		String sql = "select * from database where _id = ? ";
		Cursor c = db.rawQuery(sql, new String[] { String.valueOf(id) });
		ArrayList<String> titles = new ArrayList<String>();
		if (c.moveToNext()) {
			String title = c.getString(c
					.getColumnIndexOrThrow(MyDBOpenHelper.FIELD_TITLE));
			titles.add(title);
			return titles;
		}
		// 不用忘记关闭Cursor。
		c.close();
		return null;
	}

	// 更新
	public void upDate(int id, String title) {
		SQLiteDatabase db = dbHelper.getWritableDatabase();
		String sql = "update database set title =? where _id = ?";
		db.execSQL(sql,
				new String[] { String.valueOf(title), String.valueOf(id) });
	}

	// 查询记录的总数
	public int getCount() {
		SQLiteDatabase db = dbHelper.getWritableDatabase();
		String sql = "select count(*) from database";
		Cursor c = db.rawQuery(sql, null);
		c.moveToFirst();
		int length = c.getInt(0);
		c.close();
		return length;
	}

	/**
	 * 分页查询
	 * 
	 * @param currentPage 当前页
	 * @param pageSize 每页显示的记录
	 * @return 当前页的记录
	 */
	public ArrayList<String> getAllItems(int currentPage, int pageSize) {
		int firstResult = (currentPage - 1) * pageSize;
		int maxResult = currentPage * pageSize;
		SQLiteDatabase db = dbHelper.getWritableDatabase();
		String sql = "select * from database order by  _id desc limit ?,? ";
		Cursor mCursor = db.rawQuery(
				sql,
				new String[] { String.valueOf(firstResult),
						String.valueOf(pageSize) });
		ArrayList<String> items = new ArrayList<String>();
		int columnCount  = mCursor.getColumnCount();
		while (mCursor.moveToNext()) {
			String item = mCursor.getString(mCursor
					.getColumnIndexOrThrow(MyDBOpenHelper.FIELD_TITLE));
			items.add(item);
			
		}
		//不要关闭数据库
		return items;
	}
}
4,效果图


5,下载地址:http://download.csdn.net/detail/shi508181017/8297955

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
抱歉,我可以回答您的问题。以下是一个示例代码,帮助在 Android Studio 中使用 SQLite 数据库将数据显示ListView 上: 1. 定义 SQLiteOpenHelper 类 public class SqliteHelper extends SQLiteOpenHelper { private static final String DATABASE_NAME = "my_db"; private static final int DATABASE_VERSION = 1; public SqliteHelper(Context context) { super(context, DATABASE_NAME, null, DATABASE_VERSION); } @Override public void onCreate(SQLiteDatabase db) { String CREATE_TABLE = "CREATE TABLE my_table ( " + "id INTEGER PRIMARY KEY AUTOINCREMENT, " + "name TEXT, " + "age INTEGER )"; db.execSQL(CREATE_TABLE); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { String DROP_TABLE = "DROP TABLE IF EXISTS my_table"; db.execSQL(DROP_TABLE); this.onCreate(db); } } 2. 在 Activity 中使用 SQLiteOpenHelper public class MainActivity extends AppCompatActivity { private SqliteHelper dbHelper; private ListView listView; private ArrayAdapter<String> adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); dbHelper = new SqliteHelper(this); listView = (ListView)findViewById(R.id.listView); adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, android.R.id.text1); listView.setAdapter(adapter); SQLiteDatabase db = dbHelper.getWritableDatabase(); Cursor cursor = db.rawQuery("SELECT * from my_table", null); if (cursor.moveToFirst()) { do { String name = cursor.getString(cursor.getColumnIndex("name")); int age = cursor.getInt(cursor.getColumnIndex("age")); adapter.add("Name: " + name + ", Age: " + age); } while (cursor.moveToNext()); } cursor.close(); db.close(); } } 在这个示例代码中,我们首先定义了 SqliteHelper 类,这是一个 SQLiteOpenHelper 的子类。我们在 onCreate() 中创建了一个名为 my_table 的表格,并在 onUpgrade() 中定义了如何升级我们的数据库。 然后,在 MainActivity 中,我们使用 SqliteHelper 类创建了一个 SQLiteDatabase 对象,并使用 Cursor 对象从 my_table 表格中获取数据。最后,我们使用 ArrayAdapter 将数据添加ListView 中。 希望这个示例代码可以帮助您实现在 Android Studio 中使用 SQLite 数据库将数据显示ListView 上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值