MainActivity.java

  1. public class MainActivity extends Activity
  2. {
  3. GridView grid;
  4. ImageView imageView;
  5. int[] imageIds = new int[]
  6. {
  7. R.drawable.bomb5 , R.drawable.bomb6 , R.drawable.bomb7
  8. , R.drawable.bomb8 , R.drawable.bomb9 , R.drawable.bomb10
  9. , R.drawable.bomb11 , R.drawable.bomb12 , R.drawable.bomb13
  10. , R.drawable.bomb14 , R.drawable.bomb15 , R.drawable.bomb16
  11. };
  12. @Override
  13. public void onCreate(Bundle savedInstanceState)
  14. {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.main);
  17. // 创建一个List对象,List对象的元素是Map
  18. List<Map<String, Object>> listItems =
  19. new ArrayList<Map<String, Object>>();
  20. for (int i = 0; i < imageIds.length; i++)
  21. {
  22. Map<String, Object> listItem = new HashMap<String, Object>();
  23. listItem.put("image", imageIds[i]);
  24. listItems.add(listItem);
  25. }
  26. // 获取显示图片的ImageView
  27. imageView = (ImageView) findViewById(R.id.imageView);
  28. // 创建一个SimpleAdapter
  29. SimpleAdapter simpleAdapter = new SimpleAdapter(this,
  30. listItems
  31. // 使用/layout/cell.xml文件作为界面布局
  32. , R.layout.cell, new String[] { "image" },
  33. new int[] { R.id.image1 });
  34. grid = (GridView) findViewById(R.id.grid01);
  35. // 为GridView设置Adapter
  36. grid.setAdapter(simpleAdapter);
  37. // 添加列表项被选中的监听器
  38. grid.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener()
  39. {
  40. @Override
  41. public void onItemSelected(AdapterView<?> parent, View view, int                                                         position, long id)
  42. {
  43. // 显示当前被选中的图片
  44. imageView.setImageResource(imageIds[position]);
  45. }
  46. @Override
  47. public void onNothingSelected(AdapterView<?> parent)
  48. {
  49. }
  50. });
  51. // 添加列表项被单击的监听器
  52. grid.setOnItemClickListener(new AdapterView.OnItemClickListener()
  53. {
  54. @Override
  55. public void onItemClick(AdapterView<?> parent, View view,
  56. int position, long id)
  57. {
  58. // 显示被单击的图片
  59. imageView.setImageResource(imageIds[position]);
  60. }
  61. });
  62. }
  63. }

XML文件

Main.xml

  1. 1.<?xml version="1.0" encoding="utf-8"?>
  2. 2.<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. 3. android:orientation="vertical"
  4. 4. android:layout_width="match_parent"
  5. 5. android:layout_height="match_parent"
  6. 6. android:gravity="center_horizontal">
  7. 7. <!-- 定义一个GridView组件 -->
  8. 8. <GridView
  9. 9. android:id="@+id/grid01"
  10. 10. android:layout_width="match_parent"
  11. 11. android:layout_height="wrap_content"
  12. 12. android:horizontalSpacing="1pt"
  13. 13. android:verticalSpacing="1pt"
  14. 14. android:numColumns="4"
  15. 15. android:gravity="center"/>
  16. 16. <!-- 定义一个ImageView组件 -->
  17. 17. <ImageView android:id="@+id/imageView"
  18. 18. android:layout_width="240dp"
  19. 19. android:layout_height="240dp"
  20. 20. android:layout_gravity="center_horizontal"/>
  21. 21.</LinearLayout>

Cell.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="horizontal"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:gravity="center_horizontal"
  7. android:padding="2pt">
  8. <ImageView
  9. android:id="@+id/image1"
  10. android:layout_width="50dp"
  11. android:layout_height="50dp"
  12. />
  13. </LinearLayout>

效果:

其中关键代码是

  1. SimpleAdapter simpleAdapter = new SimpleAdapter(this,
  2. listItems
  3. // 使用/layout/cell.xml文件作为界面布局
  4. , R.layout.cell, new String[] { "image" },
  5. new int[] { R.id.image1 });

SimpleAdapter的介绍:

第一个参数:是context

第二个参数:是一个List<?extends Map<String,?>>类型的集合对象,该集合中每个Map<String,?>对象生成一个列表项

第三个参数:制定一个界面布局的ID

第四个参数:是一个String[]类型的参数,该参数决定提取Map<String,?>对象中哪些key对应的value来生成列表项

第五个参数:应该是一个int[]类型参数,决定填充哪些组件

SimpleAdapter 网络视图:带预览的图片浏览器的更多相关文章

  1. FileUpload控件实现单按钮图片自动上传并带预览显示

    FileUpload控件实现单按钮图片自动上传并带预览显示 1.实现原理:   FileUpload控件默认不支持服务端的ONCHANGE事件,此时用一种变通的方法借用客户端的onchange事件,调 ...

  2. Asp.net实现同页面内多图片自动上传并带预览显示

    FileUpload控件实现单按钮图片自动上传并带预览显示 1.实现原理: 此方法适合针对有后台生成的图片相关内容,例如购物网站商品展示页面中的封面图片,图片的数量由后台访问数据库,并加载到页面.这种 ...

  3. 移动端 H5 拍照 从手机选择图片,移动端预览,图片压缩,图片预览,再上传服务器

    前言:最近公司的项目在做全网营销,要做非微信浏览器的wap 站 的改版,其中涉及到的一点技术就是采用H5 选择手机相册中的图片,或者拍照,再将获取的图片进行压缩之后上传. 这个功能模块主要有这5点比较 ...

  4. 小程序实现图片上传,预览以及图片base64位处理

    最近一段时间在做小程序项目,第一期功也完工了.需要好好总结一下经验,把项目中遇到的问题好好总结一下,遇到的问题,踩过的坑.今天写一个小程序实现图片上传,预览,以及删除,图片base64位处理.下面就是 ...

  5. 可拖拽和带预览图的jQuery文件上传插件ssi-uploader

    插件描述:ssi-uploader是一款带预览图并且可以拖拽文件的jQuery ajax文件上传插件.该文件上传插件支持AJAX,支持多文件上传,可控制上的文件格式和文件大小,提供各种回调函数,使用非 ...

  6. 基于HTML5的可预览多图片Ajax上传

    一.关于图片上传什么什么的 在XHTML的时代,我们使用HTML file控件上传图片一次只能上传一张.要一次上传多图,做法是借助于flash.例如swfupload.js.可惜,使用复杂的点,比如f ...

  7. JAVA打印类(带预览)

    package tool; import java.awt.*; import java.awt.event.KeyEvent; import java.awt.event.KeyListener; ...

  8. HTML5可预览多图片ajax上传(使用formData传递数据)

    HTML5可预览多图片ajax上传(使用formData传递数据) 在介绍上传图片之前,我们简单的来了解下FormData的基本使用:介绍完成后这些基本知识后,我们会在文章最后提供一个demo,就是a ...

  9. input type=file实现图片上传,预览以及图片删除

    背景 前两天在做一个PC网站的意见反馈,其中涉及到了图片上传功能,要求可以上传多张图片,并且支持图片上传预览及图片删除, 图片上传这一块以前没怎么搞过,而且一般也很少会碰到这样的需求,所以在做这个功能 ...

随机推荐

  1. MIME(Multipurpose Internet Mail Extensions-多用途互联网邮件扩展)

    MIME MIME(Multipurpose Internet Mail Extensions)多用途互联网邮件扩展类型.是设定某种扩展名的文件用一种应用程序来打开的方式类型,当该扩展名文件被访问的时 ...

  2. python os模块常用命令

    python编程时,经常和文件.目录打交道,这是就离不了os模块.os模块包含普遍的操作系统功能,与具体的平台无关.以下列举常用的命令 1. os.name()——判断现在正在实用的平台,Window ...

  3. 第一个gulp程序

    说起来惭愧,一直用公司内部的工具,没有用这些红得发紫的东西.今天东抄西拼终于搞出第一个gulp应用.gulp是做什么的,好处在哪儿我不废话了.直入主题吧. 先在D盘下建立一个xxxx目录,然后打开控制 ...

  4. delphi 中判断对象是否具备某一属性

    Uses   TypInfo;         {$R   *.dfm}         procedure   TForm1.Button1Click(Sender:   TObject);     ...

  5. 关于struts.xml配置文件的说明

    <struts> <!-- action: 对应controller 中的类的 name: 匹配url要访问的类 class:包名+类名 通过反射产生对象 method:指定默认访问 ...

  6. TensorFlow RNN MNIST字符识别演示快速了解TF RNN核心框架

    TensorFlow RNN MNIST字符识别演示快速了解TF RNN核心框架 http://blog.sina.com.cn/s/blog_4b0020f30102wv4l.html

  7. Windows2008 IIS + .NET环境搭建指南

    Windows下最常用的网页服务器是自带的IIS,这里将为大家演示,windows2008下如何搭建IIS + .NET的动态网页环境. 环境配置:Qcloud 云服务器 windows 200864 ...

  8. Asp.net实现同页面内多图片自动上传并带预览显示

    FileUpload控件实现单按钮图片自动上传并带预览显示 1.实现原理: 此方法适合针对有后台生成的图片相关内容,例如购物网站商品展示页面中的封面图片,图片的数量由后台访问数据库,并加载到页面.这种 ...

  9. Python错误:close failed in file object destructor

    我遇到的情况: 二进制程序调shell再调Python后,shell退出,Python进程挂到init上(不是僵尸进程),但 此时二进制程序未退出,这时候中断而二进制程序出现此提示. 经查询: 应该是 ...

  10. springboot自定义消息转换器HttpMessageConverter

    在SpringMVC中,可以使用@RequestBody和@ResponseBody两个注解,分别完成请求报文到对象和对象到响应报文的转换,底层这种灵活的消息转换机制就是利用HttpMessageCo ...