您当前的位置: 首页 > 学无止境 > 心得笔记 网站首页心得笔记
28_初次使用listview
发布时间:2021-02-19 15:33:27编辑:雪饮阅读()
listview
listview可算是一个可以滚动的视图列表吧
主要特点就是列表中元素数量较少时候一次性全部加载了,如果数量高于屏幕高度,则多余部分不加载等上滑时候才加载多余部分的每个item
修改之前activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center_horizontal"
android:orientation="vertical" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="所有账户的信息"
android:textSize="25sp"
/>
<ListView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/lv_all_person"
></ListView>
</LinearLayout>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center_horizontal"
android:orientation="vertical" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="所有账户的信息"
android:textSize="25sp"
/>
<ListView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/lv_all_person"
></ListView>
</LinearLayout>
然后之前的MainActivity.java中修改代码实现通过数据适配器来渲染ListView
package com.example.myapplication;
import androidx.appcompat.app.AppCompatActivity;
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.List;
public class MainActivity extends AppCompatActivity {
private ListView mListView;
private List<Person> persons;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 第一步得到 组件的id的引用
mListView = (ListView) this.findViewById(R.id.lv_all_person);
PersonDao dao = new PersonDao(this);
persons = dao.findAll();
// 第二步 设置组件要显示的内容
// listview 显示的东西 比较复杂,需要数据的适配器
mListView.setAdapter(new MyAdatper());
}
// BaseAdapter 是 google的工程师 给ListAdapter的默认实现
public class MyAdatper extends BaseAdapter {
/**
* 返回当前listview有多少个条目
*/
public int getCount() {
return persons.size();
}
/**
* 返回当前position位置对应的条目 的object对象
*/
public Object getItem(int position) {
return persons.get(position);
}
/**
* 返回当前position位置 某个条目的id
*/
public long getItemId(int position) {
return position;
}
/**
* 返回每一个条目显示的具体内容
*
* 计算当前界面 会有多少个条目出现 :
* 1.得到每一个textview的高度 2.得到listview的高度 3. listview高度/textview高度 = 得到了一个屏幕显示的textview的个数
*
* listview的每一个条目的显示 都需要调用一次getview的方法 屏幕上有多个item显示 就会调用多少getview的方法
* 一般情况下getCount返回的数量较小的时候(例如屏幕高度足够容下这些数量甚至还有多余空间),则调用次数就是
* getCount次,如果数量较大的时候(例如直接超过屏幕高度好多的时候),则一屏可能显示不完,此时如果上滑屏幕获取更多显示item时候
* 则每可见一个新的item则就调用一次getView
*/
public View getView(int position, View convertView, ViewGroup parent) {
TextView tv = new TextView(MainActivity.this);
tv.setText("我是第"+position+"个文本");
Person person =persons.get(position);
tv.setText(person.getName() +" | "+person.getAge() );
Log.i("chuChong","我被调用了 "+ position);
return tv;
}
}
}
最后的效果:
布局填充服务(加载布局文件xml)
为每个item加载独立的xml文件,而不是直接通过代码new一个视图,这样视图与代码分开看着更舒服点。
建立独立的视图文件item.xml,与activity_main.xml在同一个目录
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/tv_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:text="xingming"
android:textColor="#ffff66ff"
android:textSize="18sp" />
<TextView
android:id="@+id/tv_age"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:text="age"
android:textColor="#ffff66ff"
android:textSize="18sp" />
</RelativeLayout>
然后在MainActivity.java中用LayoutInflater完成item.xml的加载(布局填充)
package com.example.myapplication;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private ListView mListView;
private List<Person> persons;
private LayoutInflater inflater; // 打气筒 ,充气泵
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// inflater 是系统的一个服务 初始化服务(布局填充服务)
inflater = (LayoutInflater) this.getSystemService(LAYOUT_INFLATER_SERVICE);
// 第一步得到 组件的id的引用
mListView = (ListView) this.findViewById(R.id.lv_all_person);
PersonDao dao = new PersonDao(this);
persons = dao.findAll();
// 第二步 设置组件要显示的内容
// listview 显示的东西 比较复杂,需要数据的适配器
mListView.setAdapter(new MyAdatper());
}
// BaseAdapter 是 google的工程师 给ListAdapter的默认实现
public class MyAdatper extends BaseAdapter {
/**
* 返回当前listview有多少个条目
*/
public int getCount() {
return persons.size();
}
/**
* 返回当前position位置对应的条目 的object对象
*/
public Object getItem(int position) {
return persons.get(position);
}
/**
* 返回当前position位置 某个条目的id
*/
public long getItemId(int position) {
return position;
}
/**
* 返回每一个条目显示的具体内容
*
* 计算当前界面 会有多少个条目出现 :
* 1.得到每一个textview的高度 2.得到listview的高度 3. listview高度/textview高度 = 得到了一个屏幕显示的textview的个数
*
* listview的每一个条目的显示 都需要调用一次getview的方法 屏幕上有多个item显示 就会调用多少getview的方法
* 一般情况下getCount返回的数量较小的时候(例如屏幕高度足够容下这些数量甚至还有多余空间),则调用次数就是
* getCount次,如果数量较大的时候(例如直接超过屏幕高度好多的时候),则一屏可能显示不完,此时如果上滑屏幕获取更多显示item时候
* 则每可见一个新的item则就调用一次getView
*/
public View getView(int position, View convertView, ViewGroup parent) {
//参数1 本次获取视图所用的独立视图文件(xml) 参数2 填充的根视图(这里用不到,可以写null)
View view = inflater.inflate(R.layout.item, null);
Person person = persons.get(position);
TextView tv_age = (TextView) view.findViewById(R.id.tv_age);
TextView tv_name = (TextView) view.findViewById(R.id.tv_name);
tv_age.setText("年龄为 " + person.getAge());
tv_name.setText("姓名:" + person.getName());
Log.i("chuChong","我被调用了 "+ position);
return view;
}
}
}
最后效果如:
关键字词:listview,android