GridView(网格视图)的使用
来源:互联网 发布:义和团红卫兵知乎 编辑:程序博客网 时间:2024/04/27 14:44
网格视图听它的名字就能知道这个一个个的网格排列的,每个网格里面摆放相应的控件。GridView和ListView都继承自AbsListView,他们的区别就在ListView只有一列,而GridView大于一列。所以在使用GridView的时候可以模仿ListView。也因此在使用GridView时也需要使用Adapter来提供数据。
先看一下它额xml属性:
这里是在官方API上截的图
看图片也能知道这些属性的意思:
android:columnWidth:表示列宽。
android:gravity:对齐方式。
android:horizontalSpacing:水平之间的间隔。
android:verticalSpacing:垂直之间的间隔
android:numColumns:总共多少列。(这里一般指定列就行了,行数会根据你设置的数据个数来自动分配行数。一般大于一列,否则就是ListViewle)。
android:stretchMode:拉伸模式。有以下几种拉伸模式,这里给出官方截图。
在java代码里面是setStretchMode(int)
下面是项目的预览图片:
下面是代码:
activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_gravity="center_horizontal" android:orientation="vertical" > <GridView android:id="@+id/gridView" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:horizontalSpacing="2dp" android:numColumns="4" android:verticalSpacing="1dp" > </GridView> <ImageView android:id="@+id/imageView" android:layout_width="450dp" android:layout_height="450dp" android:layout_gravity="center" /></LinearLayout>
MainActivity.java
package com.example.gridviewtest;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.view.Window;import android.widget.AdapterView;import android.widget.AdapterView.OnItemClickListener;import android.widget.AdapterView.OnItemSelectedListener;import android.widget.GridView;import android.widget.ImageView;import android.widget.SimpleAdapter;public class MainActivity<E> extends Activity { private GridView gridView; private ImageView imageView; private int[] imgIds = new int[] { R.drawable.img01, R.drawable.img02, R.drawable.img03, R.drawable.img04, R.drawable.img05, R.drawable.img06, R.drawable.img07, R.drawable.img08 }; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.activity_main); gridView = (GridView) findViewById(R.id.gridView); imageView = (ImageView) findViewById(R.id.imageView); // 创建List对象存放Map集合 List<Map<String, Object>> list = new ArrayList<Map<String, Object>>(); for (int i = 0; i < imgIds.length; i++) { Map<String, Object> map = new HashMap<String, Object>(); map.put("MyImg", imgIds[i]); list.add(map); } SimpleAdapter adapter = new SimpleAdapter(this, list, R.layout.img, new String[] { "MyImg" }, new int[] { R.id.myImage }); gridView.setAdapter(adapter); /* * 设置图片被选中的监听器 */ gridView.setOnItemSelectedListener(new OnItemSelectedListener() { @Override public void onItemSelected(AdapterView<?> arg0, View arg1, int position, long arg3) { imageView.setImageResource(imgIds[position]);// 当点开图片时,显示当前图片的大图。 } @Override public void onNothingSelected(AdapterView<?> arg0) { // TODO Auto-generated method stub } }); /* * 图片被点击的监听器 */ gridView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) { imageView.setImageResource(imgIds[arg2]); } }); }}
img.xml
<?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="match_parent" android:orientation="vertical" > <ImageView android:id="@+id/myImage" android:layout_width="wrap_content" android:layout_height="wrap_content" /></LinearLayout>
0 0
- GridView(网格视图)的使用
- 网格视图GridView的使用
- 网格视图GridView的使用
- 网格视图(GridView)
- 使用网格视图控件GridView
- Android中GridView(网格视图,比如九宫格)使用
- UI组件之AdapterView及其子类(二)GridView网格视图的使用
- GridView使用BaseAdapter实现网格视图
- 网格视图(GridView)的功能与用法
- Android组件 网格视图(GridView)
- 高仿易信UI之网格视图(GridView)
- 安卓--网格视图(GridView)实例
- Android基础之----GridView(网格视图)
- GridView网格视图
- Android 网格视图GridView
- [控件]GridView网格视图
- android gridview网格视图
- GridView网格视图
- Oracel查询表中某字段值为去重后第几的记录
- HDU1506 Largest Rectangle in a Histogram(水DP)
- POJ 1664 放苹果 DP
- 1094 A+B for Input-Output Practice (VI)
- JIRA敏捷开发任务管理
- GridView(网格视图)的使用
- CocoaPod的安装与问题处理
- C++ 网络编程 数据结构 面试题罗列
- iOS- 点赞动画效果
- write和fwrite函数(文件描述符)
- 1095 A+B for Input-Output Practice (VII)
- 杭电ACM1800解题报告
- 7月25日开始学习爬虫
- 【调试】打印函数栈,以及由函数指针输出函数名的方法