Git Product home page Git Product logo

pictureselector's Introduction

PictureSelector

最近项目中用到多图选择上传的需求,考虑到android机型众多问题就自己花时间写了一个,测试了大概60款机型,出现过一些问题也都一一修复了,基本上稳定了特分享出来,界面UI也是商用级的开发者不用在做太多修改了,界面高度自定义,可以设置符合你项目主色调的风格,集成完成后就可以拿来用。

项目会一直维护,发现问题欢迎提出会第一时间修复,QQ交流群 619458861,个人QQ [email protected]  希望用得着的朋友点个start。 

另附我的博客地址:http://blog.csdn.net/luck_mw

功能特点:

  1.适配android6.0+系统
  2.解决部分机型裁剪闪退问题
  3.解决图片过大oom闪退问题
  4.动态获取系统权限,避免闪退
  5.支持相片or视频的单选和多选
  6.支持裁剪比例设置,如常用的 1:1、3:4、3:2、16:9 默认为图片大小
  7.支持视频预览
  8.支持gif图片
  9.支持一些常用场景设置:如:是否裁剪、是否预览图片、是否显示相机等
  10.新增自定义主题设置
  11.新增图片勾选样式设置
  12.新增图片裁剪宽高设置
  13.新增图片压缩处理
  14.新增录视频最大时间设置
  15.新增视频清晰度设置
  16.新增QQ选择风格,带数字效果
  17.新增自定义 文字颜色 背景色让风格和项目更搭配
  18.新增多图裁剪功能
  19.新增LuBan多图压缩
  20.新增单独拍照功能
  21.新增压缩大小设置
  22.新增Luban压缩档次设置
    

那些遇到拍照闪退问题的同学,请记得看清下面适配6.0的配置~

重要的事情说三遍记得添加权限

  <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
  <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
  <uses-permission android:name="android.permission.CAMERA" />
    

注:适配android6.0以上拍照问题,请在AndroidManifest.xml中添加标签

<provider
   android:name="android.support.v4.content.FileProvider"
   android:authorities="${applicationId}.provider"
   android:exported="false"
   android:grantUriPermissions="true">
     <meta-data
         android:name="android.support.FILE_PROVIDER_PATHS"
         android:resource="@xml/file_paths" />
</provider>

集成步骤

compile引入

dependencies {
    compile 'com.github.LuckSiege.PictureSelector:picture_library:v1.3.1'
}

项目根目录

allprojects {
   repositories {
      jcenter()
      maven { url 'https://jitpack.io' }
   }
}

常见错误*

 问题一:
 rxjava冲突:在app build.gradle下添加
 packagingOptions {
   exclude 'META-INF/rxjava.properties'
 }  
 
 问题二:
 android.content.resXmlResourceParser 异常,请在AndroidManifest.xml 下添加适配6.0+拍照闪退问题
 <provider
      android:name="android.support.v4.content.FileProvider"
      android:authorities="${applicationId}.provider"
      android:exported="false"
      android:grantUriPermissions="true">
       <meta-data
         android:name="android.support.FILE_PROVIDER_PATHS"
         android:resource="@xml/file_paths" />
</provider>

问题三:
PhotoView 库冲突,可以删除自己项目中引用的,Picture_library中已经引用过,或引用com.commit451:PhotoView:1.2.4版本
 

相册启动构造方法

FunctionOptions options = new FunctionOptions.Builder()
        .setType(selectType) // 图片or视频 FunctionConfig.TYPE_IMAGE  TYPE_VIDEO
        .setCropMode(copyMode) // 裁剪模式 默认、1:1、3:4、3:2、16:9
        .setCompress(isCompress) //是否压缩
        .setEnablePixelCompress(true) //是否启用像素压缩
        .setEnableQualityCompress(true) //是否启质量压缩
        .setMaxSelectNum(maxSelectNum) // 可选择图片的数量
        .setSelectMode(selectMode) // 单选 or 多选
        .setShowCamera(isShow) //是否显示拍照选项 这里自动根据type 启动拍照或录视频
        .setEnablePreview(enablePreview) // 是否打开预览选项
        .setEnableCrop(enableCrop) // 是否打开剪切选项
        .setPreviewVideo(isPreviewVideo) // 是否预览视频(播放) mode or 多选有效
        .setCheckedBoxDrawable(checkedBoxDrawable)
        .setRecordVideoDefinition(FunctionConfig.HIGH) // 视频清晰度
        .setRecordVideoSecond(60) // 视频秒数
        .setGif(false)// 是否显示gif图片,默认不显示
        .setCropW(cropW) // cropW-->裁剪宽度 值不能小于100  如果值大于图片原始宽高 将返回原图大小
        .setCropH(cropH) // cropH-->裁剪高度 值不能小于100 如果值大于图片原始宽高 将返回原图大小
        .setMaxB(maxB) // 压缩最大值 例如:200kb  就设置202400,202400 / 1024 = 200kb
        .setPreviewColor(previewColor) //预览字体颜色
        .setCompleteColor(completeColor) //已完成字体颜色
        .setPreviewBottomBgColor(previewBottomBgColor) //预览底部背景色
        .setBottomBgColor(bottomBgColor) //图片列表底部背景色
        .setGrade(Luban.THIRD_GEAR) // 压缩档次 默认三档
        .setCheckNumMode(isCheckNumMode)
        .setCompressQuality(100) // 图片裁剪质量,默认无损
        .setImageSpanCount(4) // 每行个数
        .setSelectMedia(selectMedia) // 已选图片,传入在次进去可选中,不能传入网络图片
        .setCompressFlag(compressFlag) // 1 系统自带压缩 2 luban压缩
        .setCompressW(compressW) // 压缩宽 如果值大于图片原始宽高无效
        .setCompressH(compressH) // 压缩高 如果值大于图片原始宽高无效
        .setThemeStyle(themeStyle) // 设置主题样式
        .create();     

启动相册并拍照      

 PictureConfig.getPictureConfig().init(options).openPhoto(mContext, resultCallback);
 
 或默认配置
 PictureConfig.getPictureConfig().openPhoto(mContext, resultCallback);

单独启动拍照      

 PictureConfig.getPictureConfig().init(options).startOpenCamera(mContext, resultCallback);
 
 或默认
 PictureConfig.getPictureConfig().startOpenCamera(mContext, resultCallback);

预览图片 注:视频无效      

 PictureConfig.getPictureConfig().externalPicturePreview(mContext, position, selectMedia);

预览视频

PictureConfig.getPictureConfig().externalPictureVideo(mContext, selectMedia.get(position).getPath());

图片回调完成结果返回

  private PictureConfig.OnSelectResultCallback resultCallback = new PictureConfig.OnSelectResultCallback() {
        @Override
        public void onSelectSuccess(List<LocalMedia> resultList) {
            selectMedia = resultList;
            Log.i("callBack_result", selectMedia.size() + "");
            LocalMedia media = resultList.get(0);
            if (media.isCut() && !media.isCompressed()) {
                // 裁剪过
                String path = media.getCutPath();
            } else if (media.isCompressed() || (media.isCut() && media.isCompressed())) {
                // 压缩过,或者裁剪同时压缩过,以最终压缩过图片为准
                String path = media.getCompressPath();
            } else {
                // 原图地址
                String path = media.getPath();
            }
            if (selectMedia != null) {
                adapter.setList(selectMedia);
                adapter.notifyDataSetChanged();
            }
        }
    };
    

image image image image image image image image image image image

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.