android实现图片裁剪的两种方法

 更新时间:2021年09月18日 10:59:27   作者:kcl5715305  
这篇文章主要为大家详细介绍了android实现图片裁剪的两种方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

两种android图片裁剪方式,供大家参考,具体内容如下

一、相机拍完照之后利用系统自带裁剪工具进行截取

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);

}

这样图片可以通过手势来自由裁剪

二、自定义相机拍照界面,裁剪固定区域的图片

这里用到了一个叫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的大小,给这个长方形框添加一个背景边框,刚开始老是显示不出来右边的边框,后来发现,拍照按钮父布局的宽度为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() {
                                //将裁剪区域设置成与扫描框一样大
                                setCropLayout();
                                mCropImageView.setLayoutParams(new LinearLayout.LayoutParams(mIvCameraCrop.getWidth(), mIvCameraCrop.getHeight()));
                                mCropImageView.setImageBitmap( mCropBitmap);
                            }
                        });
                    }
                }).start();
                safeToTakePicture = true;
            }
        });
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 深入理解Android手势识别

    深入理解Android手势识别

    这篇文章主要帮助大家深入理解Android手势识别,创建手势侦听对象,设置手势识别,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 一文带你了解Android中的网络请求

    一文带你了解Android中的网络请求

    安卓开发网络请求可谓是安卓开发的灵魂,如果你不会网络请求,那么你开发的应用软件就是一具没有灵魂的枯骨。本文主要为大家介绍的是Android的网络请求,感兴趣的可以跟随小编一起学习一下
    2022-11-11
  • 利用kotlin实现一个打方块的小游戏实例教程

    利用kotlin实现一个打方块的小游戏实例教程

    最近在学习kotlin,利用其实现了一个小游戏,觉着有必要和大家分享下,所以下面这篇文章主要给大家介绍了关于利用kotlin实现一个打方块的小游戏的相关资料,文中给出了详细的示例代码供大家参考学习,需要的朋友们下面随着小编来一起学习学习吧。
    2017-12-12
  • Android保持屏幕常亮

    Android保持屏幕常亮

    本篇文章主要介绍了Android保持屏幕常亮,PowerManager.WakeLock的使用。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • Android中自定义View实现圆环等待及相关的音量调节效果

    Android中自定义View实现圆环等待及相关的音量调节效果

    这篇文章主要介绍了Android中自定义View实现圆环等待及相关的音量调节效果,逻辑非常简单,或许绘图方面更加繁琐XD 需要的朋友可以参考下
    2016-04-04
  • Android编程解析XML文件的方法详解【基于XmlPullParser】

    Android编程解析XML文件的方法详解【基于XmlPullParser】

    这篇文章主要介绍了Android编程解析XML文件的方法,结合实例形式分析了Android基于XmlPullParser解析xml文件的相关操作技巧与注意事项,需要的朋友可以参考下
    2017-07-07
  • Android开发之手势检测及通过手势实现翻页功能的方法

    Android开发之手势检测及通过手势实现翻页功能的方法

    这篇文章主要介绍了Android开发之手势检测及通过手势实现翻页功能的方法,结合实例形式分析了Android GestureDetector类实现手势检测功能的相关操作技巧,需要的朋友可以参考下
    2017-09-09
  • Android10 启动Zygote源码解析

    Android10 启动Zygote源码解析

    这篇文章主要为大家介绍了Android 10 启动分析之Zygote篇,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 详解androidstudio项目上传到github方法以及步骤

    详解androidstudio项目上传到github方法以及步骤

    在使用studio开发的项目过程中有时候我们想将项目发布到github上,studio其实是自带这种功能的,那么如何使用呢,下面我们就一起来了解一下
    2019-01-01
  • Android自定义view仿IOS开关效果

    Android自定义view仿IOS开关效果

    这篇文章主要为大家详细介绍了Android自定义view仿IOS开关效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-06-06

最新评论