`
zhoujinxiong
  • 浏览: 25982 次
  • 性别: 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;

}

}

分享到:
评论

相关推荐

    GridView图片墙,ListView中嵌入GridView,图片异步下载

    总的来说,这个项目涵盖了Android UI设计、数据加载优化和图片处理等多个核心知识点,对于提升Android应用的性能和用户体验具有重要意义。通过这样的实践,开发者可以更好地掌握Android开发中的复杂布局和资源管理...

    gridview 异步加载本地图片

    这些库提供了方便的接口,支持异步加载、缓存管理和图片缩放等功能,大大简化了开发工作。 6. **滚动监听**: 要实现滚动加载,需要监听GridView的滚动事件。可以通过设置OnScrollListener来捕获滚动事件,当检测...

    android gridview的自由拖动排序加显示页

    在这个项目中,我们看到的标题是"android gridview的自由拖动排序加显示页",这表明开发者已经实现了对GridView中的项进行自由拖动排序的功能,并且可能还结合了页面显示的优化。 首先,我们要理解“拖动排序”的...

    GridviewDemo

    "GridviewDemo"项目显然是一个展示如何在Android应用中结合使用GridView和CardView的示例代码。 GridView是一个二维的列表视图,可以水平或垂直滚动,它的每个子视图(item)都是同样大小的,通常用于创建像照片墙...

    GridView (文字)(图标)演示

    GridView是Android平台中一个常用的布局控件,常用于展示数据集,如图片、文字或两者结合,以一种网格的形式进行排列。在这个“GridView (文字) (图标) 演示”中,我们将会探讨如何创建一个简单的九宫格界面,展示...

    Android开发 ExpandableListView嵌套GridView的实现

    每个数据项占据一个单元格,通常用于显示图片和文字等信息。当我们在`ExpandableListView`的一个子组内使用`GridView`时,需要确保`GridView`的高度适配,以便正确显示所有子项。 接下来是实现步骤: 1. **创建...

    AndroidGridView拖动效果

    在许多应用中,为了提供更丰富的用户体验,我们可能需要实现GridView的拖动效果,例如图片、文字或自定义视图(如sufferView)的拖动。这个“AndroidGridView拖动效果”涉及到的技术点主要包括: 1. GridView的基本...

    android gridview

    这个“android gridview”项目显然是利用GridView来实现一个两列同时显示图片和文字的效果。下面将详细解释GridView的工作原理,以及如何在Adapter的`getView()`方法中设置显示样式。 1. ** GridView基本概念**: ...

    android ViewFlipper + Gridview 实现网格视图由上向下自动滑动效果

    GridView非常适合用来展示大量的、有规律的数据,如图片、图标或者文字等。通过适配器(如BaseAdapter或ArrayAdapter)与数据源关联,GridView可以动态加载和更新数据。 实现"网格视图由上向下自动滑动效果",首先...

    android 拖拽 gridview拖动+自动移位效果 zaker

    为了调试和测试,你可以创建一个简单的数据集,包含一些占位符图像和文字,然后在GridView中显示。在运行应用后,尝试拖动项目并观察自动移位的效果是否符合预期。 总的来说,实现“拖拽GridView拖动+自动移位效果...

    简单的ListView和GridView的排列方式

    为了使效果更佳,我们还可以自定义布局文件以适应ListView和GridView的不同需求,例如为ListView使用单行布局,为GridView使用带有图片和文字的单元格布局。这样,当用户点击图片时,不仅数据的排列方式会改变,...

    GridView异步加载大量网络图片

    在Android开发中,GridView是一种常用的布局控件,用于展示一系列数据项,如图片、文字等。当需要在GridView中加载大量网络图片时,如果不采取适当的优化策略,可能会导致内存溢出(Out Of Memory,OOM)问题,严重...

    Android 利用ViewPager+GridView,仿美团首页导航栏分类布局界面

    接下来是`GridView`,这是一个可滚动的视图,显示一个二维网格,常用于图片和文字的列表展示。在美团的分类导航中,每个分类通常包含多个子项,`GridView`则能很好地适应这种布局,将子项以网格的形式排列,用户可以...

    android用GridView实现九宫格菜单

    在Android开发中,GridView是一种非常常用的布局控件,它能够以网格的形式展示数据,非常适合用来实现九宫格...在实际开发中,还可以结合动态加载数据、异步加载图片等高级特性,进一步优化九宫格菜单的功能和性能。

    Android控件Gridview实现仿支付宝首页,Fragment底部按钮切换和登录圆形头像

    在Android中,可以自定义Gridview的Item布局,包含ImageView(图标)和TextView(文字描述)。通过设置合适的间距、边框和背景色,可以使得整体风格与支付宝首页更加接近。同时,为每个单元格添加点击事件监听,可以...

    Android中GridView配合ImageLoader实现图文展示

    5. **设置数据源**:为`GridView`设置数据源,这可以是包含图片URL和文字信息的列表。适配器会根据这个列表动态创建和填充`GridView`的单元格。 6. **监听加载状态**:`ImageLoader`提供了监听图片加载状态的功能,...

    [Android] 通过GridView仿微信动态添加本地图片示例代码

    总之,这个示例展示了如何利用Android的GridView控件结合SimpleAdapter实现类似微信动态的本地图片选择和显示功能,同时也涉及到基本的布局设计和用户交互处理。这种技术在许多应用中都有广泛的应用,比如社交应用、...

    viewPager结合Gridview使用

    在Android开发中,`ViewPager`和`GridView`是两种非常重要的布局控件,它们各自有着独特的功能,并且在很多场景下可以结合起来使用,以实现更丰富的用户界面。本项目"viewPager结合Gridview使用"就是一个典型的例子...

    广告轮播 美团九宫格 GridView分页 沉浸式标题栏 网络加载图片

    在Android应用开发中,"广告轮播 美团九宫格 GridView分页 沉浸式标题栏 网络加载图片" 这些功能是常见的组件和技术,它们为用户提供了丰富的交互体验和视觉效果。下面将详细介绍这些知识点。 1. 广告轮播: 广告...

    Android源码——GridView + ViewFlipper布局界面,模仿“机锋市场.zip

    为GridView设定列数(例如`android:numColumns="2"`)和适配器(使用`app:adapter`属性引用自定义适配器)。在ViewFlipper内添加需要切换的子视图,如ImageView或其他自定义布局。 2. 创建适配器类,继承自...

Global site tag (gtag.js) - Google Analytics