当前位置:   article > 正文

Android——UI篇:Android 图片选择器PictureSelector_android pictureselector

android pictureselector

一、功能介绍:

功能特点: 
1.适配 android7.0 系统
2.解决部分机型裁剪闪退问题
4.解决图片过大 oom 闪退问题
5.动态获取系统权限,避免闪退
6.支持相片 or 视频的单选和多选
7.支持裁剪比例设置,如常用的 1:1、3:4、3:2、16:9 默认为图片大小
8.支持视频预览
9.支持 gif 图片
10.支持一些常用场景设置:如:是否裁剪、是否预览图片、是否裁剪、是否显示相机等

二、android studio中使用:

1、添加权限

  1. <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
  2. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
  3. <uses-permission android:name="android.permission.CAMERA" />
注:适配 android6.0 以上拍照问题,请在 AndroidManifest.xml 中添加如下代码:

  1. <provider
  2. android:name="android.support.v4.content.FileProvider"
  3. android:authorities="${applicationId}.provider"
  4. android:exported="false"
  5. android:grantUriPermissions="true">
  6. <meta-data
  7. android:name="android.support.FILE_PROVIDER_PATHS"
  8. android:resource="@xml/file_paths" />
  9. </provider>
2、添加依赖

compile 'com.github.LuckSiege.PictureSelector:picture_library:v2.1.0'
然后再项目的根目录的build.gride中添加:
  1. allprojects {
  2. repositories {
  3. jcenter()
  4. maven { url 'https://jitpack.io' }
  5. }
  6. }
3、代码中使用:

  1. // 进入相册 以下是例子:用不到的 api 可以不写
  2. PictureSelector.create(MainActivity.this)
  3. .openGallery()//全部.PictureMimeType.ofAll()、图片.ofImage()、视频.ofVideo()
  4. .theme()//主题样式(不设置为默认样式) 也可参考 demo values/styles 下 例如:R.style.picture.white.style
  5. .maxSelectNum()// 最大图片选择数量 int
  6. .minSelectNum()// 最小选择数量 int
  7. .imageSpanCount(4)// 每行显示个数 int
  8. .selectionMode()// 多选 or 单选 PictureConfig.MULTIPLE or PictureConfig.SINGLE
  9. .previewImage()// 是否可预览图片 true or false
  10. .previewVideo()// 是否可预览视频 true or false
  11. .enablePreviewAudio() // 是否可播放音频 true or false
  12. .compressGrade()// luban 压缩档次,默认 3 档 Luban.THIRD_GEAR、Luban.FIRST_GEAR、Luban.CUSTOM_GEAR
  13. .isCamera()// 是否显示拍照按钮 true or false
  14. .isZoomAnim(true)// 图片列表点击 缩放效果 默认 true
  15. .sizeMultiplier(0.5f)// glide 加载图片大小 0~1 之间 如设置 .glideOverride()无效
  16. .setOutputCameraPath("/CustomPath")// 自定义拍照保存路径,可不填
  17. .enableCrop()// 是否裁剪 true or false
  18. .compress()// 是否压缩 true or false
  19. .compressMode()//系统自带 or 鲁班压缩 PictureConfig.SYSTEM_COMPRESS_MODE or LUBAN_COMPRESS_MODE
  20. .glideOverride()// int glide 加载宽高,越小图片列表越流畅,但会影响列表图片浏览的清晰度
  21. .withAspectRatio()// int 裁剪比例 如 16:9 3:2 3:4 1:1 可自定义
  22. .hideBottomControls()// 是否显示 uCrop 工具栏,默认不显示 true or false
  23. .isGif()// 是否显示 gif 图片 true or false
  24. .freeStyleCropEnabled()// 裁剪框是否可拖拽 true or false
  25. .circleDimmedLayer()// 是否圆形裁剪 true or false
  26. .showCropFrame()// 是否显示裁剪矩形边框 圆形裁剪时建议设为 false true or false
  27. .showCropGrid()// 是否显示裁剪矩形网格 圆形裁剪时建议设为 false true or false
  28. .openClickSound()// 是否开启点击声音 true or false
  29. .selectionMedia()// 是否传入已选图片 List<LocalMedia> list
  30. .previewEggs()// 预览图片时 是否增强左右滑动图片体验(图片滑动一半即可看到上一张是否选中) true or false
  31. .cropCompressQuality()// 裁剪压缩质量 默认 90 int
  32. .compressMaxKB()//压缩最大值 kb compressGrade()为 Luban.CUSTOM_GEAR 有效 int
  33. .compressWH() // 压缩宽高比 compressGrade()为 Luban.CUSTOM_GEAR 有效 int
  34. .cropWH()// 裁剪宽高比,设置如果大于图片本身宽高则无效 int
  35. .rotateEnabled() // 裁剪是否可旋转图片 true or false
  36. .scaleEnabled()// 裁剪是否可放大缩小图片 true or false
  37. .videoQuality()// 视频录制质量 0 or 1 int
  38. .videoSecond()// 显示多少秒以内的视频 or 音频也可适用 int
  39. .recordVideoSecond()//视频秒数录制 默认 60s int
  40. .forResult(PictureConfig.CHOOSE_REQUEST);//结果回调 onActivityResult code

记得要在上传完图片后调用,清理缓存:

  1. //包括裁剪和压缩后的缓存,要在上传成功后调用,注意:需要系统 sd 卡权限
  2. PictureFileUtils.deleteCacheDirFile(MainActivity.this);

4、主题配置:

  1. <!--默认样式 注意* 样式只可修改,不能删除任何一项 否则报错-->
  2. <style name="picture.default.style" parent="Theme.AppCompat.Light.DarkActionBar">
  3. <!-- Customize your theme here. -->
  4. <!--标题栏背景色-->
  5. <item name="colorPrimary">@color/bar_grey</item>
  6. <!--状态栏背景色-->
  7. <item name="colorPrimaryDark">@color/bar_grey</item>
  8. <!--是否改变图片列表界面状态栏字体颜色为黑色-->
  9. <item name="picture.statusFontColor">false</item>
  10. <!--返回键图标-->
  11. <item name="picture.leftBack.icon">@drawable/picture_back</item>
  12. <!--标题下拉箭头-->
  13. <item name="picture.arrow_down.icon">@drawable/arrow_down</item>
  14. <!--标题上拉箭头-->
  15. <item name="picture.arrow_up.icon">@drawable/arrow_up</item>
  16. <!--标题文字颜色-->
  17. <item name="picture.title.textColor">@color/white</item>
  18. <!--标题栏右边文字-->
  19. <item name="picture.right.textColor">@color/white</item>
  20. <!--图片列表勾选样式-->
  21. <item name="picture.checked.style">@drawable/checkbox_selector</item>
  22. <!--开启图片列表勾选数字模式-->
  23. <item name="picture.style.checkNumMode">false</item>
  24. <!--选择图片样式 0/9-->
  25. <item name="picture.style.numComplete">false</item>
  26. <!--图片列表底部背景色-->
  27. <item name="picture.bottom.bg">@color/color_fa</item>
  28. <!--图片列表预览文字颜色-->
  29. <item name="picture.preview.textColor">@color/tab_color_true</item>
  30. <!--图片列表已完成文字颜色-->
  31. <item name="picture.complete.textColor">@color/tab_color_true</item>
  32. <!--图片已选数量圆点背景色-->
  33. <item name="picture.num.style">@drawable/num_oval</item>
  34. <!--预览界面标题文字颜色-->
  35. <item name="picture.ac_preview.title.textColor">@color/white</item>
  36. <!--预览界面已完成文字颜色-->
  37. <item name="picture.ac_preview.complete.textColor">@color/tab_color_true</item>
  38. <!--预览界面标题栏背景色-->
  39. <item name="picture.ac_preview.title.bg">@color/bar_grey</item>
  40. <!--预览界面底部背景色-->
  41. <item name="picture.ac_preview.bottom.bg">@color/bar_grey_90</item>
  42. <!--预览界面状态栏颜色-->
  43. <item name="picture.status.color">@color/bar_grey_90</item>
  44. <!--预览界面返回箭头-->
  45. <item name="picture.preview.leftBack.icon">@drawable/picture_back</item>
  46. <!--是否改变预览界面状态栏字体颜色为黑色-->
  47. <item name="picture.preview.statusFontColor">false</item>
  48. <!--裁剪页面标题背景色-->
  49. <item name="picture.crop.toolbar.bg">@color/bar_grey</item>
  50. <!--裁剪页面状态栏颜色-->
  51. <item name="picture.crop.status.color">@color/bar_grey</item>
  52. <!--裁剪页面标题文字颜色-->
  53. <item name="picture.crop.title.color">@color/white</item>
  54. <!--相册文件夹列表选中图标-->
  55. <item name="picture.folder_checked_dot">@drawable/orange_oval</item>
  56. </style>
5、常用功能:

启动相册、拍照:

  1. PictureSelector.create(MainActivity.this)
  2. .openGallery(PictureMimeType.ofImage())
  3. .forResult(PictureConfig.CHOOSE_REQUEST);
单独启动拍照或视频 根据 PictureMimeType 自动识别

  1. PictureSelector.create(MainActivity.this)
  2. .openCamera(PictureMimeType.ofImage())
  3. .forResult(PictureConfig.CHOOSE_REQUEST);

预览图片:

  1. // 预览图片 可自定长按保存路径
  2. PictureSelector.create(MainActivity.this).externalPicturePreview(position, "/custom_file", selectList);
  3. PictureSelector.create(MainActivity.this).externalPicturePreview(position, selectList);

预览视频:

PictureSelector.create(MainActivity.this).externalPictureVideo(video_path);

结果回调:

  1. @Override
  2. protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  3. super.onActivityResult(requestCode, resultCode, data);
  4. if (resultCode == RESULT_OK) {
  5. switch (requestCode) {
  6. case PictureConfig.CHOOSE_REQUEST:
  7. // 图片选择结果回调
  8. selectList = PictureSelector.obtainMultipleResult(data);
  9. // 例如 LocalMedia 里面返回三种 path
  10. // 1.media.getPath(); 为原图 path
  11. // 2.media.getCutPath();为裁剪后 path,需判断 media.isCut();是否为 true
  12. // 3.media.getCompressPath();为压缩后 path,需判断 media.isCompressed();是否为 true
  13. // 如果裁剪并压缩了,以取压缩路径为准,因为是先裁剪后压缩的
  14. adapter.setList(selectList);
  15. adapter.notifyDataSetChanged();
  16. DebugUtil.i(TAG, "onActivityResult:" + selectList.size());
  17. break;
  18. }
  19. }
  20. }
6、混淆配置:

  1. #PictureSelector 2.0
  2. -keep class com.luck.picture.lib.** { *; }
  3. -dontwarn com.yalantis.ucrop**
  4. -keep class com.yalantis.ucrop** { *; }
  5. -keep interface com.yalantis.ucrop** { *; }
  6. #rxjava
  7. -dontwarn sun.misc.**
  8. -keepclassmembers class rx.internal.util.unsafe.*ArrayQueue*Field* {
  9. long producerIndex;
  10. long consumerIndex;
  11. }
  12. -keepclassmembers class rx.internal.util.unsafe.BaseLinkedQueueProducerNodeRef {
  13. rx.internal.util.atomic.LinkedQueueNode producerNode;
  14. }
  15. -keepclassmembers class rx.internal.util.unsafe.BaseLinkedQueueConsumerNodeRef {
  16. rx.internal.util.atomic.LinkedQueueNode consumerNode;
  17. }
  18. #rxandroid
  19. -dontwarn sun.misc.**
  20. -keepclassmembers class rx.internal.util.unsafe.*ArrayQueue*Field* {
  21. long producerIndex;
  22. long consumerIndex;
  23. }
  24. -keepclassmembers class rx.internal.util.unsafe.BaseLinkedQueueProducerNodeRef {
  25. rx.internal.util.atomic.LinkedQueueNode producerNode;
  26. }
  27. -keepclassmembers class rx.internal.util.unsafe.BaseLinkedQueueConsumerNodeRef {
  28. rx.internal.util.atomic.LinkedQueueNode consumerNode;
  29. }
  30. #glide
  31. -keep public class * implements com.bumptech.glide.module.GlideModule
  32. -keep public class * extends com.bumptech.glide.AppGlideModule
  33. -keep public enum com.bumptech.glide.load.resource.bitmap.ImageHeaderParser$** {
  34. **[] $VALUES;
  35. public *;
  36. }
  37. # for DexGuard only
  38. -keepresourcexmlelements manifest/application/meta-data@value=GlideModule
项目中需要第三方库的支持:

  • glide:4.0.0 RC1
  • rxjava:2.0.5
  • rxandroid:2.0.1
  • PhotoView:1.2.4
  • luban
  • 裁剪使用 ucrop

下面附上原文地址:
http://p.codekk.com/detail/Android/LuckSiege/PictureSelector


下面附上项目的github地址:

https://github.com/LuckSiege/PictureSelector

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/571340
推荐阅读
相关标签
  

闽ICP备14008679号