国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 系統 > Android > 正文

android ListView深入理解

2020-04-11 12:41:14
字體:
來源:轉載
供稿:網友

  在android開發中ListView是比較常用的組件,它以列表的形式展示具體內容,并且能夠根據數據的長度自適應顯示。抽空把對ListView的使用做了整理,并寫了個小例子,如下圖。

 列表的顯示需要三個元素:

1.ListVeiw 用來展示列表的View。

2.適配器 用來把數據映射到ListView上的中介。

3.數據    具體的將被映射的字符串,圖片,或者基本組件。

根據列表的適配器類型,列表分為三種,ArrayAdapter,SimpleAdapter和SimpleCursorAdapter

其中以ArrayAdapter最為簡單,只能展示一行字。SimpleAdapter有最好的擴充性,可以自定義出各種效果。SimpleCursorAdapter可以認為是SimpleAdapter對數據庫的簡單結合,可以方面的把數據庫的內容以列表的形式展示出來。

 我們從最簡單的ListView開始:

復制代碼 代碼如下:

/**
* @author allin
*
*/
public class MyListView extends Activity {

private ListView listView;
//private List<String> data = new ArrayList<String>();
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);

listView = new ListView(this);
listView.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_expandable_list_item_1,getData()));
setContentView(listView);
}



private List<String> getData(){

List<String> data = new ArrayList<String>();
data.add("測試數據1");
data.add("測試數據2");
data.add("測試數據3");
data.add("測試數據4");

return data;
}
}

上面代碼使用了ArrayAdapter(Context context, int textViewResourceId, List<T> objects)來裝配數據,要裝配這些數據就需要一個連接ListView視圖對象和數組數據的適配器來兩者的適配工作,ArrayAdapter的構造需要三個參數,依次為this,布局文件(注意這里的布局文件描述的是列表的每一行的布局,android.R.layout.simple_list_item_1是系統定義好的布局文件只顯示一行文字,數據源(一個List集合)。同時用setAdapter()完成適配的最后工作。運行后的現實結構如下圖:

SimpleCursorAdapter

  sdk的解釋是這樣的:An easy adapter to map columns from a cursor to TextViews or ImageViews defined in an XML file. You can specify which columns you want, which views you want to display the columns, and the XML file that defines the appearance of these views。簡單的說就是方便把從游標得到的數據進行列表顯示,并可以把指定的列映射到對應的TextView中。

  下面的程序是從電話簿中把聯系人顯示到類表中。先在通訊錄中添加一個聯系人作為數據庫的數據。然后獲得一個指向數據庫的Cursor并且定義一個布局文件(當然也可以使用系統自帶的)。

/** * @author allin * */public class MyListView2 extends Activity {private ListView listView;//private List<String> data = new ArrayList<String>();@Overridepublic void onCreate(Bundle savedInstanceState){super.onCreate(savedInstanceState);listView = new ListView(this);Cursor cursor = getContentResolver().query(People.CONTENT_URI, null, null, null, null);startManagingCursor(cursor);ListAdapter listAdapter = new SimpleCursorAdapter(this, android.R.layout.simple_expandable_list_item_1, cursor,new String[]{People.NAME}, new int[]{android.R.id.text1});listView.setAdapter(listAdapter);setContentView(listView);}}

 Cursor cursor = getContentResolver().query(People.CONTENT_URI, null, null, null, null);先獲得一個指向系統通訊錄數據庫的Cursor對象獲得數據來源。

 startManagingCursor(cursor);我們將獲得的Cursor對象交由Activity管理,這樣Cursor的生命周期和Activity便能夠自動同步,省去自己手動管理Cursor。

 SimpleCursorAdapter 構造函數前面3個參數和ArrayAdapter是一樣的,最后兩個參數:一個包含數據庫的列的String型數組,一個包含布局文件中對應組件id的int型數組。其作用是自動的將String型數組所表示的每一列數據映射到布局文件對應id的組件上。上面的代碼,將NAME列的數據一次映射到布局文件的id為text1的組件上。

注意:需要在AndroidManifest.xml中如權限:<uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission>

運行后效果如下圖:

SimpleAdapter

simpleAdapter的擴展性最好,可以定義各種各樣的布局出來,可以放上ImageView(圖片),還可以放上Button(按鈕),CheckBox(復選框)等等。下面的代碼都直接繼承了ListActivity,ListActivity和普通的Activity沒有太大的差別,不同就是對顯示ListView做了許多優化,方面顯示而已。

下面的程序是實現一個帶有圖片的類表。

首先需要定義好一個用來顯示每一個列內容的xml

vlist.xml

復制代碼 代碼如下:

/**
* @author allin
*
*/
public class MyListView2 extends Activity {

private ListView listView;
//private List<String> data = new ArrayList<String>();
@Override
public void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);

listView = new ListView(this);

Cursor cursor = getContentResolver().query(People.CONTENT_URI, null, null, null, null);
startManagingCursor(cursor);

ListAdapter listAdapter = new SimpleCursorAdapter(this, android.R.layout.simple_expandable_list_item_1,
cursor,
new String[]{People.NAME},
new int[]{android.R.id.text1});

listView.setAdapter(listAdapter);
setContentView(listView);
}


}

下面是實現代碼:

復制代碼 代碼如下:

/**
* @author allin
*
*/
public class MyListView3 extends ListActivity {


// private List<String> data = new ArrayList<String>();
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);

SimpleAdapter adapter = new SimpleAdapter(this,getData(),R.layout.vlist,
new String[]{"title","info","img"},
new int[]{R.id.title,R.id.info,R.id.img});
setListAdapter(adapter);
}

private List<Map<String, Object>> getData() {
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();

Map<String, Object> map = new HashMap<String, Object>();
map.put("title", "G1");
map.put("info", "google 1");
map.put("img", R.drawable.i1);
list.add(map);

map = new HashMap<String, Object>();
map.put("title", "G2");
map.put("info", "google 2");
map.put("img", R.drawable.i2);
list.add(map);

map = new HashMap<String, Object>();
map.put("title", "G3");
map.put("info", "google 3");
map.put("img", R.drawable.i3);
list.add(map);

return list;
}
}

使用simpleAdapter的數據用一般都是HashMap構成的List,list的每一節對應ListView的每一行。HashMap的每個鍵值數據映射到布局文件中對應id的組件上。因為系統沒有對應的布局文件可用,我們可以自己定義一個布局vlist.xml。下面做適配,new一個SimpleAdapter參數一次是:this,布局文件(vlist.xml),HashMap的 title 和 info,img。布局文件的組件id,title,info,img。布局文件的各組件分別映射到HashMap的各元素上,完成適配。

運行效果如下圖:

有按鈕的ListView

但是有時候,列表不光會用來做顯示用,我們同樣可以在在上面添加按鈕。添加按鈕首先要寫一個有按鈕的xml文件,然后自然會想到用上面的方法定義一個適配器,然后將數據映射到布局文件上。但是事實并非這樣,因為按鈕是無法映射的,即使你成功的用布局文件顯示出了按鈕也無法添加按鈕的響應,這時就要研究一下ListView是如何現實的了,而且必須要重寫一個類繼承BaseAdapter。下面的示例將顯示一個按鈕和一個圖片,兩行字如果單擊按鈕將刪除此按鈕的所在行。并告訴你ListView究竟是如何工作的。效果如下:

vlist2.xml

復制代碼 代碼如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="fill_parent">


<ImageView android:id="@+id/img"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_margin="5px"/>

<LinearLayout android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="wrap_content">

<TextView android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#FFFFFFFF"
android:textSize="22px" />
<TextView android:id="@+id/info"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="#FFFFFFFF"
android:textSize="13px" />

</LinearLayout>


<Button android:id="@+id/view_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/s_view_btn"
android:layout_gravity="bottom|right" />
</LinearLayout>

程序代碼:

復制代碼 代碼如下:

/**
* @author allin
*
*/
public class MyListView4 extends ListActivity {
private List<Map<String, Object>> mData;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mData = getData();
MyAdapter adapter = new MyAdapter(this);
setListAdapter(adapter);
}
private List<Map<String, Object>> getData() {
List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
Map<String, Object> map = new HashMap<String, Object>();
map.put("title", "G1");
map.put("info", "google 1");
map.put("img", R.drawable.i1);
list.add(map);
map = new HashMap<String, Object>();
map.put("title", "G2");
map.put("info", "google 2");
map.put("img", R.drawable.i2);
list.add(map);
map = new HashMap<String, Object>();
map.put("title", "G3");
map.put("info", "google 3");
map.put("img", R.drawable.i3);
list.add(map);
return list;
}
// ListView 中某項被選中后的邏輯
@Override
protected void onListItemClick(ListView l, View v, int position, long id) {
Log.v("MyListView4-click", (String)mData.get(position).get("title"));
}
/**
* listview中點擊按鍵彈出對話框
*/
public void showInfo(){
new AlertDialog.Builder(this)
.setTitle("我的listview")
.setMessage("介紹...")
.setPositiveButton("確定", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
}
})
.show();
}
public final class ViewHolder{
public ImageView img;
public TextView title;
public TextView info;
public Button viewBtn;
}
public class MyAdapter extends BaseAdapter{
private LayoutInflater mInflater;
public MyAdapter(Context context){
this.mInflater = LayoutInflater.from(context);
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return mData.size();
}
@Override
public Object getItem(int arg0) {
// TODO Auto-generated method stub
return null;
}
@Override
public long getItemId(int arg0) {
// TODO Auto-generated method stub
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if (convertView == null) {
holder=new ViewHolder();
convertView = mInflater.inflate(R.layout.vlist2, null);
holder.img = (ImageView)convertView.findViewById(R.id.img);
holder.title = (TextView)convertView.findViewById(R.id.title);
holder.info = (TextView)convertView.findViewById(R.id.info);
holder.viewBtn = (Button)convertView.findViewById(R.id.view_btn);
convertView.setTag(holder);
}else {
holder = (ViewHolder)convertView.getTag();
}
holder.img.setBackgroundResource((Integer)mData.get(position).get("img"));
holder.title.setText((String)mData.get(position).get("title"));
holder.info.setText((String)mData.get(position).get("info"));
holder.viewBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
showInfo();
}
});
return convertView;
}
}
}

  下面將對上述代碼,做詳細的解釋,listView在開始繪制的時候,系統首先調用getCount()函數,根據他的返回值得到listView的長度(這也是為什么在開始的第一張圖特別的標出列表長度),然后根據這個長度,調用getView()逐一繪制每一行。如果你的getCount()返回值是0的話,列表將不顯示同樣return 1,就只顯示一行。

  系統顯示列表時,首先實例化一個適配器(這里將實例化自定義的適配器)。當手動完成適配時,必須手動映射數據,這需要重寫getView()方法。系統在繪制列表的每一行的時候將調用此方法。getView()有三個參數,position表示將顯示的是第幾行,covertView是從布局文件中inflate來的布局。我們用LayoutInflater的方法將定義好的vlist2.xml文件提取成View實例用來顯示。然后將xml文件中的各個組件實例化(簡單的findViewById()方法)。這樣便可以將數據對應到各個組件上了。但是按鈕為了響應點擊事件,需要為它添加點擊監聽器,這樣就能捕獲點擊事件。至此一個自定義的listView就完成了,現在讓我們回過頭從新審視這個過程。系統要繪制ListView了,他首先獲得要繪制的這個列表的長度,然后開始繪制第一行,怎么繪制呢?調用getView()函數。在這個函數里面首先獲得一個View(實際上是一個ViewGroup),然后再實例并設置各個組件,顯示之。好了,繪制完這一行了。那再繪制下一行,直到繪完為止。在實際的運行過程中會發現listView的每一行沒有焦點了,這是因為Button搶奪了listView的焦點,只要布局文件中將Button設置為沒有焦點就OK了。

運行效果如下圖:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
四虎免费播放| 豆国产97在线|亚洲| 6699久久国产精品免费| 国产色视频网站| ·天天天天操| 国产黄a三级三级三级av在线看| 国产精品美女一区二区视频| 在线视频三级| 青青草免费在线视频| 国产免费黄网站| 伊人影院在线视频| 福利在线国产| 在线国产小视频| 国产美女在线看| 精品国内一区二区三区免费视频| 午夜亚洲成人| 国产成人综合美国十次| 激情视频国产| 在线视频中文字幕久| 国产九色在线| jizz亚洲大全| 在线久久视频| 国产激情视频在线| 不卡av免费观看| 91在线网站| 国产精品久久久高清免费| 俺来俺也去www色在线观看| 国产精品久久久久白浆| 最近中文字幕大全中文字幕免费| 青娱乐在线视频观看| 在线免费观看黄色片| 国产精品被窝福利一区| 国产一区在线视频观看| 日韩黄色成人| eeuss影院www在线播放| 在线中文av| 精品国产高清自在线一区二区三区 | 久久精品视频免费看| 一色桃子av在线| 97最新国自产拍视频在线完整在线看| 国产久草在线| 国产美女福利在线| 九七电影韩国女主播在线观看| 亚洲欧美精品日韩欧美| 亚洲人av在线| 麻豆国产视频| 最近中文字幕在线中文视频 | www.三级.com| www在线免费观看视频| 日本电影全部在线观看网站视频| 亚洲国产精品区| 欧美色欧美亚洲另类二区精品| 免费a级毛片在线观看| 丁香花高清视频完整版在线观看| 国产精品一区二区婷婷| 国产三级视频在线| 四虎成人免费| 中文字幕在线免费视频| 精品国语对白精品自拍视| 亚洲成人在线播放| 免费精品国产自产拍观看| 国内a∨免费播放| 国产特黄在线| 中文在线有码| 国产免费自拍视频| 中文字幕av高清在线观看| 欧洲有码在线视频| 国产一级性片| 欧洲亚洲精品视频| 国产婷婷视频在线| 四虎成年永久免费网站| 国产一区精品| 免费a在线观看| 精品极品三级久久久久| 九九色在线观看| 97视频免费| 国产一区二区三区美女秒播 | 青青草视频在线免费观看| 最新中文字幕av专区| 日本在线观看网站| 9999在线视频| 国产香蕉在线| 国产理论在线观看| 另类高清dbsm日本tvav| 在线三级av| 国产精品福利视频一区二区三区| 高清av在线| 欧美卡一卡二| 精品视频麻豆入口| 国产高清在线看| 五月婷婷在线观看| 国产尤物视频| 99色在线视频| 天天av综合网| 国产免费永久在线观看| 激情丁香在线| 国产在线日本| 国产69精品久久app免费版| 白浆爆出在线观看| 欧美精品日韩少妇| 超碰在线国产| 五月天亚洲激情| 国产精品视频一区麻豆| 国产一二在线观看| 中文字幕在线免费视频| 国产美女免费观看| 国产亚洲精品午夜高清影院| 中文字幕第一页在线| 国产无遮挡又黄又爽免费网站| 国产一区电影| 18成年在线观看| av在线天堂| 九九色在线观看| 国产一级网站视频在线| 国产高清在线看| 亚洲wwwwww| 国产卡1卡2卡三卡在线| 国产精品入口麻豆电影| 精品视频麻豆入口| av在线中文| 最新天堂资源在线| 精品一区二区观看| 波多野结衣久久高清免费| 超碰在线观看免费版| 国产视频三级在线观看播放| 在线一区二区三区精品| 免费在线黄色av| 国产区av在线| 日本视频在线观看一区二区三区| 国产久草在线| 亚洲an天堂an在线观看| 国产香蕉视频在线看| 亚洲va国产日韩欧美精品色婷婷| 九九热视频在线| 国产一级粉嫩xxxx| www在线视频| 精灵使的剑舞无删减版在线观看| 久热中文字幕精品视频在线| 国产福利热线视频| 九九视频九九热| a视频免费看| 2019中文字幕在线电影免费| 九九热免费视频| www免费在线观看视频| 在线视频观看你懂的| 国产小视频在线高清播放| 人xxxx性xxxxx欧美| 6699久久国产精品免费| 国产一区二区影视| 欧美高清xxxx性| 日本视频二区| 亚洲成年人视频| 亚洲人在线播放| 亚洲永久免费网站| 伊人精品影院| 中文字幕av高清在线观看| 精品无人区乱码1区2区3区免费| 中文字幕网站视频在线| 午夜视频在线| 国产偷倩在线播放| 国产区卡一卡二卡三乱码免费| 成人超碰在线| 天堂在线免费观看| 国产精品视频一区二区久久| 久久五月精品| 成年人在线观看| 国产一二三四| 97一区二区三区| 亚洲第一成人在线视频| 日本高清中文字幕| 丁香花在线电影小说观看| 国产免费福利| 国产高清视频在线播放| 97国产在线| www.夜夜操.com| 成年网站免费入口在线观看| 天天av天天爱| 中文岛国精品亚洲一区| 青草视频在线播放| 麻豆视频在线观看免费网站| 国产麻豆精品视频一区二区| 国产精品bbw一区二区三区| 精品女厕厕露p撒尿| 日本动漫同人动漫在线观看| 国产乱妇乱子| 亚洲成人在线播放| 丁香综合五月| 在线视频观看亚洲| 天堂在线视频| a中文在线播放| 国产午夜电影| 日本高清中文字幕在线| 国产特级淫片免费看| 色欧美在线观看| 国产毛片毛片| free性亚洲| 伊人222成人综合网| 国产色视频网站| 免费高清av| 在线免费看黄av|