第30讲 UI组件之 GridView组件

1.网格布局组件GridView

GridView是一个ViewGroup(布局控件),可使用表格的方式显示组件,可滚动的控件。一般用于显示多张图片,比如实现九宫格图,用GridView是首选,也是最简单的。主要用于设置Adapter。

GridView常用的XML属性:

属性名称

描述

android:columnWidth

设置列的宽度。

android:gravity

设置对齐方式。可选的值有:top、bottom、left、right、center_vertical、fill_vertical、center_horizontal、fill_horizontal、center、fill、clip_vertical可以多选,用“|”分开。

android:horizontalSpacing

两列之间的间距。

android:numColumns

设置列数。

android:stretchMode

缩放模式,即如何填满空余位置。columnWidth是分配剩余空间给每一列;spacingWidth是分配剩余空间给间隔空隙

android:verticalSpacing

两行之间的间距。

使用方法与Listview类似:(部分代码)

其中的adapter采用BaseAdapter方式构建

private classMyAdapter extends BaseAdapter{

private int[] image;

private Context context;

public MyAdapter(int[] image, Context context) {

super();

this.image = image;

this.context = context;

}

public int getCount() { return image.length; }

public Object getItem(int arg0) { return null; }

public long getItemId(int arg0) { return 0; }

public View getView(int position,View convertView, ViewGroup parent) {

int resId=image[position];

ImageView imageView=new ImageView(context);

imageView.setImageResource(resId);

return imageView;

}

}

MainActivity.java部分代码:

GridView gridView=(GridView) findViewById(R.id.gridView1);

int[] image=new int[] {

R.drawable.down,  R.drawable.up,  R.drawable.left,   R.drawable.down,  R.drawable.up,

R.drawable.left,    R.drawable.down, R.drawable.up,  R.drawable.left,  R.drawable.down,

R.drawable.up,  R.drawable.left,  R.drawable.right };

adapter=new MyAdapter(image,this);

gridView.setAdapter(adapter);

GridView属性

android:numColumns="3" //列数 可以设置为auto_fit,根据columnWidth和Spacing来自动计算。

android:columnWidth="30dp"

android:horizontalSpacing="10dp"

android:verticalSpacing="10dp"

android:stretchMode="columnWidth"

//如何填满空余位置,columnWidth是分配剩余空间给每一列;spacingWidth是分配剩余空间给间隔空隙

二、丰富GridView

实现如下形式的GridView,图片带名字

首先需要构建一个layout——book.xml,用来装载名字和图片。

然后更改adapter

public class MainActivity extends ActionBarActivity {

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

GridView gridView=(GridView)findViewById(R.id.gridView1);

//图片数组

int[] image=newint[] {

R.drawable.beihang, R.drawable.beihang, R.drawable.beihang,

R.drawable.beihang, R.drawable.beihang, R.drawable.beihang,

R.drawable.beihang,R.drawable.beihang, R.drawable.beihang,

R.drawable.beihang, R.drawable.beihang, R.drawable.beihang};

//设置为图片名称

String[] bookname=new String[] {

"java1","java2", "java3", "java4", "java5","java6",

"java7","java8", "java9", "java10", "java11","java12" };

//为GridView设置适配器

gridView.setAdapter(new MyAdapter(image,this,bookname));

//注册监听事件

gridView. setOnItemClickListener(newOnItemClickListener() {

public void onItemClick(AdapterView<?> agr0, View agr1, int agr2, longagr3) {

        Toast.makeText(MainActivity.this,agr2+"-"+ agr3, Toast.LENGTH_SHORT).show();


}

});

}

 

//自定义适配器

public class MyAdapter extends BaseAdapter {

private int[] image;

private Context context;

private String[] bookname;

public MyAdapter(int[] image,Context context, String[] bookname) {

super();

this.image = image;

this.context = context;

this.bookname = bookname;

}

public int getCount() { return image.length;}

public Object getItem(int position){return null; }

public long getItemId(int position){
return
0; }

//创建View方法

public View getView(int position,View convertView, ViewGroup parent) {

int resId=image[position];

String name=bookname[position];

//设置ImageView对象布局

ViewGroup group=(ViewGroup) getLayoutInflater().inflate(R.layout.book,null);

ImageView imageView=(ImageView) group.findViewById(R.id.imageView1);

//为ImageView设置图片资源

imageView.setImageResource(resId);

TextView textView=(TextView) group.findViewById(R.id.textView1);

textView.setText(name);

return group;

}

}

第30讲 UI组件之 GridView组件的更多相关文章

  1. 第29讲 UI组件之 ListView与 BaseAdapter,SimpleAdapter

    第29讲 UI组件之 ListView与 BaseAdapter,SimpleAdapter 1.BaseAdapter BaseAdapter是Android应用程序中经常用到的基础数据适配器,它的 ...

  2. 第28讲 UI组件之 ListView和ArrayAdapter

    第28讲 UI组件之 ListView和ArrayAdapter 1. Adapter 适配器 Adapter是连接后端数据和前端显示的适配器接口,是数据和UI(View)之间一个重要的纽带.在常见的 ...

  3. 第34讲 UI组件之 ProgressDialog和Message

    第34讲UI组件之 ProgressDialog和Message 1.进度对话框 ProgressDialog <1>简介 ProgressDialog是AlertDialog类的一个扩展 ...

  4. 第33讲 UI组件_进度条ProcessBar和消息队列处理器handler

    第33讲UI组件_进度条ProcessBar和消息队列处理器handler 1. 进度条ProcessBar 一个可视化的进度指示器,代表正在执行的耗时任务.可以为用户展示一个进度条,表示正在执行的任 ...

  5. 第32讲 UI组件之 时间日期控件DatePicker和TimePicker

    第32讲 UI组件之 时间日期控件DatePicker和TimePicker 在Android中,时间日期控件相对来说还是比较丰富的.其中, DatePicker用来实现日期输入设置,    Time ...

  6. 第31讲 UI组件之 Gallery画廊控件

    第31讲 UI组件之 Gallery画廊控件 1.Gallery的简介 Gallery(画廊)是一个锁定中心条目并且拥有水平滚动列表的视图,一般用来浏览图片,并且可以响应事件显示信息.Gallery只 ...

  7. 第27讲 UI组件之 ScrollView与底部动态添加数据

    第27讲 UI组件之 ScrollView与底部动态添加数据 1. ScrollView(滚动视图) ScrollView(滚动视图)是实现滚动的一个控件,只需要将需要滚动的控件添加到ScrollVi ...

  8. 第25讲 UI组件之 AlertDialog 的各种实现

    第25讲 UI组件之AlertDialog 的各种实现 对话框(Dialog)是程序运行中的弹出窗口,例如当用户要删除一个联系方式时,会弹出一个对话框. Android提供了多种对话框:警告对话框(A ...

  9. 第19讲- UI组件之_Button、checkbox、radio

    第19讲 UI组件之_Button.checkbox.radio 四.按钮Button Button继承自TextView,间接继承自View.当用户对按钮进行操作的时候,触发相应事件,如点击,触摸. ...

随机推荐

  1. C++编程规范之17:避免使用“魔数”

    摘要: 程序设计并非魔术,所以不要故弄玄虚,要避免在代码中使用诸如42和3.1415926这样的文字常量.它们本身没有提供任何说明,并且因为增加了难于检测的重复而使维护更加复杂.可以用符号名称和表达式 ...

  2. java jodd轻量级开发框架

    http://git.oschina.net/huangyong/jodd_demo/blob/master/jodd-example/src/main/java/jodd/example/servi ...

  3. [React Testing] The Redux Store - Multiple Actions

    When using Redux, we can test that our application state changes are working by testing that dispatc ...

  4. MVC三和,你能辨别它?

    上次我们聊的时间MVC,而之前我们学习过三层.那么我们不禁就要问,他们说的是一回事吗.他们有什么联系吗? 三层架构(3-tier application)通常意义上的三层架构就是将整个业务应用划分为: ...

  5. NYOJ 16 矩形嵌套(动态规划)

    矩形嵌套 时间限制: 3000 ms  |  内存限制: 65535 KB 难度: 4   描述 有n个矩形,每个矩形可以用a,b来描述,表示长和宽.矩形X(a,b)可以嵌套在矩形Y(c,d)中当且仅 ...

  6. jQuery的简单应用

     时隔多日, 终于我又有时间来浏览些新知识了, 并不是偷懒什么的, 只是真的好忙, 看似闲暇的时间总是冒出一些模糊而又不得不做的事情, 今日终于我又有时间了, 可以看下jQuery了, 并根据自己的了 ...

  7. 部署hibernate框架项目时出现问题:The type java.lang.Object cannot be resolved. It is indirectly referenced from required .class files.

    基本情况: (这些其实关系不大)我是直接impor导入HibernateDemo项目到eclipse中的,该项目的hibernate版本是3.6.7.Final版,使用了Hibernate Tools ...

  8. defer和async

    1.decument.wirte不能使用 2.<script src="text.js" type="text/javascript" defer=&qu ...

  9. js判断当前操作系统

    function validataOS(){ if(navigator.userAgent.indexOf(“Window”)>0){ return ”Windows”; }else if(na ...

  10. webstrom的注释

    今天我们小组的新同学有一个BUG调不好,然后我就帮他调一下.在调试的过程中非常累,纠其原因还是他注释写的不完善.我们可以看一下,他是这样写注释的(随便拿一个方法举例),如下图: 乍一看,是不是觉得他的 ...