一款用于在Android设备上获取照片(拍照或从相册、文件中选择)、裁剪图片、压缩图片的开源工具库
2017-06-13 13:39
1251 查看
TakePhoto 简介
TakePhoto是一款用于在Android设备上获取照片(拍照或从相册、文件中选择)、裁剪图片、压缩图片的开源工具库,目前最新版本4.0.3。
3.0以下版本及API说明,详见TakePhoto2.0+。
TakePhoto交流平台:QQ群:556387607(群1,未满)
V4.0
支持通过相机拍照获取图片
支持从相册选择图片
支持从文件选择图片
支持批量图片选取
支持图片压缩以及批量图片压缩
支持图片裁切以及批量图片裁切
支持照片旋转角度自动纠正
支持自动权限管理(无需关心SD卡及摄像头权限等问题)
支持对裁剪及压缩参数个性化配置
提供自带裁剪工具(可选)
支持智能选取及裁剪异常处理
支持因拍照Activity被回收后的自动恢复
支持Android7.0
+支持多种压缩工具
+支持多种图片选择工具
GitHub地址: https://github.com/crazycodeboy/TakePhoto
目录
安装说明演示
使用说明
自定义UI
API
兼容性
贡献
更新说明
最后
安装说明
Gradle:compile 'com.jph.takephoto:takephoto_library:4.0.3'
Maven:
<dependency> <groupId>com.jph.takephoto</groupId> <artifactId>takephoto_library</artifactId> <version>4.0.3</version> <type>pom</type> </dependency>
演示
运行效果图:
使用说明
使用TakePhoto有以下两种方式:
方式一:通过继承的方式继承
TakePhotoActivity、
TakePhotoFragmentActivity、
TakePhotoFragment三者之一。
通过
getTakePhoto()获取
TakePhoto实例进行相关操作。
重写以下方法获取结果
void takeSuccess(TResult result); void takeFail(TResult result,String msg); void takeCancel();
此方式使用简单,满足的大部分的使用需求,具体使用详见simple。如果通过继承的方式无法满足实际项目的使用,可以通过下面介绍的方式。
方式二:通过组装的方式
可参照:TakePhotoActivity,以下为主要步骤:
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”的布局文件,内容如下:<?xml version="1.0" encoding="utf-8"?> <android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android" 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"> </android.support.v7.widget.Toolbar>
在“toolbar.xml”文件中你可以指定TakePhoto自带相册的主题以及Toolbar的背景色。
自定义状态栏
在“res/values”目录中创建一个名为“colors.xml”的资源文件,内容如下:<?xml version="1.0" encoding="utf-8"?> <resources> <color name="multiple_image_select_primaryDark">#212121</color> </resources>
通过上述方式便可以自定义状态栏的颜色。
自定义提示文字
在“res/values”目录的“string.xml”文件冲添加如下代码:<resources> <string name="album_view">选择图片</string> <string name="image_view">单击选择</string> <string name="add">确定</string> <string name="selected">已选</string> <string name="limit_exceeded">最多能选 %d 张</string> </resources>
重写上述代码,便可以自定义TakePhoto自带相册的提示文字。
自定义裁切工具
在“res/layout”目录中创建一个名为“crop__activity_crop.xml”与“crop__layout_done_cancel.xml”的布局文件,内容如下:crop__activity_crop.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <com.soundcloud.android.crop.CropImageView 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" /> <include 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" /> </RelativeLayout>
crop__layout_done_cancel.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" style="@style/Crop.DoneCancelBar"> <FrameLayout android:id="@+id/btn_cancel" style="@style/Crop.ActionButton"> <TextView style="@style/Crop.ActionButtonText.Cancel" /> </FrameLayout> <FrameLayout android:id="@+id/btn_done" style="@style/Crop.ActionButton"> <TextView style="@style/Crop.ActionButtonText.Done" /> </FrameLayout> </LinearLayout>
重写上述代码,便可以自定义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<TImage> images) { //图片压缩成功 } @Override public void onCompressFailed(ArrayList<TImage> 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);
详情可参考Demo:CustomHelper.java
兼容性
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:
<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>
贡献
如果你在使用TakePhoto中遇到任何问题可以提Issues出来。另外欢迎大家为TakePhoto贡献智慧,欢迎大家Forkand Pull requests。
更新说明
v4.0.3(2017/1/18)
BugfixesFixed bug and add new features(
62a6725)-@Yanqilong
fix 鲁班压缩出现路径重复(
a0a64a59)-@namezhouyu
v4.0.2(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.**
Contact GitHub
API
Training
Shop
Blog
About
© 2017 GitHub, Inc.
Terms
Privacy
Security
Status
Help
相关文章推荐
- TakePhoto是一款用于在Android设备上获取照片(拍照或从相册、文件中选择)、裁剪图片、压缩图片的开源工具库,目前最新版本3.0.0。
- Android中相机拍摄照片,以及相册选择图片压缩上传(压缩后保存进SD中)(可用于修改头像等)
- Android 相册选择照片或拍照获取图片系统6.0及7.0实现
- Android-->拍照/相册选择照片(从Uri中获取图片路径)
- Android设备上获取照片、裁剪图片、压缩图片
- 在 Android 设备上获取照片、裁剪图片、压缩图片 @TakePhoto V3.0 发布
- Android实现类似QQ头像点击打开相册或者拍照,并获取裁剪后的图片
- android客户端学习-拍照或从相册选择图片并裁剪
- Android 拍照/相册 选择图片工具
- Android实现拍照、选择相册图片并裁剪功能
- android 图片压缩,自动旋转保存,查看照片信息,拍照设备类型等
- Android拍照或相册获取照片上传 (带图片剪裁)
- Android 拍照(获取原图),选择照片并且剪切图片
- android:通过选择相册或者拍照获取照片
- Android 图片压缩、照片选择、裁剪,上传、一整套图片解决方案
- android选择图片拍照详解(裁剪-旋转-压缩)
- Android开发之获取相册照片和获取拍照照片三之 图片旋转
- Android大图片裁剪之手机拍照和从相册中选择注意点
- Android图片裁剪(拍照和从相册选择)