设为首页 加入收藏

TOP

一起学Android之GridView(一)
2019-09-01 23:25:32 】 浏览:48
Tags:一起 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)
首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇Flutter 即学即用系列博客——01 .. 下一篇Android 离线人脸识别 ArcFace 2...

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目