Android网格布局的简单使用


运行效果如图:

点击事件效果:


功能:GridView 组件的使用,图片以3*8排列,点击图片弹出对话框显示图片。

  • Java反射
  • SimpleAdapter的进行封装数据
  • OnItemClickListener事件的使用
  • AlertDialog的基本使用

主布局文件 activity_main.xml

"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:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context="com.example.gridviewdemo.MainActivity" >    "@+id/gv"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:numColumns="3" /></RelativeLayout>

显示Item的布局模板 title_view.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/img"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:contentDescription="@string/bookdesc"        android:scaleType="center" />LinearLayout>

主程序 MainActivity.java

package com.example.gridviewdemo;import android.app.Activity;import android.app.AlertDialog;import android.app.Dialog;import android.content.DialogInterface;import android.content.DialogInterface.OnClickListener;import android.os.Bundle;import android.view.View;import android.widget.AdapterView;import android.widget.AdapterView.OnItemClickListener;import android.widget.GridView;import android.widget.ImageView;import android.widget.SimpleAdapter;import java.lang.reflect.Field;import java.util.*;public class MainActivity extends Activity {    private GridView gridView = null;    private List> list = new ArrayList>();    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        gridView = (GridView) findViewById(R.id.gv); // 获取组件        setData();        gridView.setAdapter(getAdapter());        // 下面设置点击事件        gridView.setOnItemClickListener(new OnItemClickListener() {            @Override            public void onItemClick(AdapterView<?> parent, View view,                    int position, long id) {                ImageView iv = new ImageView(MainActivity.this);                Map map = list.get(position);                iv.setImageResource(map.get("img"));                Dialog dialog = new AlertDialog.Builder(MainActivity.this)                        .setIcon(R.drawable.pic_gdqy).setTitle("查看图片")                        .setView(iv)                        .setNegativeButton("关闭", new OnClickListener() {                            @Override                            public void onClick(DialogInterface dialog,                                    int which) {                            }                        }).create();                dialog.show();            }        });    }    // 设置数据    private void setData() {        Field[] data = R.drawable.class.getDeclaredFields(); // 得到drawable下所有的图片文件字段        if (data != null && data.length != 0) {            for (int i = 0; i < data.length; i++) {                try {                    // 如果是以png开头的话 那么就是图片数据                    if (data[i].getName().startsWith("png_")) {                        Map map = new HashMap();                        map.put("img",                                (Integer) data[i].getInt(R.drawable.class));                        list.add(map);                    }                } catch (Exception e) {                    e.printStackTrace();                }            }        }    }    private SimpleAdapter getAdapter() {        SimpleAdapter adapter = new SimpleAdapter(this, list,                R.layout.title_view, new String[] { "img" },                new int[] { R.id.img });        return adapter;    }}

2015年9月28日


                               一步一个脚印

更多相关文章

  1. 箭头函数的基础使用
  2. NPM 和webpack 的基础使用
  3. Python list sort方法的具体使用
  4. 【阿里云镜像】使用阿里巴巴DNS镜像源——DNS配置教程
  5. android 使用html5作布局文件: webview跟javascript交互
  6. Android(安卓)matrix 控制图片的旋转、缩放、移动
  7. Android(安卓)Resource介绍和使用
  8. "Failed to fetch URL https://dl-ssl.google.com/android/repos
  9. 使用NetBeans搭建Android开发环境

随机推荐

  1. android中xml中的sax pull解析
  2. Android -- Service的使用
  3. android source code下载镜像
  4. 二、VR全景图显示器开发 ---- Android VR
  5. Android底层知识点(AD+JNI+NDK+HAL)
  6. Android初级教程 ——Content Provider
  7. android SQLite数据库用法图文详解(附源码
  8. Android UI系列:TextView显示文本
  9. 使用Acitivity实现简易的音乐播放器
  10. Android _Drag 学习笔记