android系統(tǒng)拍照結(jié)合android-crop裁剪圖片
在一個應(yīng)用中更換用戶的頭像,一般有拍照和從圖庫中選擇照片兩種方法,現(xiàn)在網(wǎng)上也有很多開源的,但是很多都太復雜。而 Android-crop 這個庫比較小,代碼不復雜,比較適合,但是它沒有拍照這個功能,需要我們自己整合進去。
調(diào)用系統(tǒng)相機拍照
1、返回略縮圖的拍照
// 調(diào)用系統(tǒng)的拍照
private void dispatchTakePictureIntent() {
Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE);
}
}
重寫 onActivityResult 方法,系統(tǒng)相機會返回略縮圖
@Override
protected 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.返回全圖片
. 如果是全圖片,一般都是存在手機的外部存儲空間,這個時候需要讀寫外部的權(quán)限
<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 權(quán)限,所以,我們添加了 Android: maxSdkVersion = “18”
. 因為是全圖片,圖片一般都會很大,我們不能再像上面一樣全部數(shù)據(jù)返回,不然很容易就出現(xiàn) OOM , 所以,啟動拍照的時候設(shè)置一個指定路徑保存圖片,拍照成功之后就可以直接使用這個路徑了
// 圖片路徑
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);
}
}
}
// 創(chuàng)建圖片路徑
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;
}
在創(chuàng)建圖片 uri 的時候,使用了 FileProvider, FileProvider 只是 ContentProvider 的一個子類。用于方便文件的共享。
FileProvider 需要一些配置
在 Manifext.xml 中在節(jié)點下
<!--自定義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 的內(nèi)容要與 FileProvider.getUriForFile()方法中的第二個參數(shù)相同。
同時也要對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. 我們這里結(jié)合拍照一起使用。
上面我們已經(jīng)準備好拍照了,我們需要在 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() 方法根據(jù)其的需求選擇不同的重載方法
Crop.of(source, destination).asSquare().start(getActivity(), MineFragment.this);
}
// 將裁剪回來的數(shù)據(jù)進行處理
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();
}
}
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android實現(xiàn)長按圓環(huán)動畫View效果的思路代碼
這篇文章主要介紹了Android實現(xiàn)長按圓環(huán)動畫View效果,本文給大家分享實現(xiàn)思路,通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
Android利用CircleImageView實現(xiàn)圓形頭像的方法
這篇文章主要介紹了Android利用CircleImageView實現(xiàn)圓形頭像的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10
一文教你如何使用Databinding寫一個關(guān)注功能
這篇文章主要介紹了一文教你如何使用Databinding寫一個關(guān)注功能,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09
Android實現(xiàn)ViewPager無限循環(huán)效果(二)
這篇文章主要為大家詳細介紹了Android實現(xiàn)ViewPager無限循環(huán)效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-05-05
Android ReboundScrollView仿IOS拖拽回彈效果
這篇文章主要為大家詳細介紹了Android ReboundScrollView仿IOS拖拽回彈效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11
Android開發(fā)之獲取網(wǎng)絡(luò)鏈接狀態(tài)
這篇文章主要介紹了Android獲取網(wǎng)絡(luò)鏈接狀態(tài)的方法,主要是通過ConnectivityManager類來完成的,需要的朋友可以參考下2014-08-08

