在我們的日常開發中,經常有使用多圖選擇和展示的需求。這個時候,如果沒有較好的解決方案,我們需要自己編寫大量的代碼處理圖片的選擇和展示,這無疑會增加我們的開發時間和難度。因此,本文將介紹一個Android圖片選擇器,可以輕鬆解決多圖選擇和展示問題,讓我們的開發變得更加簡單。
一、使用方式
對於這個圖片選擇器,我們可以使用以下步驟集成到我們的項目中:
1、在項目的build.gradle文件中添加以下代碼:
allprojects {
repositories {
maven { url 'https://jitpack.io' }
}
}
2、在app的build.gradle文件中添加以下代碼,引入庫:
dependencies {
implementation 'com.github.LuckSiege.PictureSelector:v2.8.0-androidx'
}
3、在啟動圖片選擇器的Activity中添加以下代碼:
// 使用方法
PictureSelector.create(this)
.openGallery(PictureMimeType.ofImage())
.maxSelectNum(9)
.imageSpanCount(4)
.compress(true)
.forResult(PictureConfig.CHOOSE_REQUEST);
我們可以從以上代碼中看出,在使用該庫時,只需要簡單的幾行代碼調用就可以打開圖片選擇器,並實現多圖選擇功能。
二、基本功能介紹
1、可以選擇與預覽多張圖片。
通過使用該庫,我們可以在幾行代碼中輕鬆實現多圖選擇和預覽。而且在預覽圖片時,我們還可以自定義圖片的風格和布局。
2、支持單圖壓縮和多圖壓縮。
使用該庫時,我們可以自由選擇是否開啟圖片壓縮功能。而且在進行圖片壓縮時,該庫還能自動判定當前手機設置的圖片壓縮質量,以達到最優化的結果。
3、支持圖片裁剪功能。
在使用該庫時,我們可以自由選擇是否啟用圖片裁剪功能。而且在進行圖片裁剪時,該庫還可以根據我們設置的裁剪規則生成對應的裁剪框,方便我們更精確的進行圖片裁剪。
同時,該庫還支持圖片旋轉、拍照、錄製視頻等功能。
三、實現代碼
以下是一個簡單的實現使用該庫的代碼示例:
// Step 1. 圖片選擇設置
PictureSelector.create(this)
.openGallery(PictureMimeType.ofImage())
.maxSelectNum(9)
.imageSpanCount(4)
.compress(true)
.forResult(PictureConfig.CHOOSE_REQUEST);
// Step 2. 圖片預覽設置
PictureSelector.create(this)
.themeStyle(R.style.picture_default_style)
.loadImageEngine(GlideEngine.createGlideEngine())
.forResult(PictureConfig.CHOOSE_REQUEST);
// Step 3. 圖片壓縮功能設置
compressConfig =
new CompressConfig.Builder().setMaxSize(512000) // 最大壓縮尺寸
.setMaxPixel(1200) // 最大像素,默認值:1200
.enableReserveRaw(true) // 是否保留原文件,默認:true
.create();
PictureSelector.create(this)
.compress(true) // 開啟壓縮功能
.synOrAsy(true) // 同步壓縮方法
.loadImageEngine(GlideEngine.createGlideEngine()) // 請參考Demo GlideEngine.java
.compressSavePath(getPath()) // 壓縮圖片保存地址
.compressConfig(compressConfig) // 壓縮圖片的配置
.forResult(PictureConfig.CHOOSE_REQUEST);
// Step 4. 圖片裁剪功能設置
PictureSelector.create(this)
.openGallery(PictureMimeType.ofImage())
.imageSpanCount(4)
.maxSelectNum(9)
.minSelectNum(1)
.selectionMode(PictureConfig.MULTIPLE)
.isCamera(true)
.isZoomAnim(true)
.isGif(false)
.previewImage(true)
.previewVideo(false)
.enablePreviewAudio(false)
.enableCrop(true)
.cropWH(1,1)
.compress(true)
.compressQuality(80)
.synOrAsy(true)
.glideOverride(160,160)
.withAspectRatio(1, 1)
.hideBottomControls(false)
.freeStyleCropEnabled(true)
.isDragFrame(false)
.forResult(PictureConfig.CHOOSE_REQUEST);
參考資料
感興趣的讀者可以參考以下資料以深入了解該庫的使用和實現細節:
https://github.com/LuckSiege/PictureSelector
希望本文能夠幫助到大家,降低我們在圖片選擇和展示方面的開發難度,為我們的日常開發工作帶來更大的便利。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/206980.html