使用ListView显示学生信息

在上一篇博客(使用SQLite中自带的API操作SQLite数据库)中博主直接使用TextView显示从数据库中读取到的学生信息,其实这样做是很没有效率的,当数据库中有成百上千学生的信息时,需要一次性创建成百上千个TextView控件,这样会大大的消耗内存,实不可取的,在实际开发中也不会使用这种方式,Android中提供了一个ListView控件解决这个问题,使用ListView控件时,当从数据库中读取了很多个学生信息时,并不会直接创建多个条目,只会创建在可视区域中显示的条目,当滑动ListView控件时,被遮挡的条目会被销毁,这样可以极大地提高软件的运行效率

ListView的使用方法

1、在activity_main.xml的布局文件中添加ListView控件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.fyt.listviewdemo.MainActivity">

    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    </ListView>
</RelativeLayout>


在MainActivity中实现ListView的功能,实现的效果和上一篇博客使用SQLite中自带的API操作SQLite数据库)的效果一样,但是执行效率比直接使用TextView的效率高

package com.fyt.listviewdemo;

import android.app.Activity;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;

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

public class MainActivity extends Activity {

    private MyOpenHelper oh;
    private SQLiteDatabase db;
    private List<Student> studentList;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        //加载布局文件
        setContentView(R.layout.activity_main);

        //创建集合,保存学生的信息
        studentList = new ArrayList<Student>();

        //创建数据库
        createDatabase();

        //从数据库中读取数据
        readDataFromDatabase();

        //使用ListView显示学生的信息
        showStudentData();
    }

    //创建数据库
    public void createDatabase() {

        //创建帮助器对象
        oh = new MyOpenHelper(this, "people.db", null, 1);

        //创建数据库对象
        db = oh.getWritableDatabase();
    }

    //从数据库中读取数据
    public void readDataFromDatabase() {

        Cursor cursor = db.query("student", null, null, null, null, null, null, null);

        while(cursor.moveToNext())
        {
            String name = cursor.getString(cursor.getColumnIndex("name"));
            int age = cursor.getInt(cursor.getColumnIndex("age"));
            int no = cursor.getInt(cursor.getColumnIndex("no"));
            float cpp = cursor.getFloat(cursor.getColumnIndex("cpp"));
            float math = cursor.getFloat(cursor.getColumnIndex("math"));
            float english = cursor.getFloat(cursor.getColumnIndex("english"));

            Log.d("MainActivity", name + ", " + age + ", " + no + ", "
                    + cpp + ", " + math + ", " + english);

            //将学生的信息添加到集合中
            Student student = new Student(name, age, no, cpp, math, english);
            studentList.add(student);
        }
    }

    //使用ListView显示学生的信息
    public void showStudentData() {

        //获得布局文件上的ListView控件
        ListView listView = (ListView)findViewById(R.id.lv);

        //给ListView设置一个适配器
        listView.setAdapter(new MyAdapter());
    }

    //创建一个继承自BaseAdapter的内部类
    public class MyAdapter extends BaseAdapter {

        //由系统调用,用于设置ListView中条目的个数
        @Override
        public int getCount() {
            return studentList.size();
        }

        //由系统调用,获取一个View对象,作为ListView的条目
        @Override
        public View getView(int position, View convertView, ViewGroup parent) {

            Student student = studentList.get(position);

            TextView textView = new TextView(MainActivity.this);
            textView.setText(student.toString());
            textView.setTextSize(18);

            return textView;
        }

        @Override
        public Object getItem(int position) {
            return null;
        }

        @Override
        public long getItemId(int position) {
            return 0;
        }
    }
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值