Android GridView选择样式

笔者在用GridView时发现GridView的select style会根据系统而不同,因为在客户端中一边具有统一的显示风格,所以尝试了下指定GridView的选中样式。

首先看一下代码:

menu.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:layout_width="fill_parent" 
	android:layout_height="fill_parent"
	android:background="#e1e7e8"
	android:orientation="vertical">
	<include android:id="@+id/menu_title" layout="@layout/title" />
    <GridView android:listSelector="#e1e7e8"
	android:id="@+id/menu" android:layout_width="fill_parent" android:layout_marginTop="10dip"
	android:layout_height="fill_parent" android:numColumns="auto_fit"
	android:verticalSpacing="10dp" android:horizontalSpacing="10dp"
	android:columnWidth="90dp" android:stretchMode="columnWidth"
    android:gravity="center">
    </GridView>
</LinearLayout>
其中android:listSelector="#e1e7e8"这句,android:listSelector的颜色值一定要和它父类容器的背景色相同,这样就不会出现选中时的黑色。

menuitem.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
	android:layout_height="wrap_content" 
	android:paddingBottom="4dip"
	android:background="@drawable/bg_alibuymenu_states"
	android:layout_width="fill_parent">
	<ImageView android:layout_height="wrap_content" 
	    android:id="@+id/ItemImage"
	    android:layout_marginTop="20dip"
		android:layout_width="wrap_content" 
		android:layout_centerHorizontal="true">
	</ImageView>
	<TextView android:layout_width="wrap_content"
	    android:gravity="center"
	    android:textColor="@color/text_color"
	    android:singleLine="true"
	    android:textSize="16dip"
		android:layout_below="@+id/ItemImage" 
		android:layout_height="wrap_content"
		android:layout_centerHorizontal="true" 
		android:id="@+id/ItemText">
	</TextView>
</RelativeLayout>

android:background="@drawable/bg_alibuymenu_states"这句话指定了 GridView中的元素的背景风格。


bg_alibuymenu_states.xml

<?xml version="1.0" encoding="UTF-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
	<item android:state_pressed="true" android:drawable="@drawable/bg_alibuybutton_selected" />
	<item android:state_focused="true" android:drawable="@drawable/bg_alibuybutton_selected" />
</selector>
在此文件中也可设置default的样式,如果需要的话。


bg_alibuybutton_selected.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
	<corners android:radius="3dp" />
	<stroke android:width="0.5dp" android:color="#62809a" />
	<gradient android:startColor="@color/button_selected_start_color"
		android:endColor="@color/button_selected_end_color" android:type="linear"
		android:angle="90" android:centerX="0.5" android:centerY="0.5" />
</shape>

bg_alibuybutton_default.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
	<corners android:radius="3dp" />
	<stroke android:width="0.5dp" android:color="#62809a" />
	<gradient android:startColor="@color/button_defalut_start_color"
		android:endColor="@color/button_defalut_end_color" android:type="linear"
		android:angle="90" android:centerX="0.5" android:centerY="0.5" />
</shape>

Android GridView选择样式_第1张图片

你可能感兴趣的:(android,layout,encoding)