Adapter是用來幫助填充數(shù)據(jù)的中間橋梁;
簡單點(diǎn)說就是:將各種數(shù)據(jù)以合適的形式顯示到view上
view:xml在java中的抽象引用
PS:由于個(gè)人理解也不是很透徹 下文就寫一下如何使用吧
1、布局文件
將兩個(gè)TextView水平放置 寬度比為1:2
接下來列表就會(huì)按照這個(gè)布局排布
<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){ //構(gòu)造函數(shù)
this.context = context;
this.names = names;
this.abilitys = abilitys;
}
// @Override 復(fù)寫標(biāo)志 抽象方法需要復(fù)寫
// 前三個(gè)不重要 重點(diǎn)在 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 相當(dāng)于循環(huán)中的 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<>可以模擬所有的線性隊(duì)列 以List<String>為例
/*構(gòu)造集合 添加元素*/
//方法一:
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(); // 求長度 相當(dāng)于 str.length
list.get(i); // 找元素 相當(dāng)于 str[i]
list.add(str); //在隊(duì)列后面添加元素 PS: 隊(duì)列長度可變 每次加一
Q2: inflate() 和 findViewById()
Inflate()作用就是將xml定義的一個(gè)布局找出來,但僅僅是找出來而且隱藏的,沒有找到的同時(shí)并顯示功能。
如果你的Activity里用到別的layout,比如對(duì)話框layout,你還要設(shè)置這個(gè)layout上的其他組件的內(nèi)容,你就必須用inflate()方法先將對(duì)話框的layout找出來,然后再用findViewById()找到它上面的其它組件
Q3: setTag() 和 getTag()?
Q4: ViewHolder 是干嘛的?
要想使用 ListView 就需要編寫一個(gè) Adapter 將數(shù)據(jù)適配到 ListView上,而為了節(jié)省資源提高運(yùn)行效率,一般自定義類 ViewHolder 來減少 findViewById() 的使用以及避免過多地 inflate view,從而實(shí)現(xiàn)目標(biāo)。
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);
//建兩個(gè) 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一個(gè)適配器
TestListActivity.TestListAdapter adapter = new TestListActivity.TestListAdapter(context,name,ability);
list1 = findViewById(R.id.list1);
list1.setAdapter(adapter);
//單擊一條 出現(xiàn)小框提示 “名字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();
}
});
//長按一條 出現(xiàn)小框提示 “你長按了名字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;
}
});
}
}