一起学Android之GridView

本文以一个简单的小例子,简述Android开发中GridView的常见应用,仅供学习分享使用。

概述

GiridView是一个表格显示资源的控件,可以在两个可滚动的方向上显示。列表项的资源会通过ListAdapter自动添加到布局控件中GirdView上。

如下图所示:

数据绑定步骤

如下图所示:

涉及知识点

  • android:numColumns="auto_fit"  设置GridView中的列数,可以是数字,auto_fit表示系统自动根据屏幕的大小进行适应性显示。
  • android:verticalSpacing="10dp” 用于设置行与行之间的垂直间隔
  • android:horizontalSpacing="10dp" 用于设置列与列之间的水平间隔
  • android:stretchMode="columnWidth" 设置列中元素的拉伸模式
  • setOnItemClickListener 设置列元素的监听事件

示例效果图

如下图所示:

核心代码

GridView如下:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <RelativeLayout
 3     xmlns:android="http://schemas.android.com/apk/res/android"
 4     xmlns:tools="http://schemas.android.com/tools"
 5     android:layout_width="match_parent"
 6     android:layout_height="match_parent"
 7     tools:context="com.hex.demogridview.MainActivity">
 8     <GridView
 9         android:id="@+id/gv_info"
10         android:columnWidth="90dp"
11         android:verticalSpacing="10dp"
12         android:horizontalSpacing="10dp"
13         android:numColumns="auto_fit"
14         android:stretchMode="columnWidth"
15         android:layout_width="match_parent"
16         android:layout_height="match_parent"></GridView>
17 </RelativeLayout>

列表项代码(图片和文本)

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3               android:layout_width="match_parent"
 4               android:layout_height="match_parent"
 5               android:orientation="vertical">
 6     <ImageView
 7         android:id="@+id/img_info"
 8         android:src="@drawable/a011"
 9         android:layout_width="match_parent"
10         android:layout_height="wrap_content"/>
11     <TextView
12         android:id="@+id/tv_info"
13         android:text="abc"
14         android:textSize="20sp"
15         android:textAlignment="center"
16         android:textColor="@color/colorAccent"
17         android:layout_width="match_parent"
18         android:layout_height="wrap_content"/>
19 </LinearLayout>

后台代码(Adapter类)

 1 class  MyAdapter extends BaseAdapter {
 2         private Context mContext;
 3
 4         public MyAdapter(Context context) {
 5             this.mContext = context;
 6         }
 7
 8         @Override
 9         public int getCount() {
10             return mList != null ? mList.size() : 0;
11         }
12
13         @Override
14         public Object getItem(int position) {
15             return mList.get(position);
16         }
17
18         @Override
19         public long getItemId(int position) {
20             return position;
21         }
22
23         @Override
24         public View getView(int position, View convertView, ViewGroup parent) {
25             ViewHolder viewHolder;
26             if (convertView == null) {
27                 // if it‘s not recycled, initialize some attributes
28                 LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE); //getLayoutInflater();
29                 convertView = inflater.inflate(R.layout.grid_item,null);
30                 viewHolder=new ViewHolder();
31                 viewHolder.img = (ImageView) convertView.findViewById(R.id.img_info);
32                 viewHolder.tv = (TextView) convertView.findViewById(R.id.tv_info);
33
34                 convertView.setTag(viewHolder);
35             } else {
36                 viewHolder = (ViewHolder) convertView.getTag();
37             }
38             viewHolder.img.setImageResource((int)mList.get(position).get("img"));
39             viewHolder.tv.setText((String) mList.get(position).get("txt"));
40             return convertView;
41         }
42     }

后台代码(Activity)

 1 public class MainActivity extends AppCompatActivity {
 2     private  int[] imgs;
 3     private List<Map<String,Object>> mList;
 4    private  GridView gvInfo;
 5     @Override
 6     protected void onCreate(Bundle savedInstanceState) {
 7         super.onCreate(savedInstanceState);
 8         setContentView(R.layout.activity_main);
 9         gvInfo= (GridView) this.findViewById(R.id.gv_info);
10
11         imgs=new int[]{R.drawable.a011,R.drawable.a012,R.drawable.a013,R.drawable.a014,R.drawable.a015,R.drawable.a016,R.drawable.a017,R.drawable.a018,R.drawable.a019,R.drawable.a0110,R.drawable.a0111};
12         mList=new ArrayList<Map<String, Object>>();
13         for(int i=0;i<11;i++) {
14             Map<String, Object> map = new HashMap<String, Object>();
15             map.put("img", imgs[i]);
16             map.put("txt", "第" + i + "个");
17             mList.add(map);
18         }
19         MyAdapter adapter =new MyAdapter(this);
20         gvInfo.setAdapter(adapter);
21         gvInfo.setOnItemClickListener(new AdapterView.OnItemClickListener() {
22             @Override
23             public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
24                 TextView textView= (TextView) view.findViewById(R.id.tv_info);
25                 String msg = textView.getText().toString();
26                 Toast.makeText(MainActivity.this,msg,Toast.LENGTH_SHORT).show();
27             }
28         });
29
30     }

备注

学习一门新的语言,坚持的源头是兴趣,坚持的前方是希望。

原文地址:https://www.cnblogs.com/hsiang/p/10347296.html

时间: 02-01

一起学Android之GridView的相关文章

从零开始学android&lt;GridView网格视图.二十八.&gt;

GridView组件是以网格的形式显示所有的组件,例如:在制作相册的时候,所有的图片都会以相同大小显示在不同的格子之中,就可以依靠此组件完成,此组件的继承结构如下所示: java.lang.Object ? android.view.View ? android.view.ViewGroup ? android.widget.AdapterView<T extends android.widget.Adapter> ? android.widget.AbsListView ? android.

android的GridView和Gallery

GridView: activity_main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"     xmlns:tools="http://schemas.android.com/tools"     android:layout_width="match_parent"     android:layout_height=&q

一起学android之利用回调函数onCreateDialog实现加载对话框(23)

效果图: 有时候我们需要去做一个Activity启动时的数据加载对话框,关于对话框的各种实现可以通过一起学android之对话框 Dialog的创建(7)来完成,在这里另外介绍一个,利用onCreateDialog回调方法来实现,当然这个方法标记已经过 时了,但我们还是可以使用这个方法来实现我们想要的功能.具体请参看代码: public class MainActivity extends Activity { @SuppressWarnings("deprecation") @Ove

从零开始学android&lt;android事件的处理方式.二十四.&gt;

在android中一共有 多种事件,每种事件都有自己相对应的处理机制 如以下几种 1 单击事件 View.OnClickListener public abstract void onClick (View v) 单击组件时触发 2 单击事件 View.OnLongClickListener public abstract boolean onLongClick (View v) 长按组件时触发 3 键盘事件 View.OnKeyListener public abstract boolean

从零开始学android&lt;RatingBar评分组件.二十三.&gt;

如果现在用户要对某个应用程序打分往往会使用图所示的组件,通过选择的"五角星"的个数来决定最终的打分成绩 这样的功能在Android之中,可以使用RatingBar组件实现,使用此组件可以方便用户的输入,而且很直观,RatingBar类的定义结构如下: java.lang.Object ? android.view.View ? android.widget.ProgressBar ? android.widget.AbsSeekBar ? android.widget.RatingBa

从零开始学android&lt;AutoCompleteTextView随笔提示文本框.十九.&gt;

随笔提示功能可以很好的帮助用户进行方便的信息输入,而在Android之中也提供了与之类似的功能,而这个功能的实现就需要依靠android.widget.AutoCompleteTextView类完成,此类的继承结构如下: java.lang.Object ? android.view.View ? android.widget.TextView ? android.widget.EditText ? android.widget.AutoCompleteTextView No. 方法 类型 描述

从零开始学android&lt;使用嵌套布局实现计算器界面.十七.&gt;

所谓的嵌套布局就是在一个文件中嵌套多个布局文件 <span style="font-size:18px;"> <LinearLayout android:layout_width="match_parent" android:layout_height="fill_parent" android:orientation="vertical" > <FrameLayout android:layou

菜鸟学Android编程——简单计算器《一》

菜鸟瞎搞,高手莫进 本人菜鸟一枚,最近在学Android编程,网上看了一些视频教程,于是想着平时手机上的计算器应该很简单,自己何不尝试着做一个呢? 于是就冒冒失失的开撸了. 简单计算器嘛,功能当然很少,加减乘除就可以. 第一步:设计布局文件 界面如下图: 由于刚开始学Android,对布局文件也不是很了解,边查边找,最后凑合着写好了布局文件. 注意事项:此布局文件用到了GridLayout布局,是在Android4.0以上才出现的(不知道谷歌有没有开发相应的包来适配4.0以下版本). 有关Gri

Android 自定义GridView添加网格线

有一个需求是这样的,查了下网上的资料都是利用间隔 ,但是我这个Gridview的背景是渐变的...于是就不好办了...又在google上面看见一个自定义的Gridview,但是有BUG.....在偶数的情况下,最下面一行会有底线...奇数并不会.于是修改了下. 通过重写dispatchDraw    利用Paint进行绘制 package com.hrcp.starsshoot.widget; import android.content.Context; import android.grap

Android使用GridView实现日历功能(详细代码)

代码有点多,发个图先: 如果懒得往下看的,可以直接下载源码吧(0分的),最近一直有人要,由于时间太久了,懒得找出来整理,今天又看到有人要,正好没事就整理了一下 http://download.csdn.net/detail/onlyonecoder/6574379 布局文件: [html] view plaincopy <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:androi