GridView, ListView 区别

ListView, GridView部分的类层次结构 GridView, ListView 区别_第1张图片
AbsListView的xml属性 android:listSelector 当前item高亮时,显示的drawable

GridView, ListView 区别_第2张图片
android:drawSelectorOnTop 是否将selector显示在item的上方

GridView, ListView 区别_第3张图片
android:fastScrollEnabled 是否启动快速滚动。

GridView, ListView 区别_第4张图片
android:cacheColorHint 缓存颜色提示。它的值是一个颜色值,如#FFF,#FFFFFF等。

【注意:最好要将这个属性设为@null或这与你背景颜色相同,不然你会看到意想不到的情况,后面有介绍】

设置该值时,就提示列表,现在是绘制在一个纯色的、不透明的背景上的,以让列表优化绘制。
android:scrollingCache 是否使用滚动缓存。

设为true时,会在滚动过程中使用一个drawing cache,这样能使绘制变得更快,但会使用更多的内存。

设为false时,就是不使用缓存。


android:smoothScrollbar 是否平滑滚动条。

设为true时,会更以更精确的方式计算滚动条大小,并且在滚动的过程中,实时的会对滚动条的大小进行计算。(所以如果各条数据的高度不一致时,会很耗性能,最好设为false)。

设为false时,以粗略的方式来计算滚动条的大小(根据当前有多少条数据)。
android:stackFromBottom 是否将内容从最后一个显示到第一个,并将滚动条放在最底部。
android:transcriptMode

改写模式,它的值可以为disabled,normal,alwaysScroll

disabled时,在adapter的内容发生改变时,滚动条不发生变化

normal时,当收到notifyDataSetChanged等提示时,只有内容发生改变时(例如增加了一个条目),滚动条会自动滚到底部

alwaysScroll,当收到notifyDataSetChanged等提示时,不管内容改不改变,滚动条都将滚至底部


android:textFilterEnabled 是否启用内容过滤。

设为true时,会根据当前输入的文本,对列表内容进行过滤。


android:cacheColorHint可能会引起的问题

Xml代码 复制代码  收藏代码
 
<LinearLayout
	xmlns:android="http://schemas.android.com/apk/res/android"
	android:layout_width="fill_parent"
	android:layout_height="fill_parent"
	android:orientation="vertical"
	android:background="#0F0"
	android:paddingTop="20dp"
>		
	<ListView
		android:id="@+id/listview1"
		android:layout_width="fill_parent"
		android:layout_height="fill_parent" />
</LinearLayout>

【注意:布局的背景色是绿色,有20dp的padding,ListView没有设置android:cacheColorHint。意外就是拖动时,会出现黑色背景】 GridView, ListView 区别_第5张图片

引起这个的主要原因就是: 默认的ListItem背景是透明的,它在滚动的过程中会与android:cacheColorHint的颜色值进行混合,在黑色主题下默认的颜色值是#191919。

解决解决办法就是将其设为透明或者与背景相同的颜色

android:cacheColorHint="@null"

GridView xml属性

android:columnWidth

列宽(一般与numColumns="auto_fit"配合使用,如果numColumns设置为具体的值时,其不起作用)
android:gravity item

在item container中如何放置(类似于TextView的gravity是决定text如何在TextView中如何放置)。


android:horizontalSpacing

水平空白


android:numColumns

列数。其值可以是具体值(如:100dp),也可以值auto_fit(根据GridView的宽度以及columnWidth来确定列数)


android:stretchMode

缩放模式。其值可以为:none, spacingWidth, columnWidht, spacingWidthUniform


android:verticalSpacing

垂直空白


GridView其实也可以表现的像ListView,只要将其列设为1列 使用ArrayAdapter的GridView

 
R.layout.activity_gridview_use
<merge
	xmlns:android="http://schemas.android.com/apk/res/android">
	<GridView
			android:id="@+id/gridview"
			android:layout_width="fill_parent"
			android:layout_height="fill_parent"
			android:numColumns="auto_fit"
			android:columnWidth="100dp" 
			android:horizontalSpacing="20dp"
			android:verticalSpacing="20dp" />
</merge>		
		
		
public class GridViewUse extends Activity {
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_gridview_use);
		GridView gridView = (GridView) findViewById(R.id.gridview);
		ArrayAdapter<String> gridAdapter = new ArrayAdapter<String>(getApplicationContext(),
				android.R.layout.simple_list_item_1, android.R.id.text1);
		gridAdapter.add("one");
		gridAdapter.add("two");
		gridAdapter.add("three");
		gridAdapter.add("four");
		gridAdapter.add("five");
		gridView.setAdapter(gridAdapter);
	}
}

使用SimpleAdapter的GridView

R.layout.item_image_text
<LinearLayout
	xmlns:android="http://schemas.android.com/apk/res/android"
	android:layout_width="wrap_content"
	android:layout_height="wrap_content"
	android:orientation="vertical"
>
	<ImageView
	    android:id="@+id/image"
	    android:layout_width="wrap_content"
	    android:layout_height="wrap_content"
	    android:scaleType="fitCenter" />
	
	<TextView
	    android:id="@+id/text"
	    android:layout_width="wrap_content"
	    android:layout_height="wrap_content"
	    android:textColor="#FFF" />
</LinearLayout>


private static final String[] FROM = {"image", "text"};
private static final int[] TO = {R.id.image, R.id.text};
private static final List<HashMap<String, Object>> DATA = 
		new ArrayList<HashMap<String, Object>>();
	
public class GridViewUse extends Activity {
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_gridview_use);
		GridView gridView = (GridView) findViewById(R.id.gridview);
		HashMap<String, Object> item;
		// item1
		item = new HashMap<String, Object>();
		item.put("image", R.drawable.ic_launcher);
		item.put("text", "item1");
		DATA.add(item);
		// item2
		item = new HashMap<String, Object>();
		item.put("image", R.drawable.ic_launcher);
		item.put("text", "item2");
		DATA.add(item);
		// item3
		item = new HashMap<String, Object>();
		item.put("image", R.drawable.ic_launcher);
		item.put("text", "item3");
		DATA.add(item);
		
		SimpleAdapter gridAdapter = new SimpleAdapter(getApplicationContext(), DATA, 
				R.layout.item_image_text, FROM, TO);
		gridView.setAdapter(gridAdapter);
	}
}

GridView, ListView 区别_第6张图片

ListView xml属性

android:choiceMode

选择行为的设置。可以设置的值none(默认),singleChoice(一个数据可以处于选中状态),multipleChoice(多个数据可以处于选中状态)


android:divider

数据间的分隔线。颜色或drawable


android:dividerHeight

分隔线的高度。


android:entries

列表的数据。值为一个数组资源值。


android:footerDividersEnabled footer

view间是否使用分隔线


android:headerDividersEnabled

header view间是否使用分隔线

GridView, ListView 区别_第7张图片
其他参考 ListView应该注意的地方:http://gundumw100.iteye.com/blog/1169065

你可能感兴趣的:(ListView)