ListView具備多種item佈局——實現微信對話列

 這篇文章的效果也是你們常見的,各類通信應用的對話列表都是這種方式,像微信、whatsapp、易信、米聊等。咱們這篇文章也權當爲回憶,造成簡單的筆記。這篇文章參考了2009年Google IO中的《TurboChargeYourUI-How to make your AndroidUI fast and efficient》和2010年Google IO中的《The World of List View》。像2009年Google IO的資料仍是很前沿的,那會android開發資料不多,最重要的就是參考google發佈的各類資料。java

 

    在《TurboChargeYourUI-How to make your AndroidUI fast and efficient》介紹了怎樣提升listview的性能,優化了listview的加載速度。這裏的item使用的是單一佈局,可以實現view的重用和回收,那麼多種佈局文件的怎麼辦呢,若是再使用上面的方法,view的重用會出現問題,Android使用的BaseAdapter提供瞭解決多種佈局文件的重用方法。android

 

1)重寫 getViewTypeCount() – 該方法返回多少個不一樣的佈局微信

2)重寫 getItemViewType(int) – 根據position返回相應的Itemapp

 

[java]  view plain copy print ? 在CODE上查看代碼片 派生到個人代碼片
 
  1. /** 
  2.  * 比原來的多了getItemViewType和getViewTypeCount這兩個方法, 
  3.  *  
  4.  * */  
  5. public class ChatAdapter extends BaseAdapter {  
  6.   
  7.     public static final String KEY = "key";  
  8.     public static final String VALUE = "value";  
  9.   
  10.     public static final int VALUE_TIME_TIP = 0;// 7種不一樣的佈局  
  11.     public static final int VALUE_LEFT_TEXT = 1;  
  12.     public static final int VALUE_LEFT_IMAGE = 2;  
  13.     public static final int VALUE_LEFT_AUDIO = 3;  
  14.     public static final int VALUE_RIGHT_TEXT = 4;  
  15.     public static final int VALUE_RIGHT_IMAGE = 5;  
  16.     public static final int VALUE_RIGHT_AUDIO = 6;  
  17.     private LayoutInflater mInflater;  
  18.   
  19.     private List<Message> myList;  
  20.   
  21.     public ChatAdapter(Context context, List<Message> myList) {  
  22.         this.myList = myList;  
  23.   
  24.         mInflater = (LayoutInflater) context  
  25.                 .getSystemService(Context.LAYOUT_INFLATER_SERVICE);  
  26.     }  
  27.   
  28.     @Override  
  29.     public int getCount() {  
  30.         return myList.size();  
  31.     }  
  32.   
  33.     @Override  
  34.     public Object getItem(int arg0) {  
  35.         return myList.get(arg0);  
  36.     }  
  37.   
  38.     @Override  
  39.     public long getItemId(int arg0) {  
  40.         return arg0;  
  41.     }  
  42.   
  43.     @Override  
  44.     public View getView(int position, View convertView, ViewGroup arg2) {  
  45.   
  46.         Message msg = myList.get(position);  
  47.         int type = getItemViewType(position);  
  48.         ViewHolderTime holderTime = null;  
  49.         ViewHolderRightText holderRightText = null;  
  50.         ViewHolderRightImg holderRightImg = null;  
  51.         ViewHolderRightAudio holderRightAudio = null;  
  52.         ViewHolderLeftText holderLeftText = null;  
  53.         ViewHolderLeftImg holderLeftImg = null;  
  54.         ViewHolderLeftAudio holderLeftAudio = null;  
  55.           
  56.         if (convertView == null) {  
  57.             switch (type) {  
  58.             case VALUE_TIME_TIP:  
  59.                 holderTime = new ViewHolderTime();  
  60.                 convertView = mInflater.inflate(R.layout.list_item_time_tip,  
  61.                         null);  
  62.                 holderTime.tvTimeTip = (TextView) convertView  
  63.                         .findViewById(R.id.tv_time_tip);  
  64.                 holderTime.tvTimeTip.setText(msg.getValue());  
  65.                 convertView.setTag(holderTime);  
  66.                 break;  
  67.             // 左邊  
  68.             case VALUE_LEFT_TEXT:  
  69.                 holderLeftText = new ViewHolderLeftText();  
  70.                 convertView = mInflater.inflate(R.layout.list_item_left_text,  
  71.                         null);  
  72.                 holderLeftText.ivLeftIcon = (ImageView) convertView  
  73.                         .findViewById(R.id.iv_icon);  
  74.                 holderLeftText.btnLeftText = (Button) convertView  
  75.                         .findViewById(R.id.btn_left_text);  
  76.                 holderLeftText.btnLeftText.setText(msg.getValue());  
  77.                 convertView.setTag(holderLeftText);  
  78.                 break;  
  79.   
  80.             case VALUE_LEFT_IMAGE:  
  81.                 holderLeftImg = new ViewHolderLeftImg();  
  82.                 convertView = mInflater.inflate(R.layout.list_item_left_iamge,  
  83.                         null);  
  84.                 holderLeftImg.ivLeftIcon = (ImageView) convertView  
  85.                         .findViewById(R.id.iv_icon);  
  86.                 holderLeftImg.ivLeftImage = (ImageView) convertView  
  87.                         .findViewById(R.id.iv_left_image);  
  88.                 holderLeftImg.ivLeftImage.setImageResource(R.drawable.test);  
  89.                 convertView.setTag(holderLeftImg);  
  90.                 break;  
  91.   
  92.             case VALUE_LEFT_AUDIO:  
  93.                 holderLeftAudio = new ViewHolderLeftAudio();  
  94.                 convertView = mInflater.inflate(R.layout.list_item_left_audio,  
  95.                         null);  
  96.                 holderLeftAudio.ivLeftIcon = (ImageView) convertView  
  97.                         .findViewById(R.id.iv_icon);  
  98.                 holderLeftAudio.btnLeftAudio = (Button) convertView  
  99.                         .findViewById(R.id.btn_left_audio);  
  100.                 holderLeftAudio.tvLeftAudioTime = (TextView) convertView  
  101.                         .findViewById(R.id.tv_left_audio_time);  
  102.                 holderLeftAudio.tvLeftAudioTime.setText(msg.getValue());  
  103.                 convertView.setTag(holderLeftAudio);  
  104.                 break;  
  105.             // 右邊  
  106.             case VALUE_RIGHT_TEXT:  
  107.                 holderRightText= new ViewHolderRightText();  
  108.                 convertView = mInflater.inflate(R.layout.list_item_right_text,  
  109.                         null);  
  110.                 holderRightText.ivRightIcon = (ImageView) convertView  
  111.                         .findViewById(R.id.iv_icon);  
  112.                 holderRightText.btnRightText = (Button) convertView  
  113.                         .findViewById(R.id.btn_right_text);  
  114.                 holderRightText.btnRightText.setText(msg.getValue());  
  115.                 convertView.setTag(holderRightText);  
  116.                 break;  
  117.   
  118.             case VALUE_RIGHT_IMAGE:  
  119.                 holderRightImg= new ViewHolderRightImg();  
  120.                 convertView = mInflater.inflate(R.layout.list_item_right_iamge,  
  121.                         null);  
  122.                 holderRightImg.ivRightIcon = (ImageView) convertView  
  123.                         .findViewById(R.id.iv_icon);  
  124.                 holderRightImg.ivRightImage = (ImageView) convertView  
  125.                         .findViewById(R.id.iv_right_image);  
  126.                 holderRightImg.ivRightImage.setImageResource(R.drawable.test);  
  127.                 convertView.setTag(holderRightImg);  
  128.                 break;  
  129.   
  130.             case VALUE_RIGHT_AUDIO:  
  131.                 holderRightAudio=new ViewHolderRightAudio();  
  132.                 convertView = mInflater.inflate(R.layout.list_item_right_audio,  
  133.                         null);  
  134.                 holderRightAudio.ivRightIcon = (ImageView) convertView  
  135.                         .findViewById(R.id.iv_icon);  
  136.                 holderRightAudio.btnRightAudio = (Button) convertView  
  137.                         .findViewById(R.id.btn_right_audio);  
  138.                 holderRightAudio.tvRightAudioTime = (TextView) convertView  
  139.                         .findViewById(R.id.tv_right_audio_time);  
  140.                 holderRightAudio.tvRightAudioTime.setText(msg.getValue());  
  141.                 convertView.setTag(holderRightAudio);  
  142.                 break;  
  143.   
  144.             default:  
  145.                 break;  
  146.             }  
  147.               
  148.         } else {  
  149.             Log.d("baseAdapter""Adapter_:"+(convertView == null) );  
  150.             switch (type) {  
  151.             case VALUE_TIME_TIP:  
  152.                 holderTime=(ViewHolderTime)convertView.getTag();  
  153.                 holderTime.tvTimeTip.setText(msg.getValue());  
  154.                 break;  
  155.             case VALUE_LEFT_TEXT:  
  156.                 holderLeftText=(ViewHolderLeftText)convertView.getTag();  
  157.                 holderLeftText.btnLeftText.setText(msg.getValue());  
  158.                 break;  
  159.             case VALUE_LEFT_IMAGE:  
  160.                 holderLeftImg=(ViewHolderLeftImg)convertView.getTag();  
  161.                 holderLeftImg.ivLeftImage.setImageResource(R.drawable.test);  
  162.                 break;  
  163.             case VALUE_LEFT_AUDIO:  
  164.                 holderLeftAudio=(ViewHolderLeftAudio)convertView.getTag();  
  165.                 holderLeftAudio.tvLeftAudioTime.setText(msg.getValue());  
  166.                 break;  
  167.             case VALUE_RIGHT_TEXT:  
  168.                 holderRightText=(ViewHolderRightText)convertView.getTag();  
  169.                 holderRightText.btnRightText.setText(msg.getValue());  
  170.                 break;  
  171.             case VALUE_RIGHT_IMAGE:  
  172.                 holderRightImg=(ViewHolderRightImg)convertView.getTag();  
  173.                 holderRightImg.ivRightImage.setImageResource(R.drawable.test);  
  174.                 break;  
  175.             case VALUE_RIGHT_AUDIO:  
  176.                 holderRightAudio=(ViewHolderRightAudio)convertView.getTag();  
  177.                 holderRightAudio.tvRightAudioTime.setText(msg.getValue());  
  178.                 break;  
  179.   
  180.             default:  
  181.                 break;  
  182.             }  
  183.               
  184.             //holder = (ViewHolder) convertView.getTag();  
  185.         }  
  186.         return convertView;  
  187.     }  
  188.   
  189.     /** 
  190.      * 根據數據源的position返回須要顯示的的layout的type 
  191.      *  
  192.      * type的值必須從0開始 
  193.      *  
  194.      * */  
  195.     @Override  
  196.     public int getItemViewType(int position) {  
  197.   
  198.         Message msg = myList.get(position);  
  199.         int type = msg.getType();  
  200.         Log.e("TYPE:""" + type);  
  201.         return type;  
  202.     }  
  203.   
  204.     /** 
  205.      * 返回全部的layout的數量 
  206.      *  
  207.      * */  
  208.     @Override  
  209.     public int getViewTypeCount() {  
  210.         return 7;  
  211.     }  
  212.   
  213.     class ViewHolderTime {  
  214.         private TextView tvTimeTip;// 時間  
  215.     }  
  216.   
  217.     class ViewHolderRightText {  
  218.         private ImageView ivRightIcon;// 右邊的頭像  
  219.         private Button btnRightText;// 右邊的文本  
  220.     }  
  221.   
  222.     class ViewHolderRightImg {  
  223.         private ImageView ivRightIcon;// 右邊的頭像  
  224.         private ImageView ivRightImage;// 右邊的圖像  
  225.     }  
  226.   
  227.     class ViewHolderRightAudio {  
  228.         private ImageView ivRightIcon;// 右邊的頭像  
  229.         private Button btnRightAudio;// 右邊的聲音  
  230.         private TextView tvRightAudioTime;// 右邊的聲音時間  
  231.     }  
  232.   
  233.     class ViewHolderLeftText {  
  234.         private ImageView ivLeftIcon;// 左邊的頭像  
  235.         private Button btnLeftText;// 左邊的文本  
  236.     }  
  237.   
  238.     class ViewHolderLeftImg {  
  239.         private ImageView ivLeftIcon;// 左邊的頭像  
  240.         private ImageView ivLeftImage;// 左邊的圖像  
  241.     }  
  242.   
  243.     class ViewHolderLeftAudio {  
  244.         private ImageView ivLeftIcon;// 左邊的頭像  
  245.         private Button btnLeftAudio;// 左邊的聲音  
  246.         private TextView tvLeftAudioTime;// 左邊的聲音時間  
  247.     }  
  248.   
  249. }  

 

 

 

分享兩張微信、易信的圖,你也能夠作成這樣子。ide

     

 

Demo下載,請猛擊。佈局

 

 

 

 

/**
* @author 張興業
*  iOS入門羣:83702688
*  android開發進階羣:241395671
*  個人新浪微博:@張興業TBOW
*/
相關文章
相關標籤/搜索