ListView显示数据库的数据-采用自定义布局-向上滑动可以加载更多数据

Posted Veer Han

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ListView显示数据库的数据-采用自定义布局-向上滑动可以加载更多数据相关的知识,希望对你有一定的参考价值。

本案例使用自定义布局实现在ListView中显示数据库的数据(用户名、手机号)的功能,ListView向上滑动可以加载更多数据。

1.user_item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal" >

    <TextView
        android:id="@+id/tv_name"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_weight="1"
        android:text="chj" />

    <TextView
        android:id="@+id/tv_phone"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="2"
        android:text="13527168697" />

    <Button
        android:id="@+id/btn_call"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="拨号" />

    <Button
        android:id="@+id/btn_sms"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="信息" />

</LinearLayout>

2.在activity_main.xml中添加ListView控件 id=”@+id/lv_users”

3.自定义的adapter UserAdapter.java

package com.example.dbhytc.adapter;

import java.util.List;
import java.util.Map;

import android.content.Context;
import android.content.Intent;
import android.net.Uri;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;

import com.example.dbhytc.R;
import com.example.dbhytc.SmsActivity;

public class UserAdapter extends BaseAdapter 

    private Context context;
    private List<Map<String, Object>> data;
    private ViewHolder viewHolder;

    public UserAdapter(Context context, List<Map<String, Object>> data) 
        this.context = context;
        this.data = data;
    

    @Override
    public int getCount() 
        // TODO Auto-generated method stub
        return data.size();
    

    @Override
    public Object getItem(int position) 
        // TODO Auto-generated method stub
        return data.get(position);
    

    @Override
    public long getItemId(int position) 
        // TODO Auto-generated method stub
        return position;
    

    @Override
    public View getView(int position, View convertView, ViewGroup parent) 

        if (convertView == null) 
            viewHolder = new ViewHolder();
            convertView = View.inflate(context, R.layout.user_item, null);
            viewHolder.tv_name = (TextView) convertView
                    .findViewById(R.id.tv_name);
            viewHolder.tv_phone = (TextView) convertView
                    .findViewById(R.id.tv_phone);
            viewHolder.btn_call = (Button) convertView
                    .findViewById(R.id.btn_call);
            viewHolder.btn_sms = (Button) convertView
                    .findViewById(R.id.btn_sms);

            convertView.setTag(viewHolder);
         else 
            viewHolder = (ViewHolder) convertView.getTag();
        

        // 赋值
        Map map = data.get(position);
        viewHolder.tv_name.setText(map.get("name").toString());
        final String phone = map.get("phone").toString();
        viewHolder.tv_phone.setText(phone);

        viewHolder.btn_call.setOnClickListener(new OnClickListener() 

            @Override
            public void onClick(View v) 
                Toast.makeText(context, "打电话", 1).show();
                Intent intent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:"
                        + phone));
                context.startActivity(intent);
            
        );

        viewHolder.btn_sms.setOnClickListener(new OnClickListener() 

            @Override
            public void onClick(View v) 
                Toast.makeText(context, "发信息", 1).show();
                // 执行一个意图 打开发短信界面
                // 1.定义一个意图
                Intent intent = new Intent(context, SmsActivity.class);
                // 通过这个意图可以附带数据
                intent.putExtra("phone", phone);
                // 2.执行意图
                context.startActivity(intent);
            
        );

        return convertView;
    

    class ViewHolder 
        public TextView tv_name, tv_phone;
        public Button btn_call, btn_sms;

    

4.HytcSQLiteOpenHelper.java

package com.example.dbhytc.db;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;

public class HytcSQLiteOpenHelper extends SQLiteOpenHelper


    //数据库的名称
    private static String name="hytc.db";
    //数据库的版本
    private static Integer version=2;

    /**
     * 只需保证 在实例化子类对象时,保证父类对象先实例化
     * @param context
     */
    public HytcSQLiteOpenHelper(Context context) 
        super(context, name, null, version);
    

    /**
     * 第一次执行的时候创建数据库
     */
    @Override
    public void onCreate(SQLiteDatabase db) 
       db.execSQL("CREATE TABLE user (id integer primary key autoincrement, name varchar(20))");
    

    /**
     * 当版本号发生变化的时候 触发
     */
    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) 
        db.execSQL("alter table user add column phone varchar(11)");

    

5.UserDao中定义了查询数据data集合的方法getObjects()及得到总页数的方法getPages()

package com.example.dbhytc.dao;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;

import com.example.dbhytc.db.HytcSQLiteOpenHelper;

public class UserDao 

    // 数据库管理操作对象
    private HytcSQLiteOpenHelper helper;
    private List<Map<String, Object>> data;
    private int pagesize = 12;

    public UserDao(List<Map<String, Object>> data, Context context) 
        this.data = data;
        helper = new HytcSQLiteOpenHelper(context);
    

    /**
     * 查询方法
     */

    public void getObjects(Integer nowpage) 
        // 获取SQLiteDatabase对象
        SQLiteDatabase db = helper.getReadableDatabase();
        // 计算开始的记录数
        int startSize = (nowpage - 1) * pagesize;
        Cursor c = db.rawQuery("select id,name,phone from user limit ?,?",
                new String[]  startSize + "", pagesize + "" );

        while (c.moveToNext()) 
            Map<String, Object> map = new HashMap<String, Object>();
            map.put("name", c.getString(c.getColumnIndex("name")));
            map.put("phone", c.getString(c.getColumnIndex("phone")));
            map.put("id", c.getInt(c.getColumnIndex("id")));
            data.add(map);
        
        c.close();
        db.close();

    

    public int getPages() 
        int pages = 0;
        // 获取SQLiteDatabase对象
        SQLiteDatabase db = helper.getReadableDatabase();
        // 计算开始的记录数
        Cursor c = db.rawQuery("select count(*) as c from user", null);
        if (c.moveToNext()) 
            int count = c.getInt(c.getColumnIndex("c"));
            //计算总页数
            pages = count % pagesize == 0 ? count / pagesize : count / pagesize
                    + 1;
        
        c.close();
        db.close();
        return pages;
    

6.MainActivity.java

package com.example.dbhytc;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import android.app.Activity;
import android.os.Bundle;
import android.view.ViewTreeObserver.OnScrollChangedListener;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.ListView;

import com.example.dbhytc.adapter.UserAdapter;
import com.example.dbhytc.dao.UserDao;

public class MainActivity extends Activity implements OnScrollListener 

    // 声明控件
    private ListView lv_users;

    private UserDao userDao;
    private List<Map<String, Object>> data = new ArrayList<Map<String, Object>>();

    private int nowpage = 1;

    private boolean isLastRow = false;

    private UserAdapter adapter;

    private int pages;

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 获取控件对象
        lv_users = (ListView) findViewById(R.id.lv_users);

        // 数据
        userDao = new UserDao(data, this);
        // 查询出总页数
        pages = userDao.getPages();
        userDao.getObjects(nowpage);

        adapter = new UserAdapter(this, data);

        // 设置适配器
        lv_users.setAdapter(adapter);

        // 注册事件监听 滚动的事件
        lv_users.setOnScrollListener(this);
    

    /**
     * 当scrollstate改变的时候 都会触发该函数 scrollstate 0 空闲 1滚动 2抛 1 0 1 2 0
     */

    @Override
    public void onScrollStateChanged(AbsListView view, int scrollState) 

        // 判断是否是最后一行
        if (isLastRow) 
            // 再判断是否停止滚动
            if (scrollState == SCROLL_STATE_IDLE) 
                // pages = userDao.getPages();
                if (nowpage < pages) 
                    // 让当前页加1
                    nowpage = nowpage + 1;
                    // 假设往这个集合中添加数据
                    userDao.getObjects(nowpage);
                    // 通知变化
                    adapter.notifyDataSetChanged();
                
            
            // 改变值
            isLastRow = false;
        

    

    /**
     * 当滚动的时候触发的函数 firstVisibleItem:条目可见第一个位置值 visibleItemCount:条目可见的数量
     * totalItemCount data集合数量 条目总个数
     */
    @Override
    public void onScroll(AbsListView view, int firstVisibleItem,
            int visibleItemCount, int totalItemCount) 

        // 判断
        if ((firstVisibleItem + visibleItemCount) >= totalItemCount) 
            isLastRow = true;
        
    

以上是关于ListView显示数据库的数据-采用自定义布局-向上滑动可以加载更多数据的主要内容,如果未能解决你的问题,请参考以下文章

无法在 ListView 中使用自定义项目布局正确显示图像

Android之自定义LoadingViewHelper

为什么ListView与自定义适配器显示什么?

找不到有关如何在自定义小部件中使用 ListView 的正确布局选项

自定义listview数据源adapter时可以继承的类都有哪些

Android自定义Arrayadapter不显示数据