新浪微博開發之為ListView設定微博資料

來源:互聯網
上載者:User

擷取到微博資料後,我們要自訂一個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;}}

通過上述代碼我們就可以為微博首頁提供資料了。代碼比較簡單,就不做解釋了!

說明:轉載請註明出處!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.