擷取到微博資料後,我們要自訂一個Adapter為首頁Listview提供資料,listView的item布局要包含微博的相關屬性,主要是微博內容,帳戶圖片,微博發表時間等,具體布局如下:
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:layout_width="fill_parent"android:layout_height="wrap_content"android:padding="3dip"android:background="@color/white"><LinearLayout android:orientation="horizontal"android:layout_width="fill_parent"android:layout_height="wrap_content"android:paddingTop="2dip"><ImageView android:id="@+id/user_logo"android:layout_width="wrap_content"android:layout_height="wrap_content"android:background="@drawable/ic_profile"/><RelativeLayout android:layout_width="fill_parent"android:layout_height="wrap_content"><TextView android:id="@+id/user_name"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textSize="18dip"android:paddingLeft="5dip"android:text="使用者名稱"android:layout_alignParentLeft="true"/><TextView android:id="@+id/time"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textSize="18dip"android:paddingRight="5dip"android:text="微博發表時間"android:layout_alignParentRight="true"/><TextView android:id="@+id/status_content"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_marginTop="5dip"android:textColor="#000000"android:textSize="18dip"android:text="微博內容"android:paddingLeft="5dip"android:paddingRight="1dip"android:layout_below="@id/time"/><ImageView android:id="@+id/picture"android:layout_marginTop="5dip"android:layout_width="150dip"android:layout_height="140dip"android:scaleType="fitXY"android:layout_below="@id/status_content"android:layout_centerHorizontal="true"android:visibility="gone"android:background="@drawable/edittext_background"/></RelativeLayout></LinearLayout></LinearLayout>
Adapter繼承與BaseAdapter要實現它的一些方法。具體代碼如下:
package com.cloay.weibo.adapter;import java.util.ArrayList;import java.util.List;import weibo4android.Status;import com.cloay.weibo.R;import com.cloay.weibo.utils.AsyncBitMapLoader;import com.cloay.weibo.utils.AsyncBitMapLoader.ImageCallback;import com.cloay.weibo.utils.TextHightUtil;import com.cloay.weibo.utils.TimeUtil;import android.content.Context;import android.graphics.Bitmap;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.BaseAdapter;import android.widget.ImageView;import android.widget.TextView;/** * 為首頁提供微博資料 * @author cloay * 2012-2-24 * 下午03:49:15 */public class HomeListAdapter extends BaseAdapter{private List<Status> listStatus = new ArrayList<Status>(); //微博內容private Context context;private LayoutInflater layoutInflater; //item布局public int listSize = 16;public HomeListAdapter(Context context, List<Status> listStatus){this.context = context;this.listStatus = listStatus; layoutInflater = LayoutInflater.from(this.context);}@Overridepublic int getCount() { //listView條目數if(76 == listSize){return 75;}return listSize;}@Overridepublic Object getItem(int position) {return null;}@Overridepublic long getItemId(int position) {return 0;}@Overridepublic View getView(int position, View convertView, ViewGroup parent) {int realPosition = getCount() - 1; //當是最後一個微博時,將更多條目隱藏if(75 == getCount()){realPosition = getCount();}if (position < realPosition) { convertView = layoutInflater.inflate( R.layout.home_list_item, null); final ImageView user_icon = (ImageView) convertView.findViewById(R.id.user_logo); //帳戶圖片AsyncBitMapLoader bitMap = new AsyncBitMapLoader();bitMap.loadBitMap(listStatus.get(position).getUser().getProfileImageUrl(), new ImageCallback() {//使用非同步方式載入帳戶圖片@Overridepublic void imageLoaded(Bitmap bitmap, String imageUrl) {user_icon.setImageBitmap(bitmap);}});TextView user_name = (TextView) convertView.findViewById(R.id.user_name); //使用者名稱//設定使用者名稱並高亮顯示user_name.setText(TextHightUtil.setTextHight(listStatus.get(position).getUser().getName()));TextView date = (TextView) convertView.findViewById(R.id.time); //微博發表時間TextView content = (TextView) convertView.findViewById(R.id.status_content);//微博內容//將話題、@的使用者、連結高亮顯示String statusText = listStatus.get(position).getText().toString();if(null != listStatus.get(position).getRetweeted_status()){statusText += listStatus.get(position).getRetweeted_status().getText().toString();}TextHightUtil.textHighlight(statusText, content);String picUrl = listStatus.get(position).getThumbnail_pic();if(!"".equals(picUrl)){final ImageView picture = (ImageView) convertView.findViewById(R.id.picture);picture.setVisibility(View.VISIBLE);bitMap.loadBitMap(picUrl, new ImageCallback() {//使用非同步方式載入微博圖片@Overridepublic void imageLoaded(Bitmap bitmap, String imageUrl) {picture.setImageBitmap(bitmap);}});}date.setText(TimeUtil.getCreateAt(listStatus.get(position).getCreatedAt())); }else{ convertView = layoutInflater.inflate( //顯示更多按鈕 R.layout.home_list_moreitem, null); }return convertView;}}
通過上述代碼我們就可以為微博首頁提供資料了。代碼比較簡單,就不做解釋了!
說明:轉載請註明出處!