Android网格布局的简单使用


运行效果如图:
Android网格布局的简单使用_第1张图片
点击事件效果:
Android网格布局的简单使用_第2张图片


功能: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. Android 图片压缩实现过程代码
  2. Android中使用HorizontalScrollView横向滑动布局
  3. 相对布局(RelativeLayout)常用属性
  4. Android 应用软件开发(六)窗口布局
  5. Android 图片异步加载的体会,SoftReference已经不再适用
  6. Android如何拍照或选择图片并裁剪
  7. Android加载图片时OOM异常解决办法——Bitmap Options
  8. Android 截取屏幕图片并保存

随机推荐

  1. Android(安卓)中SwipeRefreshLayout刷新
  2. 解决方案:公众号h5页面开发时微信自带返回
  3. Android(安卓)ListView Adapter的getItem
  4. android studio 导入自定义编码格式
  5. android 中 intent 重点
  6. 在Unity顶部显示手机状态栏(iOS/Android)
  7. Android使用NavigationView和Toolbar和Dr
  8. Android弹出式对话框AlertDialog中的Edit
  9. android 5.0新特性学习--视图阴影
  10. Android(安卓)Studio3.4新功能和改进