当前位置: 首页 > news >正文

自定义实现图片裁剪

要实现这个功能,首先需要创建一个自定义的View,然后在该View中绘制背景框和裁剪后的图片。以下是一个简单的实现:

1. 创建一个名为`CustomImageView`的自定义View类,继承自`View`:


import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.view.View;

public class CustomImageView extends View {
    private Bitmap mOriginalBitmap;
    private Bitmap mCroppedBitmap;
    private RectF mCropRect;
    private Paint mPaint;

    public CustomImageView(Context context) {
        super(context);
        init();
    }

    public CustomImageView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    public CustomImageView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        init();
    }

    private void init() {
        mPaint = new Paint();
        mPaint.setAntiAlias(true);
        mPaint.setColor(0xFF0000FF); // 设置矩形框颜色为紫色
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        if (mCroppedBitmap != null) {
            canvas.drawBitmap(mCroppedBitmap, mCropRect, mCropRect, mPaint);
        }
    }

    public void setOriginalBitmap(Bitmap originalBitmap) {
        mOriginalBitmap = originalBitmap;
        invalidate();
    }

    public void setCropRect(RectF cropRect) {
        mCropRect = cropRect;
        invalidate();
    }

    public void setCroppedBitmap(Bitmap croppedBitmap) {
        mCroppedBitmap = croppedBitmap;
        invalidate();
    }
}
```

2. 在布局文件中使用`CustomImageView`:


<com.example.myapplication.CustomImageView
    android:id="@+id/custom_image_view"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />
```

3. 在Activity或Fragment中设置`CustomImageView`的属性:


CustomImageView customImageView = findViewById(R.id.custom_image_view);
Bitmap originalBitmap = ...; // 从资源或其他来源获取原始图片
Bitmap croppedBitmap = ...; // 对原始图片进行裁剪得到的图片
RectF cropRect = new RectF(...); // 裁剪区域,例如:new RectF(100, 100, 300, 300)

customImageView.setOriginalBitmap(originalBitmap);
customImageView.setCropRect(cropRect);
customImageView.setCroppedBitmap(croppedBitmap);
```

这样,你就可以在自定义View中显示裁剪后的图片了。注意,这里的代码仅作为示例,你可能需要根据实际情况进行调整。

http://www.lryc.cn/news/212632.html

相关文章:

  • 开发语言工具编程系统化教程入门和初级专辑课程上线
  • 【Truffle】二、自定义合约测试
  • 场景交易额超40亿,海尔智家三翼鸟开始收获
  • 众和策略可靠吗?股票扛杆怎么玩?
  • 解决连接Mysql出现ERROR 2013 (HY000): Lost connection to MySQL server at ‘waiting
  • Hadoop YARN功能介绍--资源管理、调度任务
  • 从AlexNet到chatGPT的演进过程
  • Unity如何实现bHaptics TrackSuit震动衣的SDK接入
  • 识别flink的反压源头
  • Spring是如何解决bean循环依赖的问题的
  • [移动通讯]【Carrier Aggregation-9】【 Radio Resource Control (RRC) Aspects】
  • 故障预测与健康管理(PHM)的由来以及当前面临的挑战
  • 【ChatGPT瀑布到水母】AI 在驱动软件研发的革新与实践
  • 【Django】项目模型
  • 字符集详解
  • Vert.x学习笔记-什么是Vert.x
  • AcWing 第127场周赛 构造矩阵
  • Seata入门系列【15】@GlobalLock注解使用场景及源码分析
  • Dubbo 路由及负载均衡性能优化
  • Python数据可视化入门指南
  • 我的ChatGPT的几个使用场景
  • 3 — NLP 中的标记化:分解文本数据的艺术
  • C++-类与对象(上)
  • 多进程间通信学习之无名管道
  • flink常用的几种调优手段的优缺点
  • 如何选择安全又可靠的文件数据同步软件?
  • 使用反射调用类的私有内部类的私有方法
  • 记一次 AWD 比赛中曲折的 Linux 提权
  • [SpringCloud] Feign 与 Gateway 简介
  • [Unity] 个人编码规范与命名准则参考