欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

android實現圖片裁剪的兩種方法

 更新時間:2021年09月18日 10:59:27   作者:kcl5715305  
這篇文章主要為大家詳細介紹了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手勢識別

    深入理解Android手勢識別

    這篇文章主要幫助大家深入理解Android手勢識別,創(chuàng)建手勢偵聽對象,設置手勢識別,感興趣的小伙伴們可以參考一下
    2016-09-09
  • 一文帶你了解Android中的網絡請求

    一文帶你了解Android中的網絡請求

    安卓開發(fā)網絡請求可謂是安卓開發(fā)的靈魂,如果你不會網絡請求,那么你開發(fā)的應用軟件就是一具沒有靈魂的枯骨。本文主要為大家介紹的是Android的網絡請求,感興趣的可以跟隨小編一起學習一下
    2022-11-11
  • 利用kotlin實現一個打方塊的小游戲實例教程

    利用kotlin實現一個打方塊的小游戲實例教程

    最近在學習kotlin,利用其實現了一個小游戲,覺著有必要和大家分享下,所以下面這篇文章主要給大家介紹了關于利用kotlin實現一個打方塊的小游戲的相關資料,文中給出了詳細的示例代碼供大家參考學習,需要的朋友們下面隨著小編來一起學習學習吧。
    2017-12-12
  • Android保持屏幕常亮

    Android保持屏幕常亮

    本篇文章主要介紹了Android保持屏幕常亮,PowerManager.WakeLock的使用。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • Android中自定義View實現圓環(huán)等待及相關的音量調節(jié)效果

    Android中自定義View實現圓環(huán)等待及相關的音量調節(jié)效果

    這篇文章主要介紹了Android中自定義View實現圓環(huán)等待及相關的音量調節(jié)效果,邏輯非常簡單,或許繪圖方面更加繁瑣XD 需要的朋友可以參考下
    2016-04-04
  • Android編程解析XML文件的方法詳解【基于XmlPullParser】

    Android編程解析XML文件的方法詳解【基于XmlPullParser】

    這篇文章主要介紹了Android編程解析XML文件的方法,結合實例形式分析了Android基于XmlPullParser解析xml文件的相關操作技巧與注意事項,需要的朋友可以參考下
    2017-07-07
  • Android開發(fā)之手勢檢測及通過手勢實現翻頁功能的方法

    Android開發(fā)之手勢檢測及通過手勢實現翻頁功能的方法

    這篇文章主要介紹了Android開發(fā)之手勢檢測及通過手勢實現翻頁功能的方法,結合實例形式分析了Android GestureDetector類實現手勢檢測功能的相關操作技巧,需要的朋友可以參考下
    2017-09-09
  • Android10 啟動Zygote源碼解析

    Android10 啟動Zygote源碼解析

    這篇文章主要為大家介紹了Android 10 啟動分析之Zygote篇,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10
  • 詳解androidstudio項目上傳到github方法以及步驟

    詳解androidstudio項目上傳到github方法以及步驟

    在使用studio開發(fā)的項目過程中有時候我們想將項目發(fā)布到github上,studio其實是自帶這種功能的,那么如何使用呢,下面我們就一起來了解一下
    2019-01-01
  • Android自定義view仿IOS開關效果

    Android自定義view仿IOS開關效果

    這篇文章主要為大家詳細介紹了Android自定義view仿IOS開關效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06

最新評論