takephoto 框架_GitHub - Smecking/TakePhoto: 一款用于在Android设备上获取照片(拍照或从相册、文件中选择)、裁剪图片、压缩图片的开源工具库...

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

3.0以下版本及API说明,详见TakePhoto2.0+。

TakePhoto交流平台:QQ群:556387607(群1,未满)

V4.0

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

支持从相册选择图片

支持从文件选择图片

支持批量图片选取

支持图片压缩以及批量图片压缩

支持图片裁切以及批量图片裁切

支持照片旋转角度自动纠正

支持自动权限管理(无需关心SD卡及摄像头权限等问题)

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

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

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

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

支持Android7.0

+支持多种压缩工具

+支持多种图片选择工具

目录

安装说明

Gradle:

compile 'com.jph.takephoto:takephoto_library:4.0.2'

Maven:

com.jph.takephoto

takephoto_library

4.0.2

pom

演示

运行效果图:

使用说明

使用TakePhoto有以下两种方式:

方式一:通过继承的方式

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

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

重写以下方法获取结果

void takeSuccess(TResult result);

void takeFail(TResult result,String msg);

void takeCancel();

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

方式二:通过组装的方式

1.实现TakePhoto.TakeResultListener,InvokeListener接口。

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

3.重写onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults),添加如下代码。

@Override

public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) {

super.onRequestPermissionsResult(requestCode, permissions, grantResults);

//以下代码为处理Android6.0、7.0动态权限所需

TPermissionType type=PermissionManager.onRequestPermissionsResult(requestCode,permissions,grantResults);

PermissionManager.handlePermissionsResult(this,type,invokeParam,this);

}

4.重写TPermissionType invoke(InvokeParam invokeParam)方法,添加如下代码:

@Override

public TPermissionType invoke(InvokeParam invokeParam) {

TPermissionType type=PermissionManager.checkPermission(TContextWrap.of(this),invokeParam.getMethod());

if(TPermissionType.WAIT.equals(type)){

this.invokeParam=invokeParam;

}

return type;

}

5.添加如下代码获取TakePhoto实例:

/**

* 获取TakePhoto实例

* @return

*/

public TakePhoto getTakePhoto(){

if (takePhoto==null){

takePhoto= (TakePhoto) TakePhotoInvocationHandler.of(this).bind(new TakePhotoImpl(this,this));

}

return takePhoto;

}

自定义UI

TakePhoto不仅支持对相关参数的自定义,也支持对UI的自定义,下面就像大家介绍如何自定义TakePhoto的相册与裁剪工具的UI。

自定义相册

如果TakePhoto自带相册的UI不符合你应用的主题的话,你可以对它进行自定义。方法如下:

自定义Toolbar

在“res/layout”目录中创建一个名为“toolbar.xml”的布局文件,内容如下:

xmlns:app="http://schemas.android.com/apk/res-auto"

android:layout_width="match_parent"

android:layout_height="?attr/actionBarSize"

app:theme="@style/CustomToolbarTheme"

android:background="#ffa352">

在“toolbar.xml”文件中你可以指定TakePhoto自带相册的主题以及Toolbar的背景色。

自定义状态栏

在“res/values”目录中创建一个名为“colors.xml”的资源文件,内容如下:

#212121

通过上述方式便可以自定义状态栏的颜色。

自定义提示文字

在“res/values”目录的“string.xml”文件冲添加如下代码:

选择图片

单击选择

确定

已选

最多能选 %d 张

重写上述代码,便可以自定义TakePhoto自带相册的提示文字。

自定义裁切工具

在“res/layout”目录中创建一个名为“crop__activity_crop.xml”与“crop__layout_done_cancel.xml”的布局文件,内容如下:

crop__activity_crop.xml

xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/crop_image"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_alignParentTop="true"

android:background="@drawable/crop__texture"

android:layout_above="@+id/done_cancel_bar" />

android:id="@+id/done_cancel_bar"

android:layout_alignParentBottom="true"

layout="@layout/crop__layout_done_cancel"

android:layout_height="50dp"

android:layout_width="match_parent" />

crop__layout_done_cancel.xml

style="@style/Crop.DoneCancelBar">

android:id="@+id/btn_cancel"

style="@style/Crop.ActionButton">

android:id="@+id/btn_done"

style="@style/Crop.ActionButton">

重写上述代码,便可以自定义TakePhoto裁切工具的UI。

API

获取图片

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

API:

/**

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

*/

void onPickFromDocuments();

/**

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

*/

void onPickFromGallery();

/**

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

* @param outPutUri 图片保存的路径

*/

void onPickFromCapture(Uri outPutUri);

/**

* 图片多选

* @param limit 最多选择图片张数的限制

**/

void onPickMultiple(int limit);

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

注:

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

裁剪图片

API

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

/**

* 从相机获取图片并裁剪

* @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);

/**

* 图片多选,并裁切

* @param limit 最多选择图片张数的限制

* @param options 裁剪配置

* */

void onPickMultipleWithCrop(int limit, CropOptions options);

对指定图片进行裁剪

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

/**

* 裁剪图片

* @param imageUri 要裁剪的图片

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

* @param options 裁剪配置

*/

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

/**

* 裁剪多张图片

* @param multipleCrop 要裁切的图片的路径以及输出路径

* @param options 裁剪配置

*/

void onCrop(MultipleCrop multipleCrop, CropOptions options)throws TException;

CropOptions

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

Usage:

CropOptions 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自带的裁剪工具进行裁剪。

另外TakePhoto4.0+支持指定使用TakePhoto自带相册,如:takePhoto.setTakePhotoOptions(new TakePhotoOptions.Builder().setWithOwnGallery(true).create());

详情可参考:Demo

压缩图片

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

API

/**

* 启用图片压缩

* @param config 压缩图片配置

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

* @return

*/

void onEnableCompress(CompressConfig config,boolean showCompressDialog);

Usage:

TakePhoto takePhoto=getTakePhoto();

takePhoto.onEnableCompress(compressConfig,true);

takePhoto.onPickFromGallery();

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

对指定图片进行压缩

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

Usage:

new CompressImageImpl(compressConfig,result.getImages(), new CompressImage.CompressListener() {

@Override

public void onCompressSuccess(ArrayList images) {

//图片压缩成功

}

@Override

public void onCompressFailed(ArrayList images, String msg) {

//图片压缩失败

}

}).compress();

CompressConfig

CompressConfig是用于图片压缩的配置类,你可以通过CompressConfig.Builder对图片压缩后的尺寸以及质量进行相关设置。如果你想改变压缩的方式可以通过CompressConfig.Builder进行相关设置。

Usage:

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

指定压缩工具

使用TakePhoto压缩工具进行压缩:

CompressConfig config=new CompressConfig.Builder()

.setMaxSize(maxSize)

.setMaxPixel(width>=height? width:height)

.create();

takePhoto.onEnableCompress(config,showProgressBar);

使用Luban进行压缩:

LubanOptions option=new LubanOptions.Builder()

.setGear(Luban.CUSTOM_GEAR)

.setMaxHeight(height)

.setMaxWidth(width)

.setMaxSize(maxSize)

.create();

CompressConfig config=CompressConfig.ofLuban(option);

takePhoto.onEnableCompress(config,showProgressBar);

兼容性

Android6.0

由于Android6.0新增了"运行时权限控制(Runtime Permissions)",为了应对这一改变,TakePhoto加入和自动权限管理,当TakePhoto检测到需要权限时,TakePhoto会自动申请权限,所以小伙伴们不用担心权限的使用问题。

Android7.0

在Android N中,Android 框架执行了 StrictMode,应用间共享文件和以前也有所区别。为了适配Android7.0的改变,同时也为了方便大家使用TakePhoto,TakePhoto会自动根据手机的Android版本自行适配,小伙伴们依旧可以向TakePhoto传递Uri imageUri = Uri.fromFile(file);类型的Uri而不用担心兼容性问题。

TakePhoto在深度兼容性方面的测试

获取更高的兼容性

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

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

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

eg:

android:name=".MainActivity"

android:screenOrientation="portrait"

android:configChanges="orientation|keyboardHidden|screenSize"

android:label="@string/app_name" >

贡献

如果你在使用TakePhoto中遇到任何问题可以提Issues出来。另外欢迎大家为TakePhoto贡献智慧,欢迎大家Fork and Pull requests。

更新说明

2016/11/28

压缩成功后返回原图路径(originalPath), 以便用户可以自行处理原图。

压缩成功后压缩路径path改为compressPath。

压缩成功后返回图片来源类型,现在分CAMERA, OTHER两种。

用户可以配置CompressConfig.enableReserveRaw(boolean)方法,ture保留原图,false删除原图,当且仅当类型为CAMERA此配置才有效

纠正拍照旋转角度功能改为可选

最后

关于代码混淆

如果你的项目中启用了代码混淆,可在混淆规则文件(如:proguard-rules.pro)中添加如下代码:

-keep class com.jph.takephoto.** { *; }

-dontwarn com.jph.takephoto.**

-keep class com.darsh.multipleimageselect.** { *; }

-dontwarn com.darsh.multipleimageselect.**

-keep class com.soundcloud.android.crop.** { *; }

-dontwarn com.soundcloud.android.crop.**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值