Android应用开发中使用GridView网格布局的代码示例

作者:泽江08 时间:2023-11-09 20:23:36 

基本布局演示
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);

所以最后效果图是这样的 

Android应用开发中使用GridView网格布局的代码示例


巧妙地添加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.运行截图

Android应用开发中使用GridView网格布局的代码示例

标签:Android,GridView
0
投稿

猜你喜欢

  • C#使用NPOI上传excel

    2022-05-20 14:46:22
  • Android canvas drawBitmap方法详解及实例

    2021-06-12 12:17:18
  • 理解java设计模式之建造者模式

    2023-03-13 14:48:55
  • Java如何实现字符串每隔4位加空格

    2023-11-27 06:00:09
  • logback输出日志屏蔽quartz的debug等级日志方式

    2023-08-04 23:40:04
  • 举例详解Java中的访问权限修饰符

    2023-01-18 08:52:17
  • Java中的逻辑控制语句详解

    2023-01-14 09:02:57
  • 浅谈C# 抽象类与开闭原则

    2023-11-07 11:00:08
  • Android实现歌词渐变色和进度的效果

    2023-09-24 02:33:17
  • Spring Security内置过滤器的维护方法

    2022-07-30 18:10:16
  • android 实现侧边弹窗特效代码

    2021-10-18 07:23:02
  • MyBatis的9种动态标签详解

    2021-06-21 19:03:40
  • OpenCV实现反阈值二值化

    2022-06-29 16:02:33
  • Spring BOOT AOP基础应用教程

    2023-05-29 20:33:32
  • 详解备忘录模式及其在Java设计模式编程中的实现

    2023-08-24 22:34:02
  • java导出大批量(百万以上)数据的excel文件

    2023-11-16 13:13:22
  • C# WPF 自定义按钮的方法

    2021-08-30 23:42:11
  • Spring Boot用户注册验证的实现全过程记录

    2023-01-03 01:58:34
  • Java中String类的常用方法总结

    2021-11-26 10:39:20
  • C#非矩形窗体实现方法

    2023-04-09 15:11:39
  • asp之家 软件编程 m.aspxhome.com