gridview布局
<?xml version="1.0" encoding="utf-8"?> <GridView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/gridview" android:layout_width="fill_parent" android:layout_height="fill_parent" android:columnWidth="90dp" android:numColumns="auto_fit" android:verticalSpacing="10dp" android:horizontalSpacing="10dp" android:stretchMode="columnWidth" android:gravity="center" />
item配件布局
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/root" android:orientation="vertical" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="5dp" > <ImageView android:id="@+id/image" android:layout_width="100dp" android:layout_height="150dp" android:layout_gravity="center" android:scaleType="fitXY" android:padding="4dp" /> <TextView android:id="@+id/title" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:gravity="center_horizontal" /> </LinearLayout>
主Activity
package com.su.testgrid3; import android.app.Activity; import android.os.Bundle; import android.os.Environment; import android.view.View; import android.widget.AdapterView; import android.widget.AdapterView.OnItemLongClickListener; import android.widget.GridView; import android.widget.Toast; import android.widget.AdapterView.OnItemClickListener; public class TestGrid3Activity extends Activity { private GridView gridView; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); String[] titles = FileUtil.getImageNames("/mnt/sdcard/k/"); String[] imagePaths = new String[titles.length]; for (int i = 0; i < titles.length; i++) { imagePaths[i]="/mnt/sdcard/k/"+titles[i]; } gridView = (GridView) findViewById(R.id.gridview); PictureAdapter adapter = new PictureAdapter(titles, imagePaths, this); gridView.setAdapter(adapter); gridView.setOnItemClickListener(new OnItemClickListener() { public void onItemClick(AdapterView<?> parent, View v, int position, long id) { Toast.makeText(TestGrid3Activity.this, "你点击了" + (position + 1), Toast.LENGTH_SHORT).show(); } }); gridView.setOnItemLongClickListener(new OnItemLongClickListener(){ public boolean onItemLongClick(AdapterView<?> parent, View v, int position, long id) { Toast.makeText(TestGrid3Activity.this, "你长按了" + (position + 1), Toast.LENGTH_SHORT).show(); return true; /* * 这里需要true * 因为:OnItemLongClick事件中:down事件返回值标记此次事 * 件是否为点击事件(返回false,是点击事件;返回true,不记为点击事件), * 而up事件标记此次事件结束时间,也就是判断是否为长按。 */ } }); } }
适配器
// 2012-4-18下午07:46:57 package com.su.testgrid3; import java.util.ArrayList; import java.util.List; import android.content.Context; import android.graphics.BitmapFactory; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ImageView; import android.widget.TextView; //自定义适配器 class PictureAdapter extends BaseAdapter { private LayoutInflater inflater; private List<Picture> pictures; public PictureAdapter(String[] titles, String[] images, Context context) { super(); pictures = new ArrayList<Picture>(); inflater = LayoutInflater.from(context); for (int i = 0; i < images.length; i++) { Picture picture = new Picture(titles[i], images[i]); pictures.add(picture); } } @Override public int getCount() { if (null != pictures) { return pictures.size(); } else { return 0; } } @Override public Object getItem(int position) { return pictures.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if (convertView == null) { convertView = inflater.inflate(R.layout.picture_item, null); viewHolder = new ViewHolder(); viewHolder.title = (TextView) convertView.findViewById(R.id.title); viewHolder.image = (ImageView) convertView.findViewById(R.id.image); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); } viewHolder.title.setText(pictures.get(position).getTitle()); viewHolder.image.setImageBitmap(BitmapFactory.decodeFile(pictures.get( position).getImageId())); return convertView; } } class ViewHolder { public TextView title; public ImageView image; }
picture的javabean
// 2012-4-18下午07:47:44 package com.su.testgrid3; class Picture { private String title; private String imageId; public Picture() { super(); } public Picture(String title, String imageId) { super(); this.title = title; this.imageId = imageId; } public String getTitle() { return title; } public void setTitle(String title) { this.title = title; } public String getImageId() { return imageId; } public void setImageId(String imageId) { this.imageId = imageId; } }
获取图片文件的名字数组的操作类
// 2012-4-18下午07:49:44 package com.su.testgrid3; import java.io.File; public class FileUtil { public static String[] getImageNames(String folderPath) { File file01 = new File(folderPath); String[] files01 = file01.list(); int imageFileNums = 0; for (int i = 0; i < files01.length; i++) { File file02 = new File(folderPath + "/" + files01[i]); if (!file02.isDirectory()) { if (isImageFile(file02.getName())) { imageFileNums++; } } } String[] files02 = new String[imageFileNums]; int j = 0; for (int i = 0; i < files01.length; i++) { File file02 = new File(folderPath + "/" + files01[i]); if (!file02.isDirectory()) { if (isImageFile(file02.getName())) { files02[j] = file02.getName(); j++; } } } return files02; } private static boolean isImageFile(String fileName) { String fileEnd = fileName.substring(fileName.lastIndexOf(".") + 1, fileName.length()); if (fileEnd.equalsIgnoreCase("jpg")) { return true; } else if (fileEnd.equalsIgnoreCase("png")) { return true; } else if (fileEnd.equalsIgnoreCase("bmp")) { return true; } else { return false; } } }
相关推荐
【ASP.NET编程知识】asp.net遍历文件夹下所有子文件夹并绑定到gridview上的方法.docx
excel文件图片和gridview图片
浏览sd卡上的图片文件,显示在GridView控件上,自定义图片适配器,点击小图,能在对话框上显示大图
Gridview批量删除,批量更新,批量修改都会用到Javascript对控件进行批量操作。这个例子很简单,但是注释写的很清楚。
可以从本地图片选择,拍照的图片也可显示到GridView中,能够长按显示删除标识,并实现删除功能。
android 自定义gridView 按日期显示图片和视频 galleryDemo android 自定义gridView 按日期显示图片和视频 galleryDemo android 自定义gridView 按日期显示图片和视频 galleryDemo 免费下载 给个好评!
gridview 和 datalist 全部遍历的几种方法 我都试过了 很好用
GridView横向显示实例GridView横向滚动显示实例
Android使用GridView加载SD卡下所有目录,文件夹多层遍历,文件图标修改,设置文件对应打开方式等功能。
这篇文章演示如果让用户有显示/隐藏他们需要的GridView的列的功能,这是非常有用的,因为在GridView的所有列并不是每个的用户都需要的.用户想根据自己的需求看到想要的列.而不是显示一个巨大的gridview,霸占了整个...
用GridView加动画写了一个滑动放大显示选中图片 项目需求在制定大小区域写一个横向菜单栏,菜单栏整体不能移动,GalleryFlow画廊不能满足需求,就自己重写写了一个)划到当图片时换个图片且动画效果渐渐放大,划到下...
gridview加载网络图片
GridView图片墙,ListView嵌入GridView
使用GridView以表格形式显示多张图片
读取手机图片并用gridview显示,用到了异步线程来进行显示
Android完美解决GridView异步加载图片和加载大量图片时出现Out Of Memory问题
这个也是别人整理好的用着不错 希望和大家一起享用 使用Gridview绑定数据库中的图片
android 开发 利用gridview读取图片并显示
android GridView搜索并显示SD卡上的图片,很不错的例子。
在ASP.NET 2.0中操作数据:在GridView控件中使用TemplateField(源码)