private View.OnClickListener mChoosePhotoAlbumListener = new OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); //根据版本号不同使用不同的Action if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) { intent.setAction(Intent.ACTION_GET_CONTENT); } else { intent.setAction(Intent.ACTION_OPEN_DOCUMENT); intent.addCategory(Intent.CATEGORY_OPENABLE); } intent.setType("image/*"); intent.putExtra("crop", "true"); intent.putExtra("scale", "true"); intent.putExtra("scaleUpIfNeeded", true); //部分机型没有设置该参数截图会有黑边 intent.putExtra("aspectX", 10); intent.putExtra("aspectY", mAspectY); // outputX outputY 是裁剪图片宽高 intent.putExtra("outputX", mWidth); intent.putExtra("outputY", mHeight); // 输出路径 intent.putExtra("output", Uri.fromFile(new File(mThemePath))); startActivityForResult(intent, REQUEST_CODE_SELECT_FROM_ALBUM); } };
//关于裁剪框你需要知道的;
http://commonsware.com/blog/2013/01/23/no-android-does-not-have-crop-intent.html
处理方法1:
@Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (resultCode == RESULT_OK) { switch (requestCode) { case REQUEST_CODE_SELECT_FROM_ALBUM: if(data != null) { Uri imageUri; if(data.getData() != null){ imageUri = data.getData(); } else { imageUri = Uri.parse(mThemePath); } //TODO 自定义时id 为-1, final String thumbPath = DirectoryBuilder.DIR_THEME + mUserId + "_thumb" + ".png"; SessionTheme sessionTheme = new SessionTheme(); sessionTheme.theme_id = -1; sessionTheme.userId = mUserId; sessionTheme.name = "user_defined"; sessionTheme.token = mUserId + "_defined_" + System.currentTimeMillis(); sessionTheme.isInnerResource = false; sessionTheme.iconPath = thumbPath; if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) { sessionTheme.themePath = imageUri.getPath(); } else { String wholeID = DocumentsContract.getDocumentId(imageUri); if(!TextUtils.isEmpty(wholeID) && wholeID.contains(":")) { // 获得资源唯一ID String id = wholeID.split(":")[1]; // 定义索引字段 String[] column = { MediaStore.Images.Media.DATA }; String sel = MediaStore.Images.Media._ID + "=?"; Cursor cursor = getContentResolver().query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, column, sel, new String[] { id }, null); int columnIndex = cursor.getColumnIndex(column[0]); if (cursor.moveToFirst()) { // DATA字段就是本地资源的全路径 String filePath = cursor.getString(columnIndex); sessionTheme.themePath = filePath; } // 切记要关闭游标 cursor.close(); } } sessionTheme.status = SessionTheme.THEME_STATE_USER_DEFINED; mReturnTheme = sessionTheme; //异步更新 预览ICON saveIconTask(imageUri, thumbPath); } break; default: break; } } }
处理方法2:
/** * Get a file path from a Uri. This will get the the path for Storage Access * Framework Documents, as well as the _data field for the MediaStore and * other file-based ContentProviders. * * @param context The context. * @param uri The Uri to query. * @author paulburke */ public static String getPath(final Context context, final Uri uri) { final boolean isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT; // DocumentProvider if (isKitKat && DocumentsContract.isDocumentUri(context, uri)) { // ExternalStorageProvider if (isExternalStorageDocument(uri)) { final String docId = DocumentsContract.getDocumentId(uri); final String[] split = docId.split(":"); final String type = split[0]; if ("primary".equalsIgnoreCase(type)) { return Environment.getExternalStorageDirectory() + "/" + split[1]; } // TODO handle non-primary volumes } // DownloadsProvider else if (isDownloadsDocument(uri)) { final String id = DocumentsContract.getDocumentId(uri); final Uri contentUri = ContentUris.withAppendedId( Uri.parse("content://downloads/public_downloads"), Long.valueOf(id)); return getDataColumn(context, contentUri, null, null); } // MediaProvider else if (isMediaDocument(uri)) { final String docId = DocumentsContract.getDocumentId(uri); final String[] split = docId.split(":"); final String type = split[0]; Uri contentUri = null; if ("image".equals(type)) { contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI; } else if ("video".equals(type)) { contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI; } else if ("audio".equals(type)) { contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI; } final String selection = "_id=?"; final String[] selectionArgs = new String[] { split[1] }; return getDataColumn(context, contentUri, selection, selectionArgs); } } // MediaStore (and general) else if ("content".equalsIgnoreCase(uri.getScheme())) { return getDataColumn(context, uri, null, null); } // File else if ("file".equalsIgnoreCase(uri.getScheme())) { return uri.getPath(); } return null; } /** * Get the value of the data column for this Uri. This is useful for * MediaStore Uris, and other file-based ContentProviders. * * @param context The context. * @param uri The Uri to query. * @param selection (Optional) Filter used in the query. * @param selectionArgs (Optional) Selection arguments used in the query. * @return The value of the _data column, which is typically a file path. */ public static String getDataColumn(Context context, Uri uri, String selection, String[] selectionArgs) { Cursor cursor = null; final String column = "_data"; final String[] projection = { column }; try { cursor = context.getContentResolver().query(uri, projection, selection, selectionArgs, null); if (cursor != null && cursor.moveToFirst()) { final int column_index = cursor.getColumnIndexOrThrow(column); return cursor.getString(column_index); } } finally { if (cursor != null) cursor.close(); } return null; } /** * @param uri The Uri to check. * @return Whether the Uri authority is ExternalStorageProvider. */ public static boolean isExternalStorageDocument(Uri uri) { return "com.android.externalstorage.documents".equals(uri.getAuthority()); } /** * @param uri The Uri to check. * @return Whether the Uri authority is DownloadsProvider. */ public static boolean isDownloadsDocument(Uri uri) { return "com.android.providers.downloads.documents".equals(uri.getAuthority()); } /** * @param uri The Uri to check. * @return Whether the Uri authority is MediaProvider. */ public static boolean isMediaDocument(Uri uri) { return "com.android.providers.media.documents".equals(uri.getAuthority()); }
相关推荐
对于Android 4.4(KitKat)及以上版本,由于安全性和API的变化,获取图库中的图片路径变得更加复杂。本文将详细介绍如何在Android 4.4上获取图库文件路径的方法。 #### 一、背景介绍 Android 4.4(KitKat)引入了...
在Android 4.4系统中,用户可以根据个人喜好设置静态壁纸或动态壁纸,为设备增添个性化的视觉体验。本文将详细介绍这两种壁纸的设置流程,并通过思维导图的方式帮助理解每一步的操作步骤。 首先,我们来看静态壁纸...
综上所述,从Android 4.4后从图库中获取照片并显示在ImageView上,涉及到Intent、ContentResolver、Uri、权限管理以及图片加载库等多个方面。理解并熟练运用这些知识点,是Android开发者在处理用户交互时必备的技能...
在Android 4.4及以上版本,当用户从相机或图库选择图片时,返回的通常是Content URI而不是文件路径。例如,当使用Intent.ACTION_PICK启动相机或图库时,可以获取到Intent的数据字段,里面包含了选中图片的URI。通过...
以上就是在Android 4.4版本以下调用图库选择图片并进行裁剪的基本流程。实际开发中,还需考虑到权限动态申请、异常处理等细节,确保在不同设备上都能正常运行。通过上述步骤,开发者可以为用户提供一个流畅的图片...
在Android中,我们可以使用`Intent`来启动系统的图库应用,让用户选择图片。创建一个`Intent`,设置其类型为图片(`Intent.ACTION_PICK`, `android.provider.MediaStore.Images.Media.CONTENT_URI`),然后通过`...
在Android应用开发中,"图库/拍照获取图片后裁剪处理(兼容4.4+)"是一个常见的功能需求,涉及到用户交互、图像处理以及版本兼容性等多个方面。这一功能通常用于让用户选择或拍摄照片,并对其进行裁剪以适应特定的...
随着Android系统的不断升级,尤其是从Android 4.4(KitKat)开始引入的存储权限管理变化,开发者需要采取不同的策略来适配不同的系统版本。在本文中,我们将详细探讨如何在Android Studio环境下,使用FileProvider来...
Android 4.4(KitKat)及以上版本提供了ACTION_PICK或者ACTION_GET_CONTENT Intent,可以启动系统相册。为了实现多选,需要使用Intent.createChooser()来创建一个多选Intent,并且在AndroidManifest.xml中配置权限。...
从返回的URI中,我们需要解析出图片的实际路径。对于Android的不同版本,解析方式可能有所不同。例如,对于content://类型的URI,可能需要通过ContentResolver查询`MediaStore`获取真实路径;对于file://类型的URI...
首先,**图片选择** 在Android中通常涉及到访问设备的图库。Android提供了`Intent.ACTION_PICK`或者`Intent.ACTION_GET_CONTENT`来启动系统图库应用,让用户选择图片。以下是一个简单的示例: ```java Intent ...
- 从相册选择图片后,Intent的数据流会包含所选图片的URI,通过ContentResolver读取图片数据。 6. **图片的裁剪和预览** - 用户可能需要裁剪拍摄的照片,可以使用Intent的ACTION_IMAGE_CROP,但要注意这个Intent...
总结起来,实现Android从相册选择照片并返回功能的关键步骤包括: 1. 在`AndroidManifest.xml`中声明读取和写入外部存储的权限。 2. 创建一个Intent来启动系统相册。 3. 在`onActivityResult()`中处理返回的图像数据...
对于Android 4.4(API 19)及以上版本,我们通常使用`ACTION_OPEN_DOCUMENT`来选取图片: ```java private void takeImageFromAlbum(Activity activity, Builder builder) { Intent intent = new Intent(Intent....
在Android应用开发中,处理用户从相册选择二维码图片通常分为以下几个步骤: 1. **请求权限**:由于涉及到读取用户相册,我们需要在AndroidManifest.xml中添加读取外部存储的权限: ```xml <uses-permission ...
用户选择图片后,系统会返回一个Uri,表示所选图片的路径。我们可以通过ContentResolver和InputStream读取该Uri指向的图片数据,将其转换为Bitmap,然后显示在ImageView上。对于Android 4.4(KitKat)及以上版本,...
总之,Android应用要实现打开图库选择照片的功能,需要确保拥有适当的权限,然后使用Intent启动图库,接着在`onActivityResult()`中处理返回的图片URI。注意不同Android版本之间的差异,如KitKat(API级别19)之后的...
然后,当用户需要拍照或从图库选取图片时,我们通常会启动相机或图库应用,并通过`Intent`返回结果。在`Intent`中,我们需要使用`FileProvider`生成一个临时的URI,以便相机应用能够保存图片。 ```java // 创建一个...
要实现微信相册的选择功能,可以使用`ACTION_PICK`或`Intent.ACTION_GET_CONTENT`,让用户从手机图库中选择图片。此外,Android 4.4(KitKat)引入了`Storage Access Framework (SAF)`,提供了一个更统一的方式来...
为了实现图片选择功能,我们可以使用Intent启动系统图库,让用户选择图片,然后通过`onActivityResult()`回调处理返回的图片路径。在Android 6.0(Marshmallow)及以上版本,需要检查运行时权限,确保应用有读取存储...