`
zhoujinxiong
  • 浏览: 25389 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类

Android GridView 图片和文字结合

阅读更多

 

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;

}

}

分享到:
评论

相关推荐

    老罗android视频开发源码和ppt经典

    6.2 TextView显示表情图像和文字 6.3 TextView单击链接弹出Activity 6.4 TextView实现跑马灯效果 6.5 EditText输入表情图像 6.6 EditText中输入特定的字符 6.7 AutoCompleteTextView完成输入 6.8 Button按钮的焦点...

    Android中实现多行、水平滚动的分页的Gridview实例

    如果是多行水平滚动,则结合Gridview(一般是垂直滚动的)和Horizontalscrollview实现。 (2)水平滚动翻页,下面有显示当前页的icon。1.实现自定义的HorizontalScrollView(HorizontalScrollView.java): 因为要翻页...

    Google Android SDK开发范例大全(PDF高清完整版1)(4-1)

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android SDK开发范例大全(PDF完整版4)(4-4)

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android SDK开发范例大全(PDF高清完整版3)(4-3)

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android SDK开发范例大全的目录

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android SDK开发范例大全(完整版附部分源码).pdf

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android SDK 开发范例大全01

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android SDK 开发范例大全02

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google+Android+SDK开发范例大全

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android sdk 开发范例大全 部分章节代码

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    Google Android SDK开发范例大全(完整版)

    4.18 动态文字排版——GridView与ArrayAdapter设计 4.19 在Activity里显示列表列表——ListView的布局 4.20 以动态列表配置选项——ListActivity与Menu整合技巧 4.21 查找程序根目录下所有文件——JavaI/O与...

    黑马程序员 安卓学院 万元哥项目经理 分享220个代码实例

    |--android dp和px之间转换 |--android INSTALL_PARSE_FAILED_MANIFEST_MALFORMED |--android root下禁用组件 |--android 判断网络状态 |--android 对话框样式 |--android 开机启动 |--android 挪动dialog的位置 |--...

Global site tag (gtag.js) - Google Analytics