/>
layout/layout_list_item.xml
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android=“http://schemas.android.com/apk/res/android”
android:layout_width=“match_parent”
android:layout_height=“match_parent”
<ImageView
android:id=“@+id/iv_head”
android:layout_width=“50dp”
android:layout_height=“50dp”
android:layout_margin=“10dp”
android:src=“@drawable/pic_6”
/>
<TextView
android:id=“@+id/tv_name”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_toRightOf=“@+id/iv_head”
android:layout_alignTop=“@+id/iv_head”
android:textSize=“16sp”
android:text=“凤姐”/>
<TextView
android:id=“@+id/tv_desc”
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_toRightOf=“@+id/iv_head”
android:layout_below=“@+id/tv_name”
android:layout_marginTop=“10dp”
android:textSize=“14sp”
android:text=“你才是一个没有故事的女同学”/>
常用属性说明:
android:cacheColorHint=”#00000000” //设置拖动背景色为透明
android:dividerHeight=”30px” //listview item之间的高度
android:divider=”@drawable/ic_launcher” //listview item之间的背景或者说是颜色
android:fadingEdge=”vertical” //上边和下边有黑色的阴影 值为none的话就没有阴影
android:scrollbars=”horizontal|none” //只有值为horizontal|vertical的时候,才会显示滚动条,并且会自动影藏和显示
android:fastScrollEnabled=”true” //快速滚动效果,配置这个属性,在快速滚动的时候旁边会出现一个小方块的快速滚动效果,自动隐藏和显示,
android:scrollbarStyle=”outsideInset” //四个值的含义如下
1>outsideInset : 该ScrollBar显示在视图(view)的边缘,增加了view的padding. 如果可能的话,该ScrollBar仅仅覆盖这个view的背景.
2>outsideOverlay : 该ScrollBar显示在视图(view)的边缘,不增加view的padding,该ScrollBar将被半透明覆盖
3>insideInset :该ScrollBar显示在padding区域里面,增加了控件的padding区域,该ScrollBar不会和视图的内容重叠.
4>insideOverlay : 该ScrollBar显示在内容区域里面,不会增加了控件的padding区域,该ScrollBar以半透明的样式覆盖在视图(view)的内容上.
首先是stackFromBottom属性,这只该属性之后你做好的列表就会显示你列表的最下面,值为true和false
android:stackFromBottom=”true”
第二是 transciptMode属性,需要用ListView或者其它显示大量Items的控件实时跟踪或者查看信息,并且希望最新的条目可以自动滚动到可视范围内。通过设置的控件transcriptMode属性可以将Android平台的控件(支持ScrollBar)自动滑动到最底部。 android:transcriptMode=”alwaysScroll”
第三cacheColorHint属性,很多人希望能够改变一下它的背景,使他能够符合整体的UI设计,改变背景背很简单只需要准备一张图片然后指定属性 android:background=”@drawable/bg”,不过不要高兴地太早,当你这么做以后,发现背景是变了,但是当你拖动,或者点击list空白位置的时候发现ListItem都变成黑色的了,破坏了整体效果。
如果你只是换背景的颜色的话,可以直接指定android:cacheColorHint为你所要的颜色,如果你是用图片做背景的话,那也只要将android:cacheColorHint指定为透明(#00000000)就可以了
第四divider属性,该属性作用是每一项之间需要设置一个图片做为间隔,或是去掉item之间的分割线
android:divider=”@drawable/list_driver” 其中 @drawable/list_driver 是一个图片资源,如果不想显示分割线则只要设置为android:divider=”@drawable/@null” 就可以了
第五fadingEdge属性,上边和下边有黑色的阴影
android:fadingEdge=”none” 设置后没有阴影了~
第六scrollbars属性,作用是隐藏listView的滚动条,
android:scrollbars=”none”与setVerticalScrollBarEnabled(true);的效果是一样的,不活动的时候隐藏,活动的时候也隐藏
第七fadeScrollbars属性,android:fadeScrollbars=”true” 配置ListView布局的时候,设置这个属性为true就可以实现滚动条的自动隐藏和显示。
Second Step:更加数据结构创建实体类
package com.devilwwj.androiddevelopcourse.domain;
/**
- Created by devilwwj on 15/10/7.
*/
public class User {
private String imageUrl;
private String name;
private String description;
public String getImageUrl() {
return imageUrl;
}
public void setImageUrl(String imageUrl) {
this.imageUrl = imageUrl;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
@Override
public String toString() {
return “User{” +
“imageUrl='” + imageUrl + ‘’’ +
“, name='” + name + ‘’’ +
“, description='” + description + ‘’’ +
‘}’;
}
}
Third Step:Activity展示
package com.devilwwj.androiddevelopcourse.activities;
import android.content.Context;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.ListView;
import android.widget.TextView;
import com.devilwwj.androiddevelopcourse.R;
import com.devilwwj.androiddevelopcourse.domain.User;
import java.util.ArrayList;
import java.util.List;
/**
-
A020-列表容器之ListView
-
@author devilwwj
*/
public class ListViewTestActivity extends ActionBarActivity implements OnItemClickListener{
private ListView mListView;
private ListViewAdapter mAdapter;
private Context mContext;
private List userList;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_listview);
mContext = ListViewTestActivity.this;
mListView = (ListView) this.findViewById(R.id.listView);
/* 模拟数据 */
userList = new ArrayList();
for (int i = 0; i < 20; i++) {
User user = new User();
user.setImageUrl(“http://tp1.sinaimg.cn/2463074124/180/40037127109/1”);
user.setName(“小巫” + i);
user.setDescription(“小巫不用说都应该知道是谁的啦!!!”);
userList.add(user);
}
mListView.setAdapter(new ListViewAdapter(this, userList));
}
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
// TODO: 点击列表跳转到其他页面
}
private class ListViewAdapter extends BaseAdapter {
private List users;
public ListViewAdapter(Context context, List users) {
this.users = users;
}
@Override
public int getCount() {
return users != null ? users.size() : 0;
}
@Override
public User getItem(int position) {
return users.get(position);
}
@Override