Giter VIP home page Giter VIP logo

pictureselector's Introduction

PictureSelector

最近项目中用到多图选择上传的需求,随后百度了一下用了别人写的demo,发现在很多机型上各种不适,闪退等问题,严重影响使用,后面我自己写了一个,公司20几款手机全部通过,在腾讯云测中也使用了4,50款手机测试,没有发现问题,特分享出来。 顺便感谢一下,大家对我的支持~

功能特点:

1.适配android7.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.新增多图裁剪功能

项目会一直维护,发现问题欢迎提出~  会第一时间修复哟~   联系方式[email protected]  希望用得着的朋友点个start,你们的支持才是我继续下去的动力,在此先谢过~  

app-build 引入compile 'com.github.LuckSiege:PictureSelector:v1.2.2'  注:之前引入如有报错,请引入最新版本、

项目根目录

allprojects {

  repositories {

      jcenter()

      maven { url 'https://jitpack.io' }

  }

}

注:适配android7.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>

        相册参数构造

FunctionConfig config = new FunctionConfig();  

config.setType(selectType); 1图片 or 2视频 LocalMediaLoader.TYPE_IMAGE,TYPE_VIDEO

config.setCopyMode(copyMode); 裁剪比例 默认 1:1 3:4 3:2 16:9 可参考 Constants.COPY_MODEL_1_1

config.setCompress(isCompress); 是否压缩

config.setMaxSelectNum(maxSelectNum - images.size()); 最大可选数量

config.setSelectMode(selectMode); 2单选 or 1多选 MODE_MULTIPLE MODE_SINGLE

config.setShowCamera(isShow); 是否显示相机

config.setEnablePreview(enablePreview); 是否预览

config.setEnableCrop(enableCrop); 是否裁剪

config.setPreviewVideo(isPreviewVideo); 是否预览视频(播放)

config.setCropW(cropW); 裁剪宽

config.setCropH(cropH); 裁剪高

config.setRecordVideoDefinition(Constants.HIGH); // 视频清晰度 Constants.HIGH 清晰 Constants.ORDINARY 普通 低质量

config.setRecordVideoSecond(60);// 视频秒数

config.setCheckNumMode(isCheckNumMode); 是否显示QQ选择风格(带数字效果)

config.setPreviewColor 预览文字颜色

config.setCompleteColor 完成文字颜色

config.setPreviewBottomBgColor 预览界面底部背景色

config.setBottomBgColor 选择图片页面底部背景色

config.options.setSelectMedia() 已选图片集合

// 先初始化参数配置,在启动相册

PictureConfig.init(config);

// 启动相册并设置回调函数  

PictureConfig.getPictureConfig.openPhoto(MainActivity.this, resultCallback);

// 外部预览图片方法 (例如选完后要预览的可调用此方法)

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

/**  * 图片回调方法 */

private PictureConfig.OnSelectResultCallback resultCallback = new PictureConfig.OnSelectResultCallback() {

  @Override

   public void onSelectSuccess(List< LocalMedia> resultList) {
          if (media.isCompressed()){
          // 注意:如果压缩过,在上传的时候,取 media.getCompressPath(); // 压缩图compressPath
          } else {
          // 注意:没有压缩过,在上传的时候,取 media.getPath(); // 原图path
           } else{

           // 注意:如果media.getCatPath();不为空的话 就代表裁剪的图片,上传时可取,但是如果又压缩过,则取最终压缩过的compressPath

           }

           selectMedia = resultList;  

          if (selectMedia != null) {

              adapter.setList(selectMedia);

              adapter.notifyDataSetChanged();

          }
      }
};

image image image image image image image image image image image

pictureselector's People

Contributors

luck1991 avatar

Watchers

James Cloos avatar  avatar

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.