Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 746|回复: 0

Android 基础编程之十六(GridView 宫格视图实践)-  Androi

[复制链接]

该用户从未签到

发表于 2011-10-24 14:51:28 | 显示全部楼层 |阅读模式
GridView 宫格视图实践
BaseAdapter 与 GridView


①新建工程
②在 res/drawable 目录下添加名称为 a.png---p.png 的图片
③修改 main.xml 布局,添加一个 GridView、一个 ImageView
<?xml version="1.0" encoding="utf-8"?>

<AbsoluteLayout

android:id="@+id/widget0"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

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

<GridView

android:id="@+id/grid"

android:layout_width="fill_parent"

android:padding="30dip"

android:columnWidth="52px"

android:layout_height="210px"

android:numColumns="5">

<!-- GridView设置为五列 边距为30pid-->

</GridView>

<ImageView

android:id="@+id/ImageView_Big"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_x="95px"

android:layout_y="250px">

</ImageView>

</AbsoluteLayout>
复制代码
④GridView 的定义与实例化

/*定义类对象*/

private GridView my_gridview;

/*从xml中获取UI资源对象*/

my_gridview = (GridView) findViewById(R.id.grid);
复制代码
⑤GridView 的图像内容设置与 ImageAdapter
/*新建一个自定义的ImageAdapter*/

myImageViewAdapter = new ImageAdapter(this);

/*为GridView对象设置一个ImageAdapter*/

my_gridview.setAdapter(myImageViewAdapter);
复制代码


⑥内部类 ImageAdapter,实现了 BaseAdapter
private class myImageAdapter extends BaseAdapter{

@Override

public int getCount() {

// TODO Auto-generated method stub

return 0;

}

@Override

public Object getItem(int position) {

// TODO Auto-generated method stub

return null;

}

@Override

public long getItemId(int position) {

// TODO Auto-generated method stub

return 0;

}

@Override

public View getView(int position,

View convertView, ViewGroup parent) {

// TODO Auto-generated method stub

return null;

}

}
复制代码
⑦GridView 的图片 Items 点击事件处理
/*为GridView添加图片Items点击事件监听器*/

my_gridview.setOnItemClickListener(this);

@Override

public void onItemClick(AdapterView<?> arg0,

View arg1, int arg2, long arg3) {

// TODO Auto-generated method stub

/*点击GridView中图片Items事件处理*/

}
复制代码
⑧GridView 移动后选中图片 Items 的事件处理
/*为GridView添加图片Items移动选中事件监听器*/

my_gridview.setOnItemSelectedListener(this);

@Override

public void onItemSelected(AdapterView<?> arg0,

View arg1, int arg2,long arg3) {



//



TODO Auto-generated method stub



/*GridView中的图片移动焦点选中时事件处理*/

}

/*未选中GridView中的图片Items事件处理*/

@Override

public void onNothingSelected(AdapterView<?> arg0) {

// TODO Auto-generated method stub

}
复制代码
⑨修改 mainActivity.java 来实现图片点击和图片移动选中的效果
package zyf.GridViewTest;

/*导入要使用的包*/

import android.app.Activity;

import android.app.AlertDialog;

import android.content.Context;

import android.content.DialogInterface;

import android.content.DialogInterface.OnClickListener;

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;

public class GridViewTest extends Activity implements

GridView.OnItemClickListener,

GridView.OnItemSelectedListener {

/** Called when the activity is first created. */

/*定义类对象*/

private GridView my_gridview;

private ImageView big_imageView;

private ImageAdapter myImageViewAdapter;

/*内部类,实现一个图片适配器*/

public class ImageAdapter extends BaseAdapter {

/*myContext为上下文*/

private Context myContext;

/*GridView用来加载图片的ImageView*/

private ImageView the_imageView;



// 这是图片资源ID的数组

private Integer[] mImageIds = {



R.drawable.a, R.drawable.b,R.drawable.c,

R.drawable.e, R.drawable.f,R.drawable.g,

R.drawable.i, R.drawable.j,R.drawable.k,

R.drawable.m, R.drawable.n,R.drawable.o,



R.drawable.d,

R.drawable.h,

R.drawable.l,

R.drawable.p



};

/*构造方法*/

public ImageAdapter(Context myContext) {

// TODO Auto-generated constructor stub

this.myContext = myContext;

/*传入一个Context,本例中传入的是GridViewTest */

}

/*返回资源ID数组长度*/

@Override

public int getCount() {

// TODO Auto-generated method stub

return mImageIds.length;

}

/*得到Item*/

@Override

public Object getItem(int position) {

// TODO Auto-generated method stub

return position;

}

/*获取Items的ID*/

@Override

public long getItemId(int position) {

// TODO Auto-generated method stub

return position;

}

/*获取要显示的View对象*/

@Override

public View getView(int position,

View convertView, ViewGroup parent) {

// TODO Auto-generated method stub

/*创建一个ImageView*/

the_imageView = new ImageView(myContext);

// 设置图像源于资源ID。

the_imageView.setImageResource(mImageIds[position]);

/*使ImageView与边界适应*/

the_imageView.setAdjustViewBounds(true);



/*设置背景图片的风格*/

the_imageView.setBackgroundResource(

android.R.drawable.picture_frame);

/*返回带有多个图片ID的ImageView*/

return the_imageView;

}

/*自定义获取对应位置的图片ID*/

public Integer getcheckedImageIDPostion(int theindex) {

return mImageIds[theindex];

}

}

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

/*设置主屏布局*/

setContentView(R.layout.main);

/*从xml中获取UI资源对象*/

my_gridview = (GridView) findViewById(R.id.grid);

big_imageView =

(ImageView) findViewById(R.id.ImageView_Big);

/*新建一个自定义的ImageAdapter*/

myImageViewAdapter = new ImageAdapter(this);

/*为GridView对象设置一个ImageAdapter*/

my_gridview.setAdapter(myImageViewAdapter);

/*为GridView添加图片Items点击事件监听器*/

my_gridview.setOnItemClickListener(this);

/*为GridView添加图片Items移动选中事件监听器*/

my_gridview.setOnItemSelectedListener(this);

}

@Override

public void onItemClick(AdapterView<?> arg0,

View arg1, int arg2, long arg3) {

/*点击GridView中图片Items后显示一个AlterDialog提示框*/

new AlertDialog.Builder(this)

.setTitle("图片浏览")

/*获得对应的图片并显示*/

.setIcon(myImageViewAdapter.getcheckedImageIDPostion(arg2))

/*添加一个按钮*/

.setPositiveButton("返回", new OnClickListener() {

@Override

public void onClick(DialogInterface dialog,

int which) {

}

/*显示提示框*/



}).show();

}

@Override

public void onItemSelected(AdapterView<?> arg0,

View arg1, int arg2,long arg3) {

// TODO Auto-generated method stub

/*GridView中的图片移动焦点选中时,

*下面的大图ImageView显示相应的大图片*/

big_imageView.setImageResource(myImageViewAdapter

.getcheckedImageIDPostion(arg2));

}

/*未选中GridView中的图片Items事件处理*/

@Override

public void onNothingSelected(AdapterView<?> arg0) {

// TODO Auto-generated method stub

}

}
复制代码
结果:
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

GMT+8, 2025-1-11 11:42 , Processed in 0.296881 second(s), 36 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表