android實現圖片裁剪的兩種方法
兩種android圖片裁剪方式,供大家參考,具體內容如下
一、相機拍完照之后利用系統(tǒng)自帶裁剪工具進行截取
public static void cropImage(Activity activity, Uri srcUri) { cropImageUri = srcUri; Intent intent = new Intent("com.android.camera.action.CROP"); intent.setDataAndType(srcUri, "image/*"); intent.putExtra("crop", "true"); // 1.寬高和比例都不設置時,裁剪框可以自行調整(比例和大小都可以隨意調整) //////////////////////////////////////////////////////////////// // 2.只設置裁剪框寬高比(aspect)后,裁剪框比例固定不可調整,只能調整大小 //////////////////////////////////////////////////////////////// // 3.裁剪后生成圖片寬高(output)的設置和裁剪框無關,只決定最終生成圖片大小 //////////////////////////////////////////////////////////////// // 4.裁剪框寬高比例(aspect)可以和裁剪后生成圖片比例(output)不同,此時, // 會以裁剪框的寬為準,按照裁剪寬高比例生成一個圖片,該圖和框選部分可能不同, // 不同的情況可能是截取框選的一部分,也可能超出框選部分,向下延伸補足 //////////////////////////////////////////////////////////////// // aspectX aspectY 是裁剪框寬高的比例 // intent.putExtra("aspectX", 1); // intent.putExtra("aspectY", 1); // // outputX outputY 是裁剪后生成圖片的寬高 // intent.putExtra("outputX", 300); // intent.putExtra("outputY", 300); // return-data為true時,會直接返回bitmap數據,但是大圖裁剪時會出現問題,推薦下面為false時的方式 // return-data為false時,不會返回bitmap,但需要指定一個MediaStore.EXTRA_OUTPUT保存圖片uri intent.putExtra(MediaStore.EXTRA_OUTPUT, cropImageUri); intent.putExtra("return-data", false); activity.startActivityForResult(intent, CROP_IMAGE); }
這樣圖片可以通過手勢來自由裁剪
二、自定義相機拍照界面,裁剪固定區(qū)域的圖片
這里用到了一個叫idcardcamera的三方,在此向原作者致敬,附上項目引用地址 ‘com.github.wildma:IDCardCamera:1.0.0'
有幾個地方,需要修改一下,我是在相機中間加了一個長方形的框,代碼片段如下:
float screenMinSize = Math.min(getResources().getDisplayMetrics().widthPixels, getResources().getDisplayMetrics().heightPixels); //根據screenMinSize,計算出cameraPreview的較寬的一邊,長寬比為標準的16:9 float maxSize = screenMinSize / 9.0f * 16.0f; RelativeLayout.LayoutParams layoutParams = new RelativeLayout.LayoutParams((int) maxSize, (int) screenMinSize); layoutParams.addRule(RelativeLayout.CENTER_IN_PARENT); mCameraPreview.setLayoutParams(layoutParams); float height = (int) (screenMinSize * 0.3); float density = getResources().getDisplayMetrics().density; // 屏幕密度(0.75 / 1.0 / 1.5) float mywdith =(int) 136*density; int widthPixels = getResources().getDisplayMetrics().widthPixels; float width = (int) (widthPixels-mywdith);//75 47 LinearLayout.LayoutParams containerParams = new LinearLayout.LayoutParams((int) width, ViewGroup.LayoutParams.MATCH_PARENT); LinearLayout.LayoutParams cropParams = new LinearLayout.LayoutParams((int) width, (int) height); mLlCameraCropContainer.setLayoutParams(containerParams); mIvCameraCrop.setLayoutParams(cropParams);
修改了 mIvCameraCrop的大小,給這個長方形框添加一個背景邊框,剛開始老是顯示不出來右邊的邊框,后來發(fā)現,拍照按鈕父布局的寬度為136dp,用代碼計算出實際占用的px,然后設置長方形的合適寬度,這樣就遮擋不住了,右邊的邊框就能夠顯示出來了,附上拍照的邏輯,選擇自動剪裁
/** * 拍照 */ private void takePhoto() { mCameraPreview.setEnabled(false); mCameraPreview.takePhoto(new Camera.PictureCallback() { @Override public void onPictureTaken(final byte[] data, Camera camera) { // camera.stopPreview(); camera.startPreview(); //子線程處理圖片,防止ANR // setCropLayout(); new Thread(new Runnable() { @Override public void run() { bitmap = BitmapFactory.decodeByteArray(data, 0, data.length); String imagePath = path; ImageUtils.save(bitmap, imagePath, Bitmap.CompressFormat.JPEG); int rotation = getWindowManager().getDefaultDisplay().getRotation(); int angle = ImageUtils.getBitmapDegree(imagePath); if (mOrientation==90){ bitmap = ImageUtils.rotateBitmap(CameraActivity.this.bitmap, 180); } /** * 計算裁剪位置 */ float left, top, right, bottom; left = ((float) mLlCameraCropContainer.getLeft() - (float) mCameraPreview.getLeft()) / (float) mCameraPreview.getWidth(); top = (float) mIvCameraCrop.getTop() / (float) mCameraPreview.getHeight(); right = (float) mLlCameraCropContainer.getRight() / (float) mCameraPreview.getWidth(); bottom = (float) mIvCameraCrop.getBottom() / (float) mCameraPreview.getHeight(); /** * 自動裁剪 **/ mCropBitmap = Bitmap.createBitmap(bitmap, (int) (left * (float) bitmap.getWidth()), (int) (top * (float) bitmap.getHeight()), (int) ((right - left) * (float) bitmap.getWidth()), (int) ((bottom - top) * (float) bitmap.getHeight())); /** * 手動裁剪 **/ runOnUiThread(new Runnable() { @Override public void run() { //將裁剪區(qū)域設置成與掃描框一樣大 setCropLayout(); mCropImageView.setLayoutParams(new LinearLayout.LayoutParams(mIvCameraCrop.getWidth(), mIvCameraCrop.getHeight())); mCropImageView.setImageBitmap( mCropBitmap); } }); } }).start(); safeToTakePicture = true; } }); }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android中自定義View實現圓環(huán)等待及相關的音量調節(jié)效果
這篇文章主要介紹了Android中自定義View實現圓環(huán)等待及相關的音量調節(jié)效果,邏輯非常簡單,或許繪圖方面更加繁瑣XD 需要的朋友可以參考下2016-04-04Android編程解析XML文件的方法詳解【基于XmlPullParser】
這篇文章主要介紹了Android編程解析XML文件的方法,結合實例形式分析了Android基于XmlPullParser解析xml文件的相關操作技巧與注意事項,需要的朋友可以參考下2017-07-07Android開發(fā)之手勢檢測及通過手勢實現翻頁功能的方法
這篇文章主要介紹了Android開發(fā)之手勢檢測及通過手勢實現翻頁功能的方法,結合實例形式分析了Android GestureDetector類實現手勢檢測功能的相關操作技巧,需要的朋友可以參考下2017-09-09詳解androidstudio項目上傳到github方法以及步驟
在使用studio開發(fā)的項目過程中有時候我們想將項目發(fā)布到github上,studio其實是自帶這種功能的,那么如何使用呢,下面我們就一起來了解一下2019-01-01