zoukankan      html  css  js  c++  java
  • Android 如何从系统图库中选择图片

    转:http://blog.csdn.net/tody_guo/article/details/7560270

    这几天我都在做Android的App,同时学习它的API,我将分享一些我学到的东西,比如: 如何从系统图库中选择图片。

    首先,让我们来看看如何将手机系统图库集成到你的App中,然后再从图库中选择图片来做一些事。例如,在Facebook的App,你就可以直接选择手机上的图片上传到你的个人资料。

    让我们来做一个简单例子,要求:

    1. 屏幕上显示一个按钮和图片视图控件。
    2. 点击“载入图片”按钮,将用户重定向到Android的图片库,在那里可以选择一个图片。
    3. 一旦图片被选中,图片将在主屏幕上的图片视图控件中显示。

    让我们开始。

    步骤1:创建基本的Android项目

    在Eclipse中,点击New > Project > Android Project,给项目取名为“ImageGalleryDemo”,然后选择Android2.1或sdk 7。

    一旦这一步完成,你将看到一个基本的hello world程序。

    步骤2:修改布局文件

    在我们的例子中,我们需要一个简单的布局:一个ImageView控件来显示我们选中的图片,一个Button控件点击重定向到手机图库。

    在项目中打开layout/main.xml,然后替换成下面的代码:

    [html] view plaincopy
     
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    3.     android:orientation="vertical"  
    4.     android:layout_width="fill_parent"  
    5.     android:layout_height="fill_parent">  
    6.     <ImageView  
    7.         android:id="@+id/imgView"  
    8.         android:layout_width="fill_parent"  
    9.         android:layout_height="wrap_content"  
    10.         android:layout_weight="1"></ImageView>  
    11.     <Button  
    12.         android:id="@+id/buttonLoadPicture"  
    13.         android:layout_width="wrap_content"  
    14.         android:layout_height="wrap_content"  
    15.         android:layout_weight="0"  
    16.         android:text="Load Picture"  
    17.         android:layout_gravity="center"></Button>  
    18. </LinearLayout>  
     

    步骤3:编写重定向到图片库的代码

    现在我们需要写一些Java代码来处理按钮的点击事件,而重定向到图片库的代码如下:

    [java] view plaincopy
     
    1. Intent i = new Intent(  
    2. Intent.ACTION_PICK, android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);  
    3.    
    4. startActivityForResult(i, RESULT_LOAD_IMAGE);  

    注意:这里要传一个整形的常量RESULT_LOAD_IMAGEstartActivityForResult()方法。

    步骤4:获取选中的图片

    一旦用户选择了一张图片,onActivityResult()方法将会被调用。我们需要处理这个方法得到的数据,代码如下:

    [java] view plaincopy
     
    1. @Override  
    2. protected void onActivityResult(int requestCode, int resultCode, Intent data) {  
    3.     super.onActivityResult(requestCode, resultCode, data);  
    4.   
    5.     if (requestCode == RESULT_LOAD_IMAGE && resultCode == RESULT_OK && null != data) {  
    6.         Uri selectedImage = data.getData();  
    7.         String[] filePathColumn = { MediaStore.Images.Media.DATA };  
    8.   
    9.         Cursor cursor = getContentResolver().query(selectedImage,  
    10.                 filePathColumn, null, null, null);  
    11.         cursor.moveToFirst();  
    12.   
    13.         int columnIndex = cursor.getColumnIndex(filePathColumn[0]);  
    14.         String picturePath = cursor.getString(columnIndex);  
    15.         cursor.close();  
    16.   
    17.         // String picturePath contains the path of selected Image  
    18. }  
     

    注意:onActivityResult()方法只有当图片被选中后才会调用。在这个方法中,我们需要检查requestCode是否是我们之前传给startActivityForResult()方法的RESULT_LOAD_IMAGE。

    最终代码 
    ImageGalleryDemoActivity类的最终代码如下:

    [java] view plaincopy
     
    1. package net.viralpatel.android.imagegalleray;  
    2.    
    3. import android.app.Activity;  
    4. import android.content.Intent;  
    5. import android.database.Cursor;  
    6. import android.graphics.BitmapFactory;  
    7. import android.net.Uri;  
    8. import android.os.Bundle;  
    9. import android.provider.MediaStore;  
    10. import android.view.View;  
    11. import android.widget.Button;  
    12. import android.widget.ImageView;  
    13.    
    14. public class ImageGalleryDemoActivity extends Activity {  
    15.    
    16.     private static int RESULT_LOAD_IMAGE = 1;  
    17.    
    18.     @Override  
    19.     public void onCreate(Bundle savedInstanceState) {  
    20.         super.onCreate(savedInstanceState);  
    21.         setContentView(R.layout.main);  
    22.    
    23.         Button buttonLoadImage = (Button) findViewById(R.id.buttonLoadPicture);  
    24.         buttonLoadImage.setOnClickListener(new View.OnClickListener() {  
    25.    
    26.             @Override  
    27.             public void onClick(View arg0) {  
    28.    
    29.                 Intent i = new Intent(  
    30.                         Intent.ACTION_PICK,  
    31.                         android.provider.MediaStore.Images.Media.EXTERNAL_CONTENT_URI);  
    32.    
    33.                 startActivityForResult(i, RESULT_LOAD_IMAGE);  
    34.             }  
    35.         });  
    36.     }  
    37.    
    38.     @Override  
    39.     protected void onActivityResult(int requestCode, int resultCode, Intent data) {  
    40.         super.onActivityResult(requestCode, resultCode, data);  
    41.    
    42.         if (requestCode == RESULT_LOAD_IMAGE && resultCode == RESULT_OK && null != data) {  
    43.             Uri selectedImage = data.getData();  
    44.             String[] filePathColumn = { MediaStore.Images.Media.DATA };  
    45.    
    46.             Cursor cursor = getContentResolver().query(selectedImage,  
    47.                     filePathColumn, null, null, null);  
    48.             cursor.moveToFirst();  
    49.    
    50.             int columnIndex = cursor.getColumnIndex(filePathColumn[0]);  
    51.             String picturePath = cursor.getString(columnIndex);  
    52.             cursor.close();  
    53.    
    54.             ImageView imageView = (ImageView) findViewById(R.id.imgView);  
    55.             imageView.setImageBitmap(BitmapFactory.decodeFile(picturePath));  
    56.    
    57.         }  
    58.    
    59.     }  
    60. }  



     

    程序截图 
    第一屏:用户将重定向到手机图库

    用户从图库选择图片

    在我们的App显示用户选中的图片

    源代码:ImageGalleryDemo.zip (46 KB)

  • 相关阅读:
    DotNet中的迭代模式和组合模式
    能以可视化方式编辑滤镜效果的Image控件
    自定义ExtenderControl实现服务器控件可拖放
    股票交易费及利润计算器
    用ajax library的客户端脚本实现无刷新分页
    实现html转Xml
    oracle10g主机身份证明错误的解决办法
    创建ASP.NET AJAX客户端组件实现验证控件的toolTip式错误提示
    可分页的Repeater控件
    数据结构趣题——约瑟夫环
  • 原文地址:https://www.cnblogs.com/mochaMM/p/5110224.html
Copyright © 2011-2022 走看看