SkillAgentSearch skills...

RxImagePicker

Android. Pick image from camera or gallery using RxJava2

Install / Use

/learn @MLSDev/RxImagePicker
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

RxImagePicker

An easy way to get image from Gallery or Camera with request runtime permission on Android M using RxJava2

Setup

To use this library your minSdkVersion must be >= 16.

In your build.gradle :

dependencies {
    implementation 'com.mlsdev.rximagepicker:library:2.2.1'    
}

Example

RxImagePicker.with(supportFragmentManager).requestImage(Sources.CAMERA).subscribe {
            //Get image by uri using one of image loading libraries. I use Glide in sample app.
        }

Request image from gallery :

RxImagePicker.with(supportFragmentManager).requestImage(Sources.GALLERY).subscribe {
            
        }

Request image from documents :

RxImagePicker.with(supportFragmentManager).requestImage(Sources.DOCUMENTS).subscribe {
            
        }

Use android chooser to get image :

RxImagePicker.with(supportFragmentManager).requestImage(Sources.CHOOSER, "Chooser title").subscribe {
            
        }

Request multiple images on Android Api level 18+ :

RxImagePicker.with(supportFragmentManager).requestMultipleImages().subscribe {
            //Get images by uris.
        }

Using converters

RxImagePicker.with(context).requestImage(Sources.GALLERY)
    .flatMap(new Function<Uri, ObservableSource<Bitmap>>() {
                    @Override
                    public ObservableSource<Bitmap> apply(@NonNull Uri uri) throws Exception {
                        return RxImageConverters.uriToBitmap(getContext(), uri);
                    }
                }).subscribe(new Consumer<Bitmap>() {
                    @Override
                    public void accept(@NonNull Bitmap bitmap) throws Exception {
                        // Do something with Bitmap
                    }
                });
RxImagePicker.with(context).requestImage(Sources.GALLERY)
    .flatMap(new Function<Uri, ObservableSource<File>>() {
                    @Override
                    public ObservableSource<File> apply(@NonNull Uri uri) throws Exception {
                        return RxImageConverters.uriToFile(getContext(), uri, new File("YOUR FILE"));
                    }
                }).subscribe(new Consumer<File>() {
                    @Override
                    public void accept(@NonNull File file) throws Exception {
                        // Do something with your file copy
                    }
                });

Sample App

<img src="https://cloud.githubusercontent.com/assets/1778155/11761109/cb70a420-a0bd-11e5-8cf1-e2b172745eab.png" width="400">

Authors

License

RxImagePicker is released under the MIT license. See LICENSE for details.

About MLSDev

<img src="https://cloud.githubusercontent.com/assets/1778155/11761239/ccfddf60-a0c2-11e5-8f2a-8573029ab09d.png" alt="MLSDev.com">

RxImagePicker is maintained by MLSDev, Inc. We specialize in providing all-in-one solution in mobile and web development. Our team follows Lean principles and works according to agile methodologies to deliver the best results reducing the budget for development and its timeline.

Find out more here and don't hesitate to contact us!

View on GitHub
GitHub Stars334
CategoryDevelopment
Updated8mo ago
Forks51

Languages

Kotlin

Security Score

87/100

Audited on Jul 22, 2025

No findings