- 浏览: 25906 次
- 性别:
- 来自: 武汉
最新评论
-
elliotann:
谢谢,正好在用
Flex Builder 4 正式版 序列号 注册码 -
hellofuck:
thinks
Flex Builder 4 正式版 序列号 注册码
package cc.pic;
import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.util.ArrayList;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.net.Uri;
import android.os.AsyncTask;
import android.os.Bundle;
import android.provider.MediaStore;
import android.view.Display;
import android.view.KeyEvent;
import android.view.View;
import android.view.ViewGroup;
import android.view.Window;
import android.view.WindowManager;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
import android.widget.AdapterView.OnItemClickListener;
public class LoadImagesFromSDCardActivity extends Activity implements
OnItemClickListener {
/**
* Grid view holding the images.
*/
private GridView sdcardImages;
/**
* Image adapter for the grid view.
*/
private ImageAdapter imageAdapter;
/**
* Display used for getting the width of the screen.
*/
private Display display;
/**
* Creates the content view, sets up the grid, the adapter, and the click listener.
*
* @see android.app.Activity#onCreate(android.os.Bundle)
*/
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// Request progress bar
requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
setContentView(R.layout.main1);
display = ((WindowManager) getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay();
setupViews();
setProgressBarIndeterminateVisibility(true);
loadImages();
}
/**
* Free up bitmap related resources.
*/
protected void onDestroy() {
super.onDestroy();
final GridView grid = sdcardImages;
final int count = grid.getChildCount();
ImageView v = null;
for (int i = 0; i < count; i++) {
v = (ImageView) grid.getChildAt(i);
((BitmapDrawable) v.getDrawable()).setCallback(null);
}
}
/**
* Setup the grid view.
*/
private void setupViews() {
sdcardImages = (GridView) findViewById(R.id.sdcard);
sdcardImages.setNumColumns(display.getWidth()/95);
sdcardImages.setClipToPadding(false);
sdcardImages.setOnItemClickListener(LoadImagesFromSDCardActivity.this);
imageAdapter = new ImageAdapter(getApplicationContext());
sdcardImages.setAdapter(imageAdapter);
}
/**
* Load images.
*/
private void loadImages() {
final Object data = getLastNonConfigurationInstance();
if (data == null) {
new LoadImagesFromSDCard().execute();
} else {
final LoadedImage[] photos = (LoadedImage[]) data;
if (photos.length == 0) {
new LoadImagesFromSDCard().execute();
}
for (LoadedImage photo : photos) {
addImage(photo);
}
}
}
/**
* Add image(s) to the grid view adapter.
*
* @param value Array of LoadedImages references
*/
private void addImage(LoadedImage... value) {
for (LoadedImage image : value) {
imageAdapter.addPhoto(image);
imageAdapter.notifyDataSetChanged();
}
}
/**
* Save bitmap images into a list and return that list.
*
* @see android.app.Activity#onRetainNonConfigurationInstance()
*/
@Override
public Object onRetainNonConfigurationInstance() {
final GridView grid = sdcardImages;
final int count = grid.getChildCount();
final LoadedImage[] list = new LoadedImage[count];
for (int i = 0; i < count; i++) {
final ImageView v = (ImageView) grid.getChildAt(i);
list[i] = new LoadedImage(((BitmapDrawable) v.getDrawable()).getBitmap());
}
return list;
}
/**
* Async task for loading the images from the SD card.
*
* @author Mihai Fonoage
*
*/
class LoadImagesFromSDCard extends AsyncTask<Object, LoadedImage, Object> {
/**
* Load images from SD Card in the background, and display each image on the screen.
*
* @see android.os.AsyncTask#doInBackground(Params[])
*/
@Override
protected Object doInBackground(Object... params) {
//setProgressBarIndeterminateVisibility(true);
Bitmap bitmap = null;
Bitmap newBitmap = null;
Uri uri = null;
// Set up an array of the Thumbnail Image ID column we want
String[] projection = {MediaStore.Images.Thumbnails._ID};
// Create the cursor pointing to the SDCard
Cursor cursor = managedQuery( MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI,
projection, // Which columns to return
null, // Return all rows
null,
null);
int columnIndex = cursor.getColumnIndexOrThrow(MediaStore.Images.Thumbnails._ID);
int size = cursor.getCount();
// If size is 0, there are no images on the SD Card.
if (size == 0) {
//No Images available, post some message to the user
}
int imageID = 0;
for (int i = 0; i < size; i++) {
cursor.moveToPosition(i);
imageID = cursor.getInt(columnIndex);
uri = Uri.withAppendedPath(MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI, "" + imageID);
try {
bitmap = BitmapFactory.decodeStream(getContentResolver().openInputStream(uri));
if (bitmap != null) {
newBitmap = Bitmap.createScaledBitmap(bitmap, 70, 70, true);
bitmap.recycle();
if (newBitmap != null) {
publishProgress(new LoadedImage(newBitmap));
}
}
} catch (IOException e) {
//Error fetching image, try to recover
}
}
cursor.close();
return null;
}
/**
* Add a new LoadedImage in the images grid.
*
* @param value The image.
*/
@Override
public void onProgressUpdate(LoadedImage... value) {
addImage(value);
}
/**
* Set the visibility of the progress bar to false.
*
* @see android.os.AsyncTask#onPostExecute(java.lang.Object)
*/
@Override
protected void onPostExecute(Object result) {
setProgressBarIndeterminateVisibility(false);
}
}
/**
* Adapter for our image files.
*
* @author Mihai Fonoage
*
*/
class ImageAdapter extends BaseAdapter {
private Context mContext;
private ArrayList<LoadedImage> photos = new ArrayList<LoadedImage>();
public ImageAdapter(Context context) {
mContext = context;
}
public void addPhoto(LoadedImage photo) {
photos.add(photo);
}
public int getCount() {
return photos.size();
}
public Object getItem(int position) {
return photos.get(position);
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
final ImageView imageView;
if (convertView == null) {
imageView = new ImageView(mContext);
} else {
imageView = (ImageView) convertView;
}
imageView.setScaleType(ImageView.ScaleType.FIT_CENTER);
imageView.setPadding(8, 8, 8, 8);
imageView.setImageBitmap(photos.get(position).getBitmap());
return imageView;
}
}
/**
* A LoadedImage contains the Bitmap loaded for the image.
*/
private static class LoadedImage {
Bitmap mBitmap;
LoadedImage(Bitmap bitmap) {
mBitmap = bitmap;
}
public Bitmap getBitmap() {
return mBitmap;
}
}
/**
* When an image is clicked, load that image as a puzzle.
*/
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
int columnIndex = 0;
String[] projection = {MediaStore.Images.Media.DATA};
Cursor cursor = managedQuery( MediaStore.Images.Thumbnails.EXTERNAL_CONTENT_URI,
projection,
null,
null,
null);
if (cursor != null) {
columnIndex = cursor.getColumnIndexOrThrow(MediaStore.Images.Media.DATA);
cursor.moveToPosition(position);
String imagePath = cursor.getString(columnIndex);
FileInputStream is = null;
BufferedInputStream bis = null;
try {
is = new FileInputStream(new File(imagePath));
bis = new BufferedInputStream(is);
Bitmap bitmap = BitmapFactory.decodeStream(bis);
Bitmap useThisBitmap = Bitmap.createScaledBitmap(bitmap, parent.getWidth(), parent.getHeight(), true);
bitmap.recycle();
//Display bitmap (useThisBitmap)
Bundle data = new Bundle();
data.putString("imagepath", imagePath);
Intent intent = new Intent();
intent.setClass(getApplicationContext(), selectPhoto.class);
intent.putExtras(data);
startActivity(intent);
}
catch (Exception e) {
//Try to recover
}
finally {
try {
if (bis != null) {
bis.close();
}
if (is != null) {
is.close();
}
cursor.close();
projection = null;
} catch (Exception e) {
}
}
}
}
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (keyCode == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) {
Intent intent = new Intent(LoadImagesFromSDCardActivity.this, picActivity.class);
setResult(RESULT_OK, intent);
finish();
overridePendingTransition(R.anim.slide_up_in, R.anim.slide_down_out);
return false;
}
return false;
}
}
发表评论
-
struts 多模块开发
2008-08-29 16:06 1352扩展 多模块开发和软件扩展是现代软件开发过程中最重要的 ... -
25个优秀的Ajax技术和实例
2008-06-05 13:26 14111.Ajax RSS reader 一个简单的RSS rea ... -
关于页面的优化
2008-05-19 13:48 908互联网带宽越来越宽,似乎让网页的加载速度得到了质的飞跃。其实不 ... -
使用 OSCache
2008-05-09 11:51 1079OSCache是当前运用最广的缓存方案,JBoss,Hiber ... -
基于Web的系统测试方法
2008-05-09 11:42 990基于Web的系统测 ...
相关推荐
总的来说,这个项目涵盖了Android UI设计、数据加载优化和图片处理等多个核心知识点,对于提升Android应用的性能和用户体验具有重要意义。通过这样的实践,开发者可以更好地掌握Android开发中的复杂布局和资源管理...
这些库提供了方便的接口,支持异步加载、缓存管理和图片缩放等功能,大大简化了开发工作。 6. **滚动监听**: 要实现滚动加载,需要监听GridView的滚动事件。可以通过设置OnScrollListener来捕获滚动事件,当检测...
在这个项目中,我们看到的标题是"android gridview的自由拖动排序加显示页",这表明开发者已经实现了对GridView中的项进行自由拖动排序的功能,并且可能还结合了页面显示的优化。 首先,我们要理解“拖动排序”的...
"GridviewDemo"项目显然是一个展示如何在Android应用中结合使用GridView和CardView的示例代码。 GridView是一个二维的列表视图,可以水平或垂直滚动,它的每个子视图(item)都是同样大小的,通常用于创建像照片墙...
GridView是Android平台中一个常用的布局控件,常用于展示数据集,如图片、文字或两者结合,以一种网格的形式进行排列。在这个“GridView (文字) (图标) 演示”中,我们将会探讨如何创建一个简单的九宫格界面,展示...
每个数据项占据一个单元格,通常用于显示图片和文字等信息。当我们在`ExpandableListView`的一个子组内使用`GridView`时,需要确保`GridView`的高度适配,以便正确显示所有子项。 接下来是实现步骤: 1. **创建...
在许多应用中,为了提供更丰富的用户体验,我们可能需要实现GridView的拖动效果,例如图片、文字或自定义视图(如sufferView)的拖动。这个“AndroidGridView拖动效果”涉及到的技术点主要包括: 1. GridView的基本...
这个“android gridview”项目显然是利用GridView来实现一个两列同时显示图片和文字的效果。下面将详细解释GridView的工作原理,以及如何在Adapter的`getView()`方法中设置显示样式。 1. ** GridView基本概念**: ...
GridView非常适合用来展示大量的、有规律的数据,如图片、图标或者文字等。通过适配器(如BaseAdapter或ArrayAdapter)与数据源关联,GridView可以动态加载和更新数据。 实现"网格视图由上向下自动滑动效果",首先...
为了调试和测试,你可以创建一个简单的数据集,包含一些占位符图像和文字,然后在GridView中显示。在运行应用后,尝试拖动项目并观察自动移位的效果是否符合预期。 总的来说,实现“拖拽GridView拖动+自动移位效果...
为了使效果更佳,我们还可以自定义布局文件以适应ListView和GridView的不同需求,例如为ListView使用单行布局,为GridView使用带有图片和文字的单元格布局。这样,当用户点击图片时,不仅数据的排列方式会改变,...
在Android开发中,GridView是一种常用的布局控件,用于展示一系列数据项,如图片、文字等。当需要在GridView中加载大量网络图片时,如果不采取适当的优化策略,可能会导致内存溢出(Out Of Memory,OOM)问题,严重...
接下来是`GridView`,这是一个可滚动的视图,显示一个二维网格,常用于图片和文字的列表展示。在美团的分类导航中,每个分类通常包含多个子项,`GridView`则能很好地适应这种布局,将子项以网格的形式排列,用户可以...
在Android开发中,GridView是一种非常常用的布局控件,它能够以网格的形式展示数据,非常适合用来实现九宫格...在实际开发中,还可以结合动态加载数据、异步加载图片等高级特性,进一步优化九宫格菜单的功能和性能。
在Android中,可以自定义Gridview的Item布局,包含ImageView(图标)和TextView(文字描述)。通过设置合适的间距、边框和背景色,可以使得整体风格与支付宝首页更加接近。同时,为每个单元格添加点击事件监听,可以...
5. **设置数据源**:为`GridView`设置数据源,这可以是包含图片URL和文字信息的列表。适配器会根据这个列表动态创建和填充`GridView`的单元格。 6. **监听加载状态**:`ImageLoader`提供了监听图片加载状态的功能,...
总之,这个示例展示了如何利用Android的GridView控件结合SimpleAdapter实现类似微信动态的本地图片选择和显示功能,同时也涉及到基本的布局设计和用户交互处理。这种技术在许多应用中都有广泛的应用,比如社交应用、...
在Android开发中,`ViewPager`和`GridView`是两种非常重要的布局控件,它们各自有着独特的功能,并且在很多场景下可以结合起来使用,以实现更丰富的用户界面。本项目"viewPager结合Gridview使用"就是一个典型的例子...
在Android应用开发中,"广告轮播 美团九宫格 GridView分页 沉浸式标题栏 网络加载图片" 这些功能是常见的组件和技术,它们为用户提供了丰富的交互体验和视觉效果。下面将详细介绍这些知识点。 1. 广告轮播: 广告...
为GridView设定列数(例如`android:numColumns="2"`)和适配器(使用`app:adapter`属性引用自定义适配器)。在ViewFlipper内添加需要切换的子视图,如ImageView或其他自定义布局。 2. 创建适配器类,继承自...