PicturePicker
github:https://github.com/sundevin/PicturePicker
一個仿微信朋友圈圖片選擇的相冊庫
項目為高仿微信圖片選擇模塊芹敌,目前可實現(xiàn)圖片的單選铲掐,多選灼伤,拍照玖详,預(yù)覽,或者只拍照不選圖鸡号,選擇后刪除等
圖片裁剪功能支持自定義裁剪框樣式良漱,大小局义,形狀,方向旋轉(zhuǎn)当窗,裁剪后圖片的尺寸等
后期將會添加自定義主題
項目參考了其他類似開源項目的部分實現(xiàn)够坐,并針對一些邊界問題做了修復(fù),例如初始時無圖片或者圖片過多導(dǎo)致的問題,并針對特殊機型的拍照 crash 問題做了修復(fù)咆霜,代碼更加簡潔邓馒。
效果演示:
更新日志
- 2.0.0
2017/12/12
修復(fù)已知的 bug
不再強制進行全局初始化
圖庫支持 gif 過濾選項
預(yù)覽圖片時 api 調(diào)用更方便
將查看圖片的邏輯放在 fragment 里,方便自定義蛾坯。
- 1.0.4
2017/7/14
修復(fù)裁剪圖片時 crash 的問題光酣;
拍攝完成后不再跳轉(zhuǎn)到預(yù)覽頁面,直接返回圖片脉课。
- 1.0.3
2017/7/13
修復(fù) Fragment 導(dǎo)包不統(tǒng)一的問題救军,增加對 Fragment 和 v4.Fragment 的支持。
使用:
適用版本 minSdkVersion 19及以上
添加依賴
1,gradle
dependencies {
// lastVersion 替換為最新版本號
compile 'com.sundevin:picturepicker:{lastVersion}'
}
2,下載 library,以 module 的方式導(dǎo)入倘零。
初始化全局配置(非必須)
@Override
public void onCreate() {
super.onCreate();
//初始化全局配置(如果不需要指定存儲路徑唱遭,可省略)
PickerGlobalConfig config = new PickerGlobalConfig.Builder()
.setCacheFolderPath("xxxx")//設(shè)置拍照的路徑,默認sdcard/data/data/package/files
.build();
PicturePicker.getInstance().init(config);
//...
}
打開圖片選擇頁面
PickOptions options = new PickOptions.Builder()
//是否僅拍照 默認false
.setJustTakePhoto(rgPickType.getCheckedRadioButtonId() == R.id.rb_just_take_photo)
//是否可多選 默認true
.setMultiMode(rgPickType.getCheckedRadioButtonId() == R.id.rb_multi)
//多選時最大選擇數(shù)量 默認 9
.setPickMaxCount(seekBar.getProgress())
//選擇圖片時點擊是否可查看大圖呈驶,默認true(多選模式有效)
.setCanPreviewImg(cbCanPreview.isChecked())
//選擇圖片時是否可拍照 默認true
.setShowCamera(cbShowCamera.isChecked())
//是否顯示 gif 拷泽,默認true
.setSelectGif(cbShowGif.isChecked())
.build();
//默認配置
// PicturePicker.getInstance().startPickPicture(MainActivity.this, PICK_IMG_REQUEST);
PicturePicker.getInstance().startPickPicture(MainActivity.this, PICK_IMG_REQUEST, options);
獲取選擇的圖片
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (data != null && requestCode == PICK_IMG_REQUEST && resultCode == Activity.RESULT_OK) {
List<PictureItem> tempList = (List<PictureItem>) data.getSerializableExtra(PictureGridActivity.EXTRA_RESULT_PICK_IMAGES);
//...
}
}
進入裁剪功能
DisplayMetrics displayMetrics = getResources().getDisplayMetrics();
//具體方法看注釋和demo
CropOptions cropOptions = new CropOptions.Builder()
.setOutPutX(800)
.setOutPutY(800)
.setStyle(CropImageView.Style.RECTANGLE)
.setFocusWidth(displayMetrics.widthPixels)
.setFocusHeight(displayMetrics.widthPixels)
.setSaveRectangle(false)
.build();
//(支持activity,app.fragment袖瞻,v4.fragment 進入)
PictureCropActivity.startPictureCropActivity(MainActivity.this, pictureItemList.get(0).pictureAbsPath, cropOptions, CROP_IMG_REQUEST);
獲取裁剪后的圖片
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (data != null && requestCode == CROP_IMG_REQUEST && resultCode == Activity.RESULT_OK) {
String cropImgPath = data.getStringExtra(PictureCropActivity.EXTRA_NAME_CROP_IMG_PATH);
//...
}
}
查看圖片
//僅查看圖片時
PicturePreviewActivity.startActivityWithOnlyPreview(...);
//預(yù)覽且圖片可刪除時(支持activity司致,app.fragment,v4.fragment 進入)
PicturePreviewActivity.startActivityWithPreviewDel(...)
如果需要對圖片進行長按或者自定義 ui聋迎,可自己創(chuàng)建 Activity
脂矫,加入 PreviewPictureFragment
,調(diào)用其監(jiān)聽方法即可霉晕,具體參見 demo 的實現(xiàn)庭再。