目录

  • 第1章 Android UI设计
    • ● 版本与程序
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章讲解
    • ● 例1-1 线性布局应用示例
    • ● 例1-2 帧布局应用示例
    • ● 例1-3 表格布局应用示例
    • ● 例1-4 相对布局应用示例
    • ● 例1-5 网格布局应用示例
    • ● 例1-6 约束布局应用示例
    • ● 例1-7 文本标签组件示例
    • ● 例1-8 制作登陆界面
    • ● 例1-9 进度条ProgressBar应用示例
    • ● 例1-10 单选按钮与复选按钮
    • ● 例1-11 简单列表示例
    • ● 例1-12 ListActivity示例
    • ● 例1-13 带有图片的列表
    • ● 例1-14 没有数据的ListView
    • ● 例1-15 改进的列表
    • ● 实战演练——生肖背后的故事
  • 第2章 Activity与多个用户界面
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章讲解
    • ● 例2-1 从Activity启动另一个Activity示例
    • ● 例2-2 传递数据到第二个Activity示例
    • ● 例2-3 消息提示Toast示例
    • ● 例2-4 消息对话框示例
    • ● 例2-5 选项菜单应用示例
    • ● 例2-6 上下文菜单应用示例
    • ● 实战演练——BMI体质指数计算器
  • 第3章 多媒体播放与录制
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章讲解
    • ● 例3-1 音乐播放器, 播放项目资源中的音乐
    • ● 例3-2 音乐播放器, 播放SD卡中的音乐
    • ● 例3-3 应用MediaPlayer设计视频播放器
    • ● 例3-4 应用VidioView设计视频播放器
    • ● 例3-5 录音示例
    • ● 例3-6 拍照示例
    • ● 实战演练——音乐播放器
  • 第4章    广播与服务
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章讲解
    • ● 例4-1 消息广播程序示例
    • ● 例4-2 系统通知服务示例
    • ● 例4-3 广播和时钟服务示例
    • ● 例4-4 调用系统功能拨打电话
    • ● 例4-5 后台音乐服务示例
    • ● 实战演练——播放后台音乐
  • 第5章    数据存储
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章讲解
    • ● 例5-1 内部存储文件示例
    • ● 例5-2 SD文件示例
    • ● 例5-3 JSON数据示例
    • ● 例5-4 SharedPreferences示例
    • ● 例5-5 创建与删除数据库示例
    • ● 例5-6 数据库记录的操作示例
    • ● 实战演练——掌上日记本
  • 第6章    图像和动画
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章讲解
    • ● 例6-1 绘制几何图形示例
    • ● 例6-2 补间动画示例
    • ● 例6-3 属性动画示例
    • ● 例6-4 ImageView图像浏览示例
    • ● 例6-5 ImageSwitcher展示相册示例
    • ● 例6-6 GridView展示相册示例
    • ● 例6-7 游戏中触屏事件示例
    • ● 实战演练——图片与动画
  • 第7章    网络编程
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章讲解
    • ● 例7-1 应用WebView的对象浏览网页
    • ● 例7-2 从Web服务器读取图像文件
    • ● 例7-3 读取JSON数据
    • ● 例7-4 解析JSON数据
    • ● 实战演练——城市天气预报
  • 第8章    分享美食
    • ● 学习目标和本章素材
    • ● 本章PPT
    • ● 本章知识点讲解
    • ● 项目制作流程演示
    • ● 示范1 图标SVG
    • ● 示范2 卡片视图
    • ● 示范3 导航视图
  • 课程资源
    • ● 学生资源包
    • ● 网站地址
例6-6 GridView展示相册示例

【例6-6】用GridView展示相册示例

准备一组图片,复制到资源drawable目录,GridView可以把一个界面划分成二维的网格,然后加载一批图片,图片被统一进行大小限制和加边框处理。


教学视频




布局文件grid_view.xml的源代码

<?xml version="1.0" encoding="utf-8"?>

<!--【例6-6】用GridView展示相册示例-->

<GridView xmlns:android="http://schemas.android.com/apk/res/android"

    android:id="@+id/grid_view"

    android:layout_width="fill_parent"

    android:layout_height="fill_parent"

    android:numColumns="auto_fit"

    android:verticalSpacing="10dp"

    android:horizontalSpacing="10dp"

    android:columnWidth="120dp"

/>

控制文件GridViewActivity.java的源代码如下:(红色代码与教材略有不同)

package com.example.chap06;


import android.app.Activity;

import android.content.Context;

import android.os.Bundle;

import android.view.View;

import android.view.ViewGroup;

import android.widget.AdapterView;

import android.widget.BaseAdapter;

import android.widget.GridView;

import android.widget.ImageView;

import android.widget.Toast;

import androidx.appcompat.app.AppCompatActivity;


//【例6-6】用GridView展示相册示例

public class GridViewActivity extends AppCompatActivity

        implements AdapterView.OnItemClickListener {

    //定义一个数组来引用图片资源

    private Integer[] mThumbIds = {R.drawable.grid_view_01,

            R.drawable.grid_view_02, R.drawable.grid_view_03,

            R.drawable.grid_view_04, R.drawable.grid_view_05,

            R.drawable.grid_view_06, R.drawable.grid_view_07,

            R.drawable.grid_view_08, R.drawable.grid_view_09,

            R.drawable.grid_view_10, R.drawable.grid_view_11,

            R.drawable.grid_view_12, R.drawable.grid_view_13,

            R.drawable.grid_view_14, R.drawable.grid_view_15,};


    @Override

    public void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.grid_view);

        setTitle("GridViewActivity");

        GridView gridview = (GridView) findViewById(R.id.grid_view);

        gridview.setAdapter(new ImageAdapter(this));

        gridview.setOnItemClickListener(this);

    }


    //如果AdapterView被单击则返回Item的单击事件,实战演练的代码应补充在这里

    @Override

    public void onItemClick(AdapterView<?> parent, View view,

                            int position, long id) {

        Toast.makeText(getApplicationContext(),

                "Item Clicked: " + position, Toast.LENGTH_SHORT).show();

    }


    //新建一个类继承BaseAdapter

    class ImageAdapter extends BaseAdapter {

        private Context mContext;


        public ImageAdapter(Context c) {

            mContext = c;

        }

        public int getCount() {

            return mThumbIds.length;

        }

        public Object getItem(int position) {

            return null;

        }

        public long getItemId(int position) {

            return 0;

        }

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

            ImageView imageView;

            if (convertView == null) {

                //初始化下面的属性

                imageView = new ImageView(mContext);

                //设置View的高度和宽度,每个图片都会被统一限制大小

                imageView.setLayoutParams(new GridView.LayoutParams(300, 300));

                //声明图片的中心点,应该和ImageView的中心点一致,并按比例扩大或缩小图片,确保填满ImageView的边框

                imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);

                //声明内部图片与控件ImageView的边距

                imageView.setPadding(8, 8, 8, 8);

            } else {

                imageView = (ImageView) convertView;

            }

            //会根据设备分辨率进行图片大小缩放

            imageView.setImageResource(mThumbIds[position]);

            return imageView;

        }

    }

}


打开项目配置文件AndroidManifest.xml,配置要启动的Activity类名为 GridViewActivity