在一個應用中更換用戶的頭像,一般有拍照和從圖庫中選擇照片兩種方法,現在網上也有很多開源的,但是很多都太復雜。而 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, int resultCode, 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(); } }以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答