Android   发布时间:2022-04-28  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

Android Bitmap 相关操作

 

Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移

Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移

 Android系列

 

常见的几个操作:缩放,裁剪,旋转,偏移

Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移

 

Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移

 

Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移

 

Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移

 

Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移

很多操作需要 Matrix 来支持;Matrix 通过矩阵来处理位图,计算出各个像素点的位置,从而把bitmap显示出来。 @H_680_50@matrix里有一个3x3的矩阵,用于图像处理:

@H_906_54@mSCALE_X MSKEW_X  MTRANS_X
MSKEW_Y  MSCALE_Y MTRANS_Y
MPERSP_0 MPERSP_1 MPERSP_2

根据变量名能猜出具体的用途:
缩放X 偏移X 平移X
偏移Y 缩放Y 平移Y
透视0 透视1 透视2

@H_277_0@matrix的操作有set,pre和post;set能够直接设置矩阵中的数值;pre类似于矩阵左乘;post类似与矩阵中的右乘

原bitmap经过计算后,会重新生成一张bitmap

代码片段:

    /**
     * 根据给定的宽和高进行拉伸
     *
     * @param origin    原图
     *  newWidth  新图的宽
     *  newHeight 新图的高
     * @return new Bitmap
     */
    private Bitmap scaleBitmap(Bitmap origin,int newWidth,1)">int newHeight) {
        if (origin == null) {
            return ;
        }
        int height = origin.getHeight();
        int width = origin.getWidth();
        float scaleWidth = ((float) newWidth) / width;
        float scaleHeight = ((float) newHeight) / height;
        Matrix matrix = new Matrix();
        matrix.postScale(scaleWidth,scaleHeight);// 使用后乘
        Bitmap newBM = Bitmap.createBitmap(origin,width,height,matrix,1)">false);
        if (!origin.isRecycled()) {
            origin.recycle();
        }
        return newBM;
    }

    
     * 按比例缩放图片
     *
     *  origin 原图
     *  ratio  比例
     *  新的bitmap
     float ratio) {
         origin.getHeight();
        Matrix matrix =  Matrix();
        matrix.preScale(ratio,ratio);
        Bitmap newBM = Bitmap.createBitmap(origin,1)">if (newBm.equals(origin)) {
             newBM;
        }
        origin.recycle();
        
     * 裁剪
     *
     *  bitmap 原图
     *  裁剪后的图像
     private Bitmap cropBitmap(Bitmap bitmap) {
        int w = bitmap.getWidth();  得到图片的宽,高
        int h = bitmap.getHeight();
        int cropWidth = w >= h ? h : w; 裁切后所取的正方形区域边长
        cropWidth /= 2;
        int cropHeight = (int) (cropWidth / 1.2return Bitmap.createBitmap(bitmap,w / 3,cropWidth,cropHeight,1)">null,1)">);
    }

    
     * 选择变换
     *
     *  alpha  旋转角度,可正可负
     *  旋转后的图片
     private Bitmap rotateBitmap(Bitmap origin,1)"> alpha) {
         Matrix();
        matrix.setRotate(alpha);
         围绕原地进行旋转
        Bitmap newBM = Bitmap.createBitmap(origin,1)">
     * 偏移效果
     *  偏移后的bitmap
      Bitmap skewBitmap(Bitmap origin) {
         Matrix();
        matrix.postSkew(-0.6f,-0.3f);
        Bitmap newBM = Bitmap.createBitmap(origin,1)"> newBM;
    }

按钮的操作定义:

    @Override
    public void onClick(View v) {
        Bitmap originBM = BitmapFactory.decoderesource(getresources(),R.drawable.littleboygreen_x128);
        switch (v.getId()) {
            case R.id.btn1: { 按尺寸缩放
                effectTextView.setText(R.String.scalE);
                Bitmap nBM = scaleBitmap(originBM,100,72);
                effectView.setImageBitmap(nBM);
                break;
            }
            case R.id.btn2: { 按比例缩放,每次点击缩放比例都会不同
                effectTextView.setText(R.String.scale_ratio);
                if (ratio < 3) {
                    ratio += 0.05f;
                } else {
                    ratio = 0.1f;
                }
                Bitmap nBM = scaleBitmap(originBM,ratio);
                effectView.setImageBitmap(nBM);
                case R.id.btn3: { 裁剪
                effectTextView.setText("剪个头");
                Bitmap cropBitmap = cropBitmap(originBM);
                effectView.setImageBitmap(cropBitmap);
                case R.id.btn4: { 顺时针旋转效果;每次点击更新旋转角度
                if (alpha < 345) {
                    alpha += 15 {
                    alpha = 0;
                }
                effectTextView.setText("旋转");
                Bitmap rotateBitmap = rotateBitmap(originBM,alpha);
                effectView.setImageBitmap(rotateBitmap);
                case R.id.btn5: { 逆时针旋转效果;每次点击更新旋转角度
                if (beta > 15) {
                    beta -= 15 {
                    beta = 360);
                effectView.setImageBitmap(rotateBitmap);
                case R.id.btn6: { 偏移效果;偏移量在方法
                Bitmap skewBM = skewBitmap(originBM);
                effectView.setImageBitmap(skewBM);
                ;
            }
        }
    }

遇到的问题

@H_773_53@matrix matrix = Matrix(); matrix.preScale(ratio,ratio); 当 ratio=1,下面的 newBM 将会等价于 origin Bitmap newBM = Bitmap.createBitmap(origin,1)">); origin.isRecycled()) { origin.recycle(); }

log如下,当ratio=1时,新bitmap和旧的bitmap同一地址


11-27 05:27:16.086 16723-16723/? D/rust: originBitmap = android.graphics.bitmap@1e8849e
11-27 05:27:16.086 16723-16723/? D/rust: newBitmap = android.graphics.bitmap@1e8849e

 更多请参见 https://rustfisher.com

大佬总结

以上是大佬教程为你收集整理的Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移全部内容,希望文章能够帮你解决Android Bitmap 常见的几个操作:缩放,裁剪,旋转,偏移所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。