在一个应用中更换用户的头像,一般有拍照和从图库中选择照片两种方法,现在网上也有很多开源的,但是很多都太复杂。而 android-crop 这个库比较小,代码不复杂,比较适合,但是它没有拍照这个功能,需要我们自己整合进去。
调用系统相机拍照
1、返回略缩图的拍照
// 调用系统的拍照 private voID dispatchTakePictureIntent() { Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); if (takePictureIntent.resolveActivity(getPackageManager()) != null) { startActivityForResult(takePictureIntent,REQUEST_IMAGE_CAPTURE); } }
重写 onActivityResult 方法,系统相机会返回略缩图
@OverrIDeprotected voID onActivityResult(int requestCode,int resultCode,Intent data) { if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == RESulT_OK) { Bundle extras = data.getExtras(); Bitmap imageBitmap = (Bitmap) extras.get("data"); mImageVIEw.setimageBitmap(imageBitmap); }}
1.返回全图片
. 如果是全图片,一般都是存在手机的外部存储空间,这个时候需要读写外部的权限
<uses-permission androID:name="androID.permission.WRITE_EXTERNAL_STORAGE" androID:maxsdkVersion="18"/><uses-permission androID:name="androID.permission.READ_EXTERNAL_STORAGE"/>
在4.4 及其以上不需要 WRTE_EXTERNAL_STORAGE 权限,所以,我们添加了 AndroID: maxsdkVersion = “18”
. 因为是全图片,图片一般都会很大,我们不能再像上面一样全部数据返回,不然很容易就出现 OOM,所以,启动拍照的时候设置一个指定路径保存图片,拍照成功之后就可以直接使用这个路径了
// 图片路径 private Uri mCurrentPhotoUri;// 拍照private voID dispatchTakePictureIntent() { Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); if (takePictureIntent.resolveActivity(mContext.getPackageManager()) != null) { file photofile = null; try { photofile = createImagefile(); } catch (IOException e) { e.printstacktrace(); } if (photofile != null){ Uri photoUri = fileProvIDer.getUriForfile(mContext,"com.yxhuang.fileprovIDer",photofile); takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT,photoUri); mCurrentPhotoUri = photoUri; startActivityForResult(takePictureIntent,REQUEST_IMAGE_CAPTURE); } } } // 创建图片路径 private file createImagefile() throws IOException { String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date()); String imagefilename = "JPEG_" + timeStamp + "_"; file storageDir = mContext.getExternalfilesDir(Environment.DIRECTORY_PICTURES); file image = file.createTempfile( imagefilename,/* prefix */ ".jpg",/* suffix */ storageDir /* directory */ ); return image; }
在创建图片 uri 的时候,使用了 fileProvIDer,fileProvIDer 只是 ContentProvIDer 的一个子类。用于方便文件的共享。
fileProvIDer 需要一些配置
在 Manifext.xml 中在节点下
<!--自定义URI 需要 provIDer --><provIDer androID:name="androID.support.v4.content.fileProvIDer" androID:authoritIEs="com.yxhuang.fileprovIDer" androID:exported="false" androID:grantUriPermissions="true"> <Meta-data androID:name="androID.support.file_PROVIDER_PATHS" androID:resource="@xml/file_paths"> </Meta-data> </provIDer>
其中 authoritIEs 的内容要与 fileProvIDer.getUriForfile()方法中的第二个参数相同。
同时也要对androID:resource 进行配置
res/xml/file_paths.xml
<?xml version="1.0" enCoding="utf-8"?><paths xmlns:androID="http://schemas.androID.com/apk/res/androID"> <external-path name="image_file" path="AndroID/data/com.yxhuang/files/Pictures"/></paths>
使用 android-crop 开源库裁剪图片
android-crop 是一个比较简单的图片裁剪库。具体使用看 GitHub 的 Demo. 我们这里结合拍照一起使用。
上面我们已经准备好拍照了,我们需要在 onActivityForResult() 方法中进行处理
@OverrIDe public voID onActivityResult(int requestCode,Intent data) { // 拍照返回 if (resultCode == RESulT_OK){ if (requestCode == REQUEST_IMAGE_CAPTURE){ beginCrop(mCurrentPhotoUri); } else if (requestCode == Crop.REQUEST_PICK){ beginCrop(data.getData()); } } // 裁剪 if (requestCode == Crop.REQUEST_CROP){ handleCrop(resultCode,data); } }// 开始裁剪private voID beginCrop(Uri source){ Uri destination = Uri.fromfile(new file(mContext.getCacheDir(),"cropped")); // start() 方法根据其的需求选择不同的重载方法 Crop.of(source,destination).asSquare().start(getActivity(),mineFragment.this); }// 将裁剪回来的数据进行处理 private voID handleCrop(int resultCode,Intent result){ if (resultCode == RESulT_OK){ mImageVIEw.setimageURI(Crop.getoutput(result)); } else if (resultCode == Crop.RESulT_ERROR){ Toast.makeText(mContext,Crop.getError(result).getMessage(),Toast.LENGTH_SHORT).show(); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的android系统拍照结合android-crop裁剪图片全部内容,希望文章能够帮你解决android系统拍照结合android-crop裁剪图片所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)