基本布局演示
1. 定义包含GridView 的 main.xmk
<?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=\"fill_parent\" > <GridView android:id=\"@+id/gride\" android:layout_width=\"fill_parent\" android:layout_height=\"wrap_content\" <strong> android:numColumns=\"3\"</strong> android:verticalSpacing=\"5dip\" /> </LinearLayout>
这行应该注意一下:
android:numColumns=\"3\"
用来设定GridView每行显示的View数目 如果没有这行 会默认每行显示一个View 和ListView 的一样
2. 自定义 class ImageList extends BaseAdapter 其中主要是:
View getView(int position, View convertView, ViewGroup parent)
用于显示目标ImageView
public class ImageList extends BaseAdapter {
Activity activity;
//construct
public ImageList(Activity a ) {
activity = a;
}
@Override
public int getCount() {
// TODO Auto-generated method stub
return image.length;
}
@Override
public Object getItem(int position) {
// TODO Auto-generated method stub
return image[position];
}
@Override
public long getItemId(int position) {
// TODO Auto-generated method stub
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// TODO Auto-generated method stub
ImageView iv = new ImageView(activity);
iv.setImageResource(image[position]);
return iv;
}
}
3. 给GridView指定Adapter
GridView gv = (GridView) findViewById(R.id.gride); ImageList adapter = new ImageList(this); gv.setAdapter(adapter);
所以最后效果图是这样的
巧妙地添加GridView的 网格线
ListView 中设置分隔线的加如下参数即可:
android:divider=\"@color/gray\" android:dividerHeight=\"1dp\"
GridView网格布局,默认情况下是没有网格线的
查找网上资料,找到了一种为GridView添加网格线的小技巧
实际上,该网格线是通过设置GridView各子项的间隔,并分别设置GridView背景色与子项背景色实现的。
实现方法:
(1)设置GridView背景色,设置水平间方向间隔属性值android:horizontalSpacing和竖直方向间隔属性值
android:verticalSpacing
(2)设置GridView子项背景色
示例代码:
1.main.xml
<GridView
android:id=\"@+id/gv_words\"
android:visibility=\"gone\"
android:background=\"@color/gray\"
android:columnWidth=\"60dp\"
android:numColumns=\"5\"
android:listSelector=\"@null\"
android:verticalSpacing=\"1.0px\"
android:horizontalSpacing=\"1.0px\"
android:soundEffectsEnabled=\"true\"
android:smoothScrollbar=\"true\"
android:stretchMode=\"columnWidth\"
android:layout_width=\"fill_parent\"
android:layout_height=\"fill_parent\"
android:layout_above=\"@+id/llayout2\"
android:layout_below=\"@+id/llayout1\"/>
2.GrivViewItem布局
<?xml version=\"1.0\" encoding=\"utf-8\"?>
<LinearLayout xmlns:android=\"http://schemas.android.com/apk/res/android\"
android:layout_width=\"match_parent\"
android:layout_height=\"wrap_content\"
android:background=\"@color/white\" >
<RelativeLayout
android:layout_width=\"50dp\"
android:layout_height=\"50dp\"
android:layout_margin=\"5dp\">
<TextView
android:id=\"@+id/gv_bushou_TextView1\"
android:layout_width=\"wrap_content\"
android:layout_height=\"wrap_content\"
android:layout_below=\"@+id/ItemImage\"
android:layout_margin=\"1dp\"
android:layout_alignParentTop=\"true\"
android:layout_alignParentLeft=\"true\"
android:layout_above=\"@+id/gv_bushou_TextView2\"
android:layout_toLeftOf=\"@+id/gv_bushou_TextView2\"
android:textSize=\"25dp\"
android:textColor=\"@color/blue\"
android:text=\"难\" >
</TextView>
<TextView
android:id=\"@+id/gv_bushou_TextView2\"
android:layout_width=\"wrap_content\"
android:layout_height=\"wrap_content\"
android:layout_below=\"@+id/ItemImage\"
android:layout_alignParentBottom=\"true\"
android:layout_alignParentRight=\"true\"
android:textColor=\"@color/gray\"
android:textSize=\"10dp\"
android:text=\"1笔\" >
</TextView>
</RelativeLayout>
</LinearLayout>
3.运行截图
本文地址:https://www.stayed.cn/item/6669
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我