TakePhoto 簡介
TakePhoto
是一款用于在Android設(shè)備上獲取照片(拍照或從相冊(cè)剧董、文件中選擇)缴允、裁剪圖片跳座、壓縮圖片的開源工具庫轧铁,目前最新版本2.0.0每聪。
2.0以下版本及API說明,詳見TakePhoto1.0+齿风。
V2.0
- 支持通過相機(jī)拍照獲取圖片
- 支持從相冊(cè)選擇圖片
- 支持從文件選擇圖片
- 支持對(duì)圖片進(jìn)行壓縮
- 支持對(duì)圖片進(jìn)行裁剪
- 支持對(duì)裁剪及壓縮參數(shù)個(gè)性化配置
- 提供自帶裁剪工具(可選)
- 支持智能選取及裁剪異常處理
- 支持因拍照Activity被回收后的自動(dòng)恢復(fù)
GitHub地址: https://github.com/crazycodeboy/TakePhoto
預(yù)覽圖
運(yùn)行效果圖:
如何使用
使用TakePhoto有以下兩種方式:
方式一:通過繼承的方式
- 繼承
TakePhotoActivity
药薯、TakePhotoFragmentActivity
、TakePhotoFragment
三者之一救斑。 - 通過
getTakePhoto()
獲取TakePhoto
實(shí)例進(jìn)行相關(guān)操作童本。 - 重寫以下方法獲取結(jié)果
void takeSuccess(String imagePath);
void takeFail(String msg);
void takeCancel();
此方式使用簡單,滿足的大部分的使用需求脸候,具體使用詳見simple穷娱。如果通過繼承的方式無法滿足實(shí)際項(xiàng)目的使用绑蔫,可以通過下面介紹的方式。
方式二:通過組裝的方式
- 獲取TakePhoto實(shí)例
TakePhoto takePhoto=new TakePhotoImpl(getActivity(),this);
- 在
onCreate
,onActivityResult
,onSaveInstanceState
方法中調(diào)用TakePhoto對(duì)用的方法泵额。 - 調(diào)用TakePhoto實(shí)例進(jìn)行相關(guān)操作配深。
- 在
TakeResultListener
相關(guān)方法中獲取結(jié)果。
獲取圖片
TakePhoto提供拍照嫁盲,從相冊(cè)選擇篓叶,從文件中選擇三種方式獲取圖片。
API:
/**
* 從文件中獲取圖片(不裁剪)
*/
void onPickFromDocuments();
/**
* 從相冊(cè)中獲取圖片(不裁剪)
*/
void onPickFromGallery();
/**
* 從相機(jī)獲取圖片(不裁剪)
* @param outPutUri 圖片保存的路徑
*/
void onPickFromCapture(Uri outPutUri);
以上三種方式均提供對(duì)應(yīng)的裁剪API亡资,詳見:裁剪圖片澜共。
注:
由于不同Android Rom廠商對(duì)系統(tǒng)有不同程度的定制,有可能導(dǎo)致某種選擇圖片的方式不支持锥腻,所以為了提高TakePhoto
的兼容性嗦董,當(dāng)某種選的圖片的方式不支持時(shí),TakePhoto
會(huì)自動(dòng)切換成使用另一種選擇圖片的方式進(jìn)行圖片選擇瘦黑。
裁剪圖片
API
TakePhoto
支持對(duì)圖片進(jìn)行裁剪京革,無論是拍照的照片,還是從相冊(cè)、文件中選擇的圖片幸斥。你只需要調(diào)用TakePhoto
的相應(yīng)方法即可:
/**
* 從相機(jī)獲取圖片并裁剪
* @param outPutUri 圖片裁剪之后保存的路徑
* @param options 裁剪配置
*/
void onPickFromCaptureWithCrop(Uri outPutUri, CropOptions options);
/**
* 從相冊(cè)中獲取圖片并裁剪
* @param outPutUri 圖片裁剪之后保存的路徑
* @param options 裁剪配置
*/
void onPickFromGalleryWithCrop(Uri outPutUri, CropOptions options);
/**
* 從文件中獲取圖片并裁剪
* @param outPutUri 圖片裁剪之后保存的路徑
* @param options 裁剪配置
*/
void onPickFromDocumentsWithCrop(Uri outPutUri, CropOptions options);
對(duì)指定圖片進(jìn)行裁剪
另外匹摇,TakePhoto也支持你對(duì)指定圖片進(jìn)行裁剪:
/**
* 裁剪圖片
* @param imageUri 要裁剪的圖片
* @param outPutUri 圖片裁剪之后保存的路徑
* @param options 裁剪配置
*/
void onCrop(Uri imageUri, Uri outPutUri, CropOptions options)throws TException;
CropOptions
CropOptions
是用于裁剪的配置類,通過它你可以對(duì)圖片的裁剪比例甲葬,最大輸出大小廊勃,以及是否使用TakePhoto
自帶的裁剪工具進(jìn)行裁剪等,進(jìn)行個(gè)性化配置经窖。
Usage:
CropOptions cropOptions=new CropOptions.Builder().setAspectX(1).setAspectY(1).setWithOwnCrop(true).create();
getTakePhoto().onPickFromDocumentsWithCrop(imageUri,cropOptions);
//或
getTakePhoto().onCrop(imageUri,outPutUri,cropOptions);
注:
由于不同Android Rom廠商對(duì)系統(tǒng)有不同程度的定制坡垫,有可能系統(tǒng)中沒有自帶或第三方的裁剪工具,所以為了提高TakePhoto
的兼容性画侣,當(dāng)系統(tǒng)中沒有自帶或第三方裁剪工具時(shí)冰悠,TakePhoto
會(huì)自動(dòng)切換到使用TakePhoto
自帶的裁剪工具進(jìn)行裁剪。
壓縮圖片
你可以選擇是否對(duì)圖片進(jìn)行壓縮處理配乱,你只需要告訴它你是否要啟用壓縮功能以及CompressConfig
即可溉卓。
API
/**
* 啟用圖片壓縮
* @param config 壓縮圖片配置
* @param showCompressDialog 壓縮時(shí)是否顯示進(jìn)度對(duì)話框
* @return
*/
TakePhoto onEnableCompress(CompressConfig config,boolean showCompressDialog);
Usage:
getTakePhoto().onEnableCompress(compressConfig,true).onPickFromGalleryWithCrop(imageUri,cropOptions);
如果你啟用了圖片壓縮,TakePhoto
會(huì)使用CompressImage
對(duì)圖片進(jìn)行壓縮處理搬泥,CompressImage
目前支持對(duì)圖片的尺寸以及圖片的質(zhì)量進(jìn)行壓縮桑寨。默認(rèn)情況下,CompressImage
開啟了尺寸與質(zhì)量雙重壓縮忿檩。
對(duì)指定圖片進(jìn)行壓縮
另外西疤,你也可以對(duì)指定圖片進(jìn)行壓縮:
Usage:
new CompressImageImpl(compressConfig).compress(picturePath, new CompressImage.CompressListener() {
@Override
public void onCompressSuccess(String imgPath) {//圖片壓縮成功
}
@Override
public void onCompressFailed(String imagePath,String msg) {//圖片壓縮失敗
}
});
CompressConfig
CompressConfig
是用于圖片壓縮的配置類,你可以通過CompressConfig.Builder
對(duì)圖片壓縮后的尺寸以及質(zhì)量進(jìn)行相關(guān)設(shè)置休溶。如果你想改變壓縮的方式可以通過CompressConfig.Builder
進(jìn)行相關(guān)設(shè)置代赁。
Usage:
CompressConfig compressConfig=new CompressConfig.Builder().setMaxSize(50*1024).setMaxPixel(800).create();
getTakePhoto().onEnableCompress(compressConfig,true).onPickFromGallery();
兼容性
TakePhoto在深度兼容性方面的測試
獲取更高的兼容性
TakePhot
o是基于Android官方標(biāo)準(zhǔn)API編寫的扰她,適配了目前市場上主流的Rom。如果你在使用過程中發(fā)現(xiàn)了適配問題芭碍,可以提交Issues徒役。
- 為適配部分手機(jī)拍照時(shí)會(huì)回收
Activity
,TakePhoto
在onSaveInstanceState
與onCreate
做了相應(yīng)的恢復(fù)處理窖壕。 - 為適配部分手機(jī)拍照或從相冊(cè)選擇圖片時(shí)屏幕方向會(huì)發(fā)生轉(zhuǎn)變,從而導(dǎo)致拍照失敗的問題忧勿,可以在AndroidManifest.xml中對(duì)使用了
TakePhoto
的Activity
添加android:configChanges="orientation|keyboardHidden|screenSize"配置。
eg:
<activity
android:name=".MainActivity"
android:screenOrientation="portrait"
android:configChanges="orientation|keyboardHidden|screenSize"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
在項(xiàng)目中使用
為方便大家使用瞻讽,現(xiàn)已將TakePhoto V2.0.0發(fā)布到JCenter(如果你對(duì)如何將項(xiàng)目發(fā)布到JCenter感興趣可以參考:《教你輕松將Android library 發(fā)布到JCenter)》
Gradle:
compile 'com.jph.takephoto:takephoto_library:2.0.0'
Maven:
<dependency>
<groupId>com.jph.takephoto</groupId>
<artifactId>takephoto_library</artifactId>
<version>2.0.0</version>
<type>pom</type>
</dependency>
最后
如果你對(duì)TakePhoto有更好的建議或想改造它鸳吸,歡迎大家Fork and Pull requests。