在Android开发中,选择相机和系统相册是常见的功能,用于获取用户拍摄的照片或选取已有的图片。 ImgUtil 是一个自定义的工具类,它封装了这部分操作,简化了开发者的工作。下面我们将详细讨论 ImgUtil 类中的关键方法和实现原理。 ImgUtil 提供了两个常量,分别表示拍照(TAKE_PHOTO)和选择相册(CHOOSE_PHOTO)的请求码。这些请求码在处理 onActivityResult() 方法时用于区分来自不同操作的结果。 在Android 6.0(API 级别 23)及以上版本,应用需要在运行时请求权限。因此,ImgUtil 中包含了两个权限请求码,REQUEST_CODE_CAMERA 和 REQUEST_CODE_ALBUM,用于相机和相册的权限请求。 ImgUtil 类中有一个静态变量 `imageUri`,这是用于存储相机拍摄图片的 Uri。在Android 7.0及以上版本,由于安全原因,拍摄的照片不能直接保存到应用私有目录,而是需要通过 FileProvider 创建一个临时 Uri 来访问。 以下是 ImgUtil 中的关键方法: 1. **choicePhoto()**:这个方法用于弹出一个对话框,让用户选择拍照或从相册选取图片。它创建了一个 AlertDialog 并设置了两个按钮,分别对应“拍照”和“选择相册”。点击每个按钮会触发对应的事件。 2. **openCamera()**:当用户选择拍照时,这个方法会被调用。它首先检查相机权限,如果缺少权限,则请求权限;如果已有权限,就启动相机应用。在Android 7.0及以上版本,我们需要创建一个 File 对象来存储照片,并通过 FileProvider 创建 Uri,以便相机应用可以访问。 3. **requestPermission()**:这是一个辅助方法,用于在Android 6.0及以上版本请求权限。它接受一个权限列表并调用 ActivityCompat.requestPermissions() 来发起权限请求。 4. **createImageFile()**:这个方法用于在外部存储创建一个临时文件,用于存储相机拍摄的照片。返回的 Uri 将被传递给相机应用,以便其可以将照片保存到这个文件中。 5. **getOutputMediaFile()**:这是一个辅助方法,用于创建一个 File 对象,通常用于存储图片或视频。它根据给定的媒体类型(如 MediaStore.Images.Media)创建一个位于外部存储的文件。 6. **compressBitmap(Bitmap bitmap)**:此方法用于压缩 Bitmap 对象,减少内存占用。它通过 ByteArrayOutputStream 和 BitmapFactory.Options 实现,可以根据需要调整压缩质量。 在实际使用 ImgUtil 时,你需要在 Activity 的 onActivityResult() 方法中处理返回的结果,例如解析 Uri 并显示选择的图片。同时,不要忘记处理 onRequestPermissionsResult() 方法,当用户对权限请求做出响应时,该方法会被调用。 ImgUtil 是一个实用的工具类,它简化了Android应用中选择相机和系统相册的操作。通过这个类,开发者可以轻松地集成这些功能,同时考虑到权限管理和Android的不同版本适配。
1