標籤:
1.這篇博文不算什麼知識點。使用的都是的系統中已經提供給我們的方式方法。這是最近用到了,感覺很實用,特此貢獻出來。
首先需要定義,listview中需要展示的view個數,和view的布布局類型
private final int TYPE_1 = 0; 類型1
private final int TYPE_2 = 1; 類型2
private final int VIEW_TYPE = 2; 總布局數
@Override
public int getItemViewType(int position) {
if (position == 0 || position == weeklyCount + 1 || position == weeklyCount + tasteCount + 2)
return TYPE_2;
else
return TYPE_1;
}
public int getViewTypeCount() {
return VIEW_TYPE;
}
/-------------------------------------------------------------------------------------******-------------------------------------------------------------------/
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
ViewHolder viewHolder = null;
ViewHolder2 viewHolderf = null;
int type = getItemViewType(position);
if (convertView == null) {
switch (type) { // 各個布局中使用的資源進行初始化
case TYPE_1:
viewHolder = new ViewHolder();
convertView = View.inflate(context, R.layout.item_ranking_user_top, null);
viewHolder.txtview_votesize = (TextView) convertView.findViewById(R.id.txtview_votesize);
viewHolder.txtview_fontnumber = (TextView) convertView.findViewById(R.id.txtview_fontnumber);
viewHolder.username = (TextView) convertView.findViewById(R.id.txtview_username);
viewHolder.imgbtn_attention = (ImageButton) convertView.findViewById(R.id.imgbtn_attention);
viewHolder.imgcrown = (ImageView) convertView.findViewById(R.id.img_crown);
viewHolder.iv_userheade = (CircularImage) convertView.findViewById(R.id.img_userheader);
viewHolder.cellContainer = (RelativeLayout) convertView.findViewById(R.id.fragment_container);
convertView.setTag(viewHolder);
break;
case TYPE_2:
viewHolderf = new ViewHolder2();
convertView = View.inflate(context, R.layout.item_ranking_title, null);
viewHolderf.txtview_catagory = (TextView) convertView.findViewById(R.id.txtview_catagory);
viewHolderf.imgview_rankingtitle = (ImageView) convertView.findViewById(R.id.imgview_rankingtitle);
convertView.setTag(viewHolderf);
break;
}
} else { //緩衝用複
switch (type) {
case TYPE_1:
viewHolder = (ViewHolder) convertView.getTag();
break;
case TYPE_2:
viewHolderf = (ViewHolder2) convertView.getTag();
break;
}
}
switch (type) {
case TYPE_1:
break;
case TYPE_2:
break; //......... 給各個布局需要展示內容 進行賦值
其他的也不過進行描述了,之前一直沒有這樣寫,以為一個listview中顯示不同的布局很麻煩。就使用其他的方式了。一直沒有自己動手寫,這次項目中用到,所以自己找了點資料看了一下。
下面項目中的真實
1項目背景是,有一個熱門排行榜,三個不同的對象。周排行,熱度排行,最受歡迎的排行。因為對象不同,所以處理起來挺麻煩的 ,一堆的判斷語句。下周一,需要review一下代碼,不然,會被批的哦。
這裡裡的標題背景是一個veiw ,類別展示是一個類別
說到這裡,正好把,這個簡單的演算法說一下,如何算出來,標題在listvew中的具體位置。
到這裡就差不多了,突然發現 getveiwcount() 和 getviewtype() 配合著 標題的這個簡單位置演算法,用起來,少了,很多煩惱。很順利的就解決了這個分類問題
android listView的item 顯示多種不同的布局