本文主要是介绍新浪微博开发之为ListView设置微博数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
获取到微博数据后,我们要自定义一个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;}
}
通过上述代码我们就可以为微博主页提供数据了。代码比较简单,就不做解释了!
说明:转载请注明出处!
这篇关于新浪微博开发之为ListView设置微博数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!