2022年3月15日 星期二

android studio:ListView

 ListView是一種陳列清單資料的視圖,如果需要陳列一些較規律性的資料,利用TextView慢慢編排,過於麻煩,便可利用ListView這個視圖,將資料快速顯現於營幕上面。

(一)使用用法一

可以於string.xml中設定string array,將想要於ListView列表的文字快速的設定好,而後在MainActivity.xml,或其它的xml,透過android:entries這個屬性,引入此string array即可。

如下:

string.xml 設定

<resources>
<string name="app_name">ListView</string> //此專案的名字
<string-array name="listview1"> //清單的名字,引用時為@array/listview1
<item>文字1</item> //清單項目一
<item>文字2</item> //清單項目二
<item>文字3</item> //清單項目三
</string-array>
</resources>


MainActivity.xml

<ListView
android:id="@+id/listview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="1dp"
android:layout_marginTop="1dp"
android:layout_marginBottom="584dp"
android:entries="@array/listview1"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="1.0" />
上面的屬性可以自由設定,重點是記得android:entries 這個屬性後面需放入上面你於String自己設定的array清單 @array/listview1 ,這樣執行後,便可在視圖中,看到你建立的listview

最後,若要於專案裡,使用listview,你可以引入listview後,利用setOnItemClickListener的方法監聽,如下:
package com.example.listview;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;

public class MainActivity extends AppCompatActivity {
private ListView listview;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listview=findViewById(R.id.listview);

//設定監聽listview時,進行以下的項目
listview.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
//adapterView 元件,指Listview ,view指該元件視圖,i為點選的為第幾個項目,l指被點擊項目的id
Log.v("acao", String.valueOf(i)); //i為你選的第幾項
Log.v("acao",adapterView.getItemAtPosition(i).toString()); //adapterView.getItemAtPosition(i)為listview中i項的文字內容

}
});
}
}

(二)使用用法二(自製用法)
ListView若透過adapter(調變器)的控制可以有更多的變化,簡單的變化可以透過ArrayAdapter、SimpleCursorAdapter、SimpleAdapter這些類別,如果要有自定的視圖,可以透過繼承BaseAdapter這個類別,使用的方法如下:
(1)製作一個xml,這個xml與activity_main.xml不同,activity_main.xml是為了整個畫面規劃,而現在的xml,只為了自製ListView這個部份。在下面建立了一個名為mylistview.xml的檔案,裡面設定兩個textView顯示要呈現的資料。
。<?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:background="#DEF8FF">

<LinearLayout
android:id="@+id/myxml"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="5dp">

<TextView
android:id="@+id/mytext1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="2"
android:text="TextView"
android:textColor="@android:color/black"
android:textSize="20sp" />

<TextView
android:id="@+id/mytext2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="TextView"
android:textColor="@android:color/black"
android:textSize="20sp" />

</LinearLayout>
</LinearLayout>

(2)製作一個繼承BaseAdapter 的adapter,這個adapter會有getCount()、getItem(int i)、getItemId(int i)、getView(int i, View view, ViewGroup viewGroup)四個方法。





沒有留言:

張貼留言