ListView的使用

ListView的使用

ListView

是一個用來展示處於垂直的滾動列表中的itemsView。這些Items來自與其相關聯的ListAdapterListAdapter繼承自Adapter,它是一個鏈接ListView 列表後面的數據的橋樑。Frequently that data comes from a Cursor, but that is not required.The ListView can display any data provided that it is wrapped in a ListAdapter.An Adapter object acts as a bridge between an AdapterViewand the underlying data for that view. The Adapter provides access to the dataitems. The Adapter is also responsible for making a Viewfor each item in the data set.

 wKiom1WBNqvwLV7_AAHOvpBnj8w705.jpg

使用ListView

wKiom1WBNuGibEWdAAbeRtLyyVE979.jpg

1.創建ListView

<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.cqjtu.yanguifeng.listview.MainActivity">
 
    <ListView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/lv_test"></ListView>
</RelativeLayout>


 

2.創建一個類,該類的對象包含了ListView中的子項中的數據。我們要創建的案例中,一個ListView中的子項包含了兩個TextView,一個TextView是大標題,另一個TextView是對大標題的詳細描述,如Memory標題下有一個4GB的描述。我們創建一個類,這個類有兩個成員變量,分別是描述ListView子項大標題和詳細描述的字符串。分別是title和content。如下所示

publicclass MyData
{
    private String title;
    private String content;
    
    public MyData(String title, String content)
    {
       this.title = title;
       this.content = content;
    }
    
    public String getContent()
    {
       returncontent;
    }
    public String getTitle()
    {
       returntitle;
    }
}


3.ListView中的子項創建佈局文件

<?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:orientation="vertical">
   
    <!-- 用來顯示子項數據之一的title -->
    <TextView
        android:id="@+id/tv_title"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:textSize="20sp"
       android:paddingTop="10dp"
        android:paddingLeft="5dp"/>
    
    <!-- 用來顯示子項數據之二的content -->
    <TextView
        android:id="@+id/tv_content"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingBottom="10dp"
        android:paddingLeft="5dp"
        android:textColor="#BFBFBF"/>
</LinearLayout>


4.創建自定義的Adapter類來加工自定義的類的對象

//創建適配器,使之能夠加工ListView子項背後的數據成爲ListView的子項
publicclass MyDataAdapter extendsArrayAdapter<MyData>
{
    private int itemLayoutId; // ListView子項的佈局文件ID
    public MyDataAdapter(Context context, intresource,List<MyData> objects)
    {
       super(context, resource, objects);
       itemLayoutId = resource;
    }
    
    //當ListView中的子項滾動到屏幕中時會調用這個方法來產生ListView的子項view,然後ListView顯示之
    @Override
    public View getView(intposition, View convertView, ViewGroup parent)
    {      
        // 根據position參數得到ListView子項後面的數據
       MyData myData = getItem(position);
       View view; // ListView的子項view
       ViewHolder viewHolder; // 存儲ListView子項view中的view
       if (convertView == null) // 如果沒有緩存
       {
           view = LayoutInflater.from(getContext()).inflate(itemLayoutId, null);
           viewHolder = new ViewHolder();
           // 將得到的view的ID保存在viewHolder的域中,方便以後的使用
           // 這種方法是爲了優化ListView的顯示而作的
           viewHolder.tv_title = (TextView) view.findViewById(R.id.tv_title);
           viewHolder.tv_content = (TextView) view.findViewById(R.id.tv_content);
           view.setTag(viewHolder);
       }
       else {
           view = convertView;
           viewHolder = (ViewHolder) view.getTag();
       }
       viewHolder.tv_title.setText(myData.getTitle());
       viewHolder.tv_content.setText(myData.getContent());
       returnview;
    }
    class ViewHolder
    {
       TextView tv_title;
       TextView tv_content;
    }
}

5.在代碼中顯式ListView

import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.Toast;
public class MainActivity extends Activity
{
private ListView lv_test;
private List<MyData> items = new ArrayList<MyData>();
// 初始化數據
private void init()
{
    MyData item1 = new MyData("手機型號", "MyPhone");
    items.add(item1);
    MyData item2 = new MyData("Android version", "4.4.4");
    items.add(item2);
    MyData item3 = new MyData("Processor", "MSM8974 four cores");
    items.add(item3);
    MyData item4 = new MyData("Memory", "4GB");
    items.add(item4);
    MyData item5 = new MyData("version", "123456");
    items.add(item5);
    MyData item6 = new MyData("Phone Number", "18523415974");
    items.add(item6);
    MyData item7 = new MyData("Name", "Yanguifeng");
    items.add(item7);
}
@Override
protected void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    init();
    lv_test = (ListView) findViewById(R.id.lv_test);
    MyDataAdapter adapter = new MyDataAdapter(this, R.layout.listview_item_layout, items);
    lv_test.setAdapter(adapter);
    lv_test.setOnItemClickListener(new OnItemClickListener()
    {
        @Override
        public void onItemClick(AdapterView<?> parent, View view,
        int position, long id)
        {
            MyData myData = (MyData) parent.getItemAtPosition(position);
            Toast.makeText(view.getContext(), myData.getTitle(), Toast.LENGTH_LONG).show();
        }
    });
}
@Override
public boolean onCreateOptionsMenu(Menu menu)
{
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }
    @Override
    public boolean onOptionsItemSelected(MenuItem item)
    {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings)
        {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}



2015-6-17日 創建




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章