Adapter是用来帮助填充数据的中间桥梁;
简单点说就是:将各种数据以合适的形式显示到view上
view:xml在java中的抽象引用
PS:由于个人理解也不是很透彻 下文就写一下如何使用吧
1、布局文件
将两个TextView水平放置 宽度比为1:2
接下来列表就会按照这个布局排布
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:orientation="horizontal" //水平布局
tools:ignore="HardcodedText">
<TextView
android:id="@+id/name"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:background="#2EA4FF"/>
<TextView
android:id="@+id/ability"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="2"
android:background="#0FC621"/>
</LinearLayout>
布局文件.png
2、适配器文件
public class TestListActivity {
public static class TestListAdapter extends BaseAdapter{ //文本适配器继承于BaseAdapter
private Context context;
private List<String> names; // List<> 详情见Q1
private List<String> abilitys;
TestListAdapter(Context context,List<String> names,List<String> abilitys){ //构造函数
this.context = context;
this.names = names;
this.abilitys = abilitys;
}
// @Override 复写标志 抽象方法需要复写
// 前三个不重要 重点在 getView()
@Override
public int getCount() {
return names.size();
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override // position 相当于循环中的 i
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder;
if(convertView==null){ //如果是第一次
//找到布局文件 详情见Q2
convertView = View.inflate(context, R.layout.layout_text, null);
viewHolder = new ViewHolder();
viewHolder.name = convertView.findViewById(R.id.name);
viewHolder.ability = convertView.findViewById(R.id.ability);
convertView.setTag(viewHolder);//详情见Q3
}else{
viewHolder = (ViewHolder) convertView.getTag(); //详情见Q3
}
viewHolder.name.setText(names.get(position));
viewHolder.ability.setText(abilitys.get(position));
return convertView;
}
private static class ViewHolder{ //详情见Q4
TextView name;
TextView ability;
}
}
}
Q1: List<>集合
List<>可以模拟所有的线性队列 以List<String>为例
/*构造集合 添加元素*/
//方法一:
ArrayList<String> list = new ArrayList<String>();
String str1 = String("test1");
String str2 = String("test2");
list.add(test1);
list.add(test2);
//方式二:
ArrayList<String> list = new ArrayList<String>(){{add("test1"); add("test2");}};
/*使用方法*/
list.size(); // 求长度 相当于 str.length
list.get(i); // 找元素 相当于 str[i]
list.add(str); //在队列后面添加元素 PS: 队列长度可变 每次加一
Q2: inflate() 和 findViewById()
Inflate()作用就是将xml定义的一个布局找出来,但仅仅是找出来而且隐藏的,没有找到的同时并显示功能。
如果你的Activity里用到别的layout,比如对话框layout,你还要设置这个layout上的其他组件的内容,你就必须用inflate()方法先将对话框的layout找出来,然后再用findViewById()找到它上面的其它组件
Q3: setTag() 和 getTag()?
Q4: ViewHolder 是干嘛的?
要想使用 ListView 就需要编写一个 Adapter 将数据适配到 ListView上,而为了节省资源提高运行效率,一般自定义类 ViewHolder 来减少 findViewById() 的使用以及避免过多地 inflate view,从而实现目标。
3、activity_main.xml中
<ListView
android:id="@+id/list1"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
4、MainActivity.onCreate()中
public class MainActivity<s, a> extends AppCompatActivity {
private ListView list1;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//建两个 List<String> 并赋值
List<String> name = new ArrayList<>();
List<String> ability = new ArrayList<>();
for (int i = 0; i < 10; i++) {
name.add("名字"+i);
ability.add("功能"+i);
}
// new一个适配器
TestListActivity.TestListAdapter adapter = new TestListActivity.TestListAdapter(context,name,ability);
list1 = findViewById(R.id.list1);
list1.setAdapter(adapter);
//单击一条 出现小框提示 “名字x 功能x”
list1.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
TextView name = view.findViewById(R.id.name);
TextView ability = view.findViewById(R.id.ability);
Toast.makeText(context, name.getText().toString() + " " + ability.getText().toString(), Toast.LENGTH_SHORT).show();
}
});
//长按一条 出现小框提示 “你长按了名字x”
list1.setOnItemLongClickListener(new AdapterView.OnItemLongClickListener() {
@Override
public boolean onItemLongClick(AdapterView<?> parent, View view, int position, long id) {
TextView name = view.findViewById(R.id.name);
Toast.makeText(context, "你长按了" + name.getText().toString(), Toast.LENGTH_SHORT).show();
return true;
}
});
}
}