Android网格布局的简单使用

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


<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日


                               一步一个脚印

你可能感兴趣的:(Android,理论)