README.md

    PictureSelector 2.0

    A Picture Selector for Android platform, support from the album to obtain pictures, video, audio & photo, support crop (single picture or multi-picture crop), compression, theme custom configuration and other functions, support dynamic access & adapt to Android 5.0+ system of open source picture selection framework。

    中文版🇨🇳

    Download APK

    PRs Welcome CSDN I Star

    Directory

    -Or use Gradle
    -Update Log
    -Style Configuration-Xml
    -Style Configuration-Code
    -Demo Effect
    -Api Explain
    -PictureSelector Path Desc
    -Open Photo Album
    -Open Camera
    -Custom Camera
    -Results Callback
    -Cache Clear
    -Confusion
    -License

    Version

    repositories {
      google()
      mavenCentral()
    }
    
    dependencies {
      implementation 'io.github.lucksiege:pictureselector:v2.7.3-rc10'
    }

    Or Maven:

    <dependency>
      <groupId>io.github.lucksiege</groupId>
      <artifactId>pictureselector</artifactId>
      <version>v2.7.3-rc10</version>
    </dependency>

    Photo

    Quick call, more functions More

    1、onActivityResult

     PictureSelector.create(this)
       .openGallery(PictureMimeType.ofImage())
       .imageEngine(GlideEngine.createGlideEngine()) // Please refer to the Demo GlideEngine.java
       .forResult(PictureConfig.CHOOSE_REQUEST);
       
        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data) {
            super.onActivityResult(requestCode, resultCode, data);
            if (resultCode == RESULT_OK) {
                switch (requestCode) {
                    case PictureConfig.CHOOSE_REQUEST:
                        // onResult Callback
                        List<LocalMedia> result = PictureSelector.obtainMultipleResult(data);
                        break;
                    default:
                        break;
                }            
            }

    2、Callback

     PictureSelector.create(this)
       .openGallery(PictureMimeType.ofAll())
       .imageEngine(GlideEngine.createGlideEngine())
       .forResult(new OnResultCallbackListener<LocalMedia>() {
           @Override
           public void onResult(List<LocalMedia> result) {
                // onResult Callback
           }
    
           @Override
           public void onCancel() {
                // onCancel Callback
           }
         });  

    Camera

    Quick Use, separately start the photo or video according to PictureMimeType automatic recognition More

    onActivityResult

     PictureSelector.create(this)
       .openCamera(PictureMimeType.ofImage())
       .imageEngine(GlideEngine.createGlideEngine()) // Please refer to the Demo GlideEngine.java
       .forResult(PictureConfig.REQUEST_CAMERA);  
       
        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data) {
            super.onActivityResult(requestCode, resultCode, data);
            if (resultCode == RESULT_OK) {
                switch (requestCode) {
                    case PictureConfig.REQUEST_CAMERA:
                        // onResult Callback
                        List<LocalMedia> result = PictureSelector.obtainMultipleResult(data);
                        break;
                    default:
                        break;
                }            
            }

    Callback

    PictureSelector.create(this)
       .openCamera(PictureMimeType.ofImage())
       .imageEngine(GlideEngine.createGlideEngine())
       .forResult(new OnResultCallbackListener<LocalMedia>() {
           @Override
           public void onResult(List<LocalMedia> result) {
                // onResult Callback
           }
    
           @Override
           public void onCancel() {
                // onCancel Callback
           }
         });

    CustomCamera

    If you need to use a custom camera you need to set up

    .isUseCustomCamera(true);

    Application implementing interface

     public class App extends Application implements CameraXConfig.Provider {
        private static final String TAG = App.class.getSimpleName();
    
        @Override
        public void onCreate() {
            super.onCreate();
        }
    
        @NonNull
        @Override
        public CameraXConfig getCameraXConfig() {
            return Camera2Config.defaultConfig();
        }
     }

    CacheClear

     // Include clipped and compressed cache, to be called upon successful upload, type refers to the image or video cache depending on which ofImage or ofVideo you set up note: system sd card permissions are required
     PictureCacheManager.deleteCacheDirFile(this,type);
     // Clear all temporary files generated by caching such as compression, clipping, video, and audio
     PictureCacheManager.deleteAllCacheDirFile(this);
     // Clear the cache and refresh the gallery
      PictureCacheManager.deleteAllCacheDirRefreshFile(this);
     // Clear the cache and refresh the gallery
     PictureCacheManager.deleteAllCacheDirFile(this, new OnCallbackListener<String>() {
                @Override
                public void onCall(String absolutePath) {
                    // Refresh the photo album
                }
            });

    Preview Image

    // Preview picture can be customized length press save path
    *Prompt .themeStyle(R.style.theme);Inside the parameters can not be deleted, otherwise crash...
    
    PictureSelector.create(this)
     .themeStyle(R.style.picture_default_style)
     .isNotPreviewDownload(true)
     .imageEngine(GlideEngine.createGlideEngine())
     .openExternalPreview(position, result);
    

    Preview Video

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

    Project use libraries

    • PhotoView
    • luban
    • ucrop

    Confusion

    #PictureSelector 2.0
    -keep class com.luck.picture.lib.** { *; }
    
    #Ucrop
    -dontwarn com.yalantis.ucrop**
    -keep class com.yalantis.ucrop** { *; }
    -keep interface com.yalantis.ucrop** { *; }
    
    

    License

       Copyright 2017 Luck
    
       Licensed under the Apache License, Version 2.0 (the "License");
       you may not use this file except in compliance with the License.
       You may obtain a copy of the License at
    
           http://www.apache.org/licenses/LICENSE-2.0
    
       Unless required by applicable law or agreed to in writing, software
       distributed under the License is distributed on an "AS IS" BASIS,
       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
       See the License for the specific language governing permissions and
       limitations under the License.

    Contact

    Android Group 662320389
    Android Group 1 619458861 (biggest)
    Android Group 2 679824206 (biggest)
    Android Group 3 854136996 (biggest)
    QQ 893855882

    Effect

    Single Mode Mixed Mode
    Default Style Preview Multiple Crop
    Digital Style Preview Multiple Crop
    White Style Preview Single Crop
    New Style Preview Multiple Crop
    Photo Album Directory Single Mode Circular Crop
    White Style Video Audio

    项目简介

    Picture Selector Library for Android or 图片选择器

    🚀 Github 镜像仓库 🚀

    源项目地址

    https://github.com/lucksiege/pictureselector

    发行版本

    当前项目没有发行版本

    贡献者 10

    开发语言

    • Java 100.0 %