`
iaiai
  • 浏览: 2198010 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

TakePhoto 简介

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

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

V3.0
  • 支持通过相机拍照获取图片
  • 支持从相册选择图片
  • 支持从文件选择图片
  • 支持批量图片选取
  • 支持图片压缩以及批量图片压缩
  • 支持图片裁切以及批量图片裁切
  • 支持照片旋转角度自动纠正
  • 支持自动权限管理(无需关心SD卡及摄像头权限等问题)
  • 支持对裁剪及压缩参数个性化配置
  • 提供自带裁剪工具(可选)
  • 支持智能选取及裁剪异常处理
  • 支持因拍照Activity被回收后的自动恢复
  • 支持Android7.0


GitHub地址: https://github.com/crazycodeboy/TakePhoto

目录
  • 安装说明
  • 演示
  • 使用说明
  • API
  • 贡献


安装说明

Gradle:
compile 'com.jph.takephoto:takephoto_library:3.0.0'


Maven:
<dependency>
  <groupId>com.jph.takephoto</groupId>
  <artifactId>takephoto_library</artifactId>
  <version>3.0.0</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;
 }


API

获取图片
TakePhoto提供拍照,从相册选择,从文件中选择三种方式获取图片。
/**
 * 从文件中获取图片(不裁剪)
 */
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自带的裁剪工具进行裁剪等,进行个性化配置。
 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自带的裁剪工具进行裁剪。

压缩图片

你可以选择是否对图片进行压缩处理,你只需要告诉它你是否要启用压缩功能以及CompressConfig即可。
 /**
  * 启用图片压缩
  * @param config 压缩图片配置
  * @param showCompressDialog 压缩时是否显示进度对话框
  * @return
  */
 void onEnableCompress(CompressConfig config,boolean showCompressDialog);


TakePhoto takePhoto=getTakePhoto();
takePhoto.onEnableCompress(compressConfig,true);
takePhoto.onPickFromGallery();


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

对指定图片进行压缩
另外,你也可以对指定图片进行压缩:
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进行相关设置。
CompressConfig compressConfig=new CompressConfig.Builder().setMaxSize(50*1024).setMaxPixel(800).create();


兼容性

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

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

<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贡献智慧,欢迎大家Fork and Pull requests

最后
既然来了,留下个喜欢再走吧,鼓励我继续创作(^_^)∠※
  • 大小: 577.5 KB
  • 大小: 461.9 KB
  • 大小: 183.5 KB
分享到:
评论

相关推荐

    takephoto拍照相册开源库更改为用androidx库v4.1.0版本实例演示

    本文将深入探讨如何将一个使用旧版依赖的拍照相册开源库——takephoto,更新到使用AndroidX库v4.1.0版本,并提供实例演示。 1. AndroidX库介绍 AndroidX库是Android Support Library的升级版,它提供了与Android...

    takephoto拍照相册开源库更改为用androidx库v4.1.0版本

    - `README.md` 文件通常包含项目简介、安装和使用指南,开发者应详细阅读以了解如何正确使用库。 5. **测试与调试**: 升级完成后,需要进行详尽的测试,确保所有功能在各个目标Android版本上都能正常运行,包括...

    android_takephoto.zip

    takephoto.jar的功能 :相机获取图片、相册获取图片、剪切、压缩等功能。 TakePhoto在作用上类似于FragmentManager,无论是拍照、裁剪、从相册中选取、压缩都需要调用TakePhoto的方法。

    Android-Android三方库--TakePhoto

    在Android应用开发中,"Android三方库--TakePhoto"是一个常用的工具库,它为开发者提供了简单易用的图片选择、裁剪和预览功能。这个库通常被用于那些需要处理用户上传图片或需要进行图像编辑的应用场景。在本文中,...

    TakePhoto.jar

    《TakePhoto.jar——Java应用程序的打包与运行》 在Java编程世界中,程序的打包与分发是一项重要的工作。TakePhoto.jar就是一个典型的Java应用程序的可执行文件,它将所有的类文件、资源文件以及必要的元数据打包在...

    android takephoto

    本篇文章将深入探讨如何在Android中实现"takephoto"功能,帮助开发者们理解并掌握这一重要技能。 首先,我们需要了解Android中的相机权限。在AndroidManifest.xml文件中,必须声明`&lt;uses-permission&gt;`标签来请求...

    TakePhoto 图片选择器

    "TakePhoto 图片选择器" 是一个专门为移动应用开发者设计的图片选择工具,它使得在Android或iOS平台上集成图片选择功能变得简单易行。这个工具提供了丰富的参数配置选项,允许开发者根据自己的需求定制图片选择流程...

    TakePhoto.zip

    "TakePhoto.zip"这个压缩包文件很可能包含了一个示例项目或者代码库,用于演示如何在Android应用中实现这一功能。下面我们将详细探讨相关的Android开发知识点。 1. **启动相机应用** Android系统提供了`Intent`...

    一个精美的照相控件takephoto.ocx(补充)

    Takephoto.ocx照相控件是专门为开发带照相功能软件而设计的。Takephoto.ocx是一个功能完备、操作简单的ActiveX控件。该控件的主要功能是利用摄像头或其它照相设备,进行拍照。它集启动摄像头、照相定位、相片大小...

    一个精美的照相控件takephoto.ocx(http://download.csdn.net/source/558594有更新的)

    Takephoto.ocx照相控件是专门为开发带照相功能软件而设计的。 Takephoto.ocx是一个功能完备、操作简单的ActiveX控件。该控件的主要功能是利用摄像头或其它照相设备,进行拍照。它集启动摄像头、照相定位、相片大小...

    TakePhoto第三方的图片选择器

    "TakePhoto第三方的图片选择器"是一个专门为Android应用设计的图片选择工具库,它简化了在应用程序中集成图片选择、裁剪和预览等功能的过程。这个库提供了丰富的自定义选项,使得开发者可以按照自己的需求定制图片...

    TakePhoto-master.zip

    【标题】"TakePhoto-master.zip" 是一个与图像拍摄相关的项目压缩包,很可能包含一个用于在Android或iOS平台上实现拍照功能的应用程序源代码。"TakePhoto-master" 可能是项目仓库的主分支或者主要版本,暗示着这个...

    安卓takephoto v4.1.0修改存储代码验证可用的拍照相册选择库20201025.zip

    【安卓takephoto v4.1.0修改存储代码验证可用的拍照相册选择库】是一个专为Android平台设计的开源库,它允许开发者方便地集成拍照、从相册选取图片以及裁剪图片等功能。这个库在2020年10月25日更新到了v4.1.0版本,...

    安卓照相机TakePhoto.zip

    从提供的标题"安卓照相机TakePhoto.zip"和描述来看,这个压缩包文件应该包含了一个完整的Android Studio项目,用于实现一个解决常见问题(如按钮闪退、存储问题以及速度优化)的照相应用程序。以下是对这些知识点的...

    TakePhoto-master.rar

    "TakePhoto-master.rar" 是一个压缩包文件,包含了一个名为 "TakePhoto-master" 的项目,该项目专注于在安卓(Android)平台上实现拍照功能。这个源码示例为开发者提供了如何在自己的应用中集成拍照功能的详细指导。...

    相机TakePhoto

    在iOS开发中,"相机TakePhoto"涉及到的主要知识点是如何在应用程序中集成并使用相机功能,让用户能够拍照并可能地访问手机相册。以下是对这些功能的详细解释: 1. **AVFoundation框架**:在iOS中,AVFoundation框架...

    TakePhoto:APP拍照&相册选择工具

    引入TakePhoto到您的项目 引入方法: Maven: &lt;groupId&gt;com.kongzue.takephoto&lt;/groupId&gt; &lt;artifactId&gt;takephoto &lt;version&gt;2.0.1 &lt;type&gt;pom Gradle: implementation 'com.kongzue.takephoto:takephoto:2.0.1'...

    选择图片拍照设置图片获取图片路径源码支持Android6.0以上TakePhoto

    "选择图片拍照设置图片获取图片路径源码支持Android6.0以上TakePhoto"是一个针对Android 6.0及以上版本的图片操作库,它提供了方便的API来帮助开发者实现这些功能。这个库的使用可以帮助开发者避免在兼容不同Android...

    人工智能人脸识别_python-AI-takephoto.zip

    人工智能人脸识别_python-AI-takephoto

    takephoto.zip

    在React开发中,调用设备摄像头并实现..."takephoto.zip"中的代码应该包含了实现这一功能的完整流程,包括上述提到的各个部分。通过深入研究和理解这些代码,开发者可以学习到如何在自己的React项目中实现类似的功能。

Global site tag (gtag.js) - Google Analytics