takephoto 框架_TakePhoto-轻量级Android照片处理框架V2.0发布

TakePhoto

TakePhoto是一款用于在Android设备上获取照片(拍照或从相册、文件中选择)、裁剪图片、压缩图片的开源工具库,目前最新版本2.0.0。

2.0以下版本及API说明,详见TakePhoto1.0+。

V2.0

·         支持通过相机拍照获取图片

·         支持从相册选择图片

·         支持从文件选择图片

·         支持对图片进行压缩

·         支持对图片进行裁剪

·         支持对裁剪及压缩参数个性化配置

·         提供自带裁剪工具(可选)

·         支持智能选取及裁剪异常处理

·         支持因拍照Activity被回收后的自动恢复

如何使用

使用TakePhoto有以下两种方式:

方式一:通过继承的方式

1. 继承TakePhotoActivity、TakePhotoFragmentActivity、TakePhotoFragment三者之一。

2. 通过getTakePhoto()获取TakePhoto实例进行相关操作。

3. 重写以下方法获取结果

[代码]java代码:1

2

3void takeSuccess(String   imagePath);

void takeFail(String msg);

void takeCancel();

此方式使用简单,满足的大部分的使用需求,具体使用详见simple。如果通过继承的方式无法满足实际项目的使用,可以通过下面介绍的方式。

方式二:通过组装的方式

1. 获取TakePhoto实例TakePhoto takePhoto=new TakePhotoImpl(getActivity(),this);

2. 在 onCreate,onActivityResult,onSaveInstanceState方法中调用TakePhoto对用的方法。

3. 调用TakePhoto实例进行相关操作。

4. 在TakeResultListener相关方法中获取结果。

获取图片

TakePhoto提供拍照,从相册选择,从文件中选择三种方式获取图片。

API:

[代码]java代码:01

02

03

04

05

06

07

08

09

10

11

12

13/**

*从文件中获取图片(不裁剪)

*/

void onPickFromDocuments();

/**

*从相册中获取图片(不裁剪)

*/

void onPickFromGallery();

/**

*从相机获取图片(不裁剪)

* @param outPutUri图片保存的路径

*/

void onPickFromCapture(Uri   outPutUri);

以上三种方式均提供对应的裁剪API,详见:裁剪图片。

注:

由于不同Android Rom厂商对系统有不同程度的定制,有可能导致某种选择图片的方式不支持,所以为了提高TakePhoto的兼容性,当某种选的图片的方式不支持时,TakePhoto会自动切换成使用另一种选择图片的方式进行图片选择。

裁剪图片

API

TakePhoto支持对图片进行裁剪,无论是拍照的照片,还是从相册、文件中选择的图片。你只需要调用TakePhoto的相应方法即可:

[代码]java代码:01

02

03

04

05

06

07

08

09

10

11

12

13

14

15

16

17

18/**

*从相机获取图片并裁剪

* @param outPutUri图片裁剪之后保存的路径

* @param options裁剪配置

*/

void onPickFromCaptureWithCrop(Uri   outPutUri, CropOptions options);

/**

*从相册中获取图片并裁剪

* @param outPutUri图片裁剪之后保存的路径

* @param options裁剪配置

*/

void onPickFromGalleryWithCrop(Uri   outPutUri, CropOptions options);

/**

*从文件中获取图片并裁剪

* @param outPutUri图片裁剪之后保存的路径

* @param options裁剪配置

*/

void onPickFromDocumentsWithCrop(Uri   outPutUri, CropOptions options);

#### 对指定图片进行裁剪

另外,TakePhoto也支持你对指定图片进行裁剪:

[代码]java代码:1

2

3

4

5

6

7/**

*裁剪图片

* @param imageUri要裁剪的图片

* @param outPutUri图片裁剪之后保存的路径

* @param options裁剪配置

*/

void onCrop(Uri imageUri, Uri   outPutUri, CropOptions options)throws TException;

CropOptions

CropOptions是用于裁剪的配置类,通过它你可以对图片的裁剪比例,最大输出大小,以及是否使用TakePhoto自带的裁剪工具进行裁剪等,进行个性化配置。

Usage:

[代码]java代码:1

2

3

4CropOptions cropOptions=new CropOptions.Builder().setAspectX(1).setAspectY(1).setWithOwnCrop(true).create();

getTakePhoto().onPickFromDocumentsWithCrop(imageUri,cropOptions);

//或

getTakePhoto().onCrop(imageUri,outPutUri,cropOptions);

注:

由于不同Android Rom厂商对系统有不同程度的定制,有可能系统中没有自带或第三方的裁剪工具,所以为了提高TakePhoto的兼容性,当系统中没有自带或第三方裁剪工具时,TakePhoto会自动切换到使用TakePhoto自带的裁剪工具进行裁剪。

压缩图片

你可以选择是否对图片进行压缩处理,你只需要告诉它你是否要启用压缩功能以及CompressConfig即可。

API

[代码]java代码:1

2

3

4

5

6

7/**

*启用图片压缩

* @param config压缩图片配置

* @param showCompressDialog压缩时是否显示进度对话框

* @return

*/

TakePhoto onEnableCompress(CompressConfig config,boolean showCompressDialog);

Usage:

[代码]java代码:1getTakePhoto().onEnableCompress(compressConfig,true).onPickFromGalleryWithCrop(imageUri,cropOptions);

如果你启用了图片压缩,TakePhoto会使用CompressImage对图片进行压缩处理,CompressImage目前支持对图片的尺寸以及图片的质量进行压缩。默认情况下,CompressImage开启了尺寸与质量双重压缩。

对指定图片进行压缩

另外,你也可以对指定图片进行压缩:

Usage:

[代码]java代码:01

02

03

04

05

06

07

08

09

10new 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对图片压缩后的尺寸以及质量进行相关设置。如果你想改变压缩的方式可以通过CompressConfig.Builder进行相关设置。

Usage:

[代码]java代码:1

2CompressConfig compressConfig=new CompressConfig.Builder().setMaxSize(50*1024).setMaxPixel(800).create();

getTakePhoto().onEnableCompress(compressConfig,true).onPickFromGallery();

兼容性

TakePhoto在深度兼容性方面的测试获取更高的兼容性

TakePhoto是基于Android官方标准API编写的,适配了目前市场上主流的Rom。如果你在使用过程中发现了适配问题,可以提交Issues。

1. 为适配部分手机拍照时会回收Activity,TakePhoto在onSaveInstanceState与 onCreate做了相应的恢复处理。

2. 为适配部分手机拍照或从相册选择图片时屏幕方向会发生转变,从而导致拍照失败的问题,可以在AndroidManifest.xml中对使用了TakePhoto的Activity添加android:configChanges=”orientation|keyboardHidden|screenSize”配置。

eg:

[代码]xml代码:01

02

03

04

05

06

07

08

09

10

android:name=".MainActivity"

android:screenOrientation="portrait"

android:configChanges="orientation|keyboardHidden|screenSize"

android:label="@string/app_name" >

在项目中使用

为方便大家使用,现已将TakePhoto V2.0.0发布到JCenter(如果你对如何将项目发布到JCenter感兴趣可以参考:《教你轻松将Android library 发布到JCenter)》

Gradle:

[代码]xml代码:1compile 'com.jph.takephoto:takephoto_library:2.0.0'

Maven:

[代码]xml代码:1

2

3

4

5

6

com.jph.takephoto

takephoto_library

2.0.0

pom

最后

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值