Android矩阵Matrix变换setRectToRect,Kotlin

Android矩阵Matrix变换setRectToRect,Kotlin

Android画布Canvas裁剪区域clipRect,Kotlin-CSDN博客 基础上,增加一个点,通过setRectToRect挖出Bitmap原图中心区域的一块放到目标RectF里面。

Kotlin 复制代码
import android.content.Context
import android.graphics.Bitmap
import android.graphics.Canvas
import android.graphics.Color
import android.graphics.Matrix
import android.graphics.RectF
import android.graphics.drawable.BitmapDrawable
import android.os.Bundle
import android.util.AttributeSet
import android.util.SizeF
import android.widget.ImageView
import androidx.appcompat.app.AppCompatActivity
import androidx.appcompat.widget.AppCompatImageView

class MainActivity : AppCompatActivity() {
    private var iv: MyImageView? = null

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        iv = findViewById(R.id.iv)

        val result = findViewById<ImageView>(R.id.result)
        iv?.setTestImageView(result)
    }
}

class MyImageView : AppCompatImageView {
    private var mSrcBmp: Bitmap? = null
    private var testIV: ImageView? = null

    private val mSizeF = SizeF(500f, 200f)

    constructor(ctx: Context, attrs: AttributeSet) : super(ctx, attrs) {
        //mSrcBmp是原始图大小,没有缩放和拉伸的。
        mSrcBmp = (drawable as BitmapDrawable).bitmap
    }

    fun setTestImageView(imageView: ImageView) {
        testIV = imageView
    }

    override fun onDraw(canvas: Canvas) {
        val cx = this.width / 2
        val cy = this.height / 2
        val srcRectF = RectF(cx - mSizeF.width / 2, cy - mSizeF.height / 2, cx + mSizeF.width / 2, cy + mSizeF.height / 2)
        canvas.clipRect(srcRectF)
        super.onDraw(canvas)

        val bmp = Bitmap.createBitmap(mSizeF.width.toInt(), mSizeF.height.toInt(), Bitmap.Config.ARGB_8888)
        val c = Canvas(bmp)
        c.drawColor(Color.BLUE)

        //选取源bitmap的一块中心区域。
        val bmpCenterX = mSrcBmp!!.width / 2
        val bmpCenterY = mSrcBmp!!.height / 2
        val bmpRectF = RectF(
            bmpCenterX - mSizeF.width / 2,
            bmpCenterY - mSizeF.height / 2,
            bmpCenterX + mSizeF.width / 2,
            bmpCenterY + mSizeF.height / 2
        )

        val dstRectF = RectF(0f, 0f, mSizeF.width, mSizeF.height)
        val matrix = Matrix()
        //把bitmap中心区域的那一块放到目标的dstRectF里面。
        matrix.setRectToRect(bmpRectF, dstRectF, Matrix.ScaleToFit.CENTER)
        c.drawBitmap(mSrcBmp!!, matrix, null)

        testIV?.setImageBitmap(bmp)
    }
}

上图是clipRect裁剪剪切区域绘制出来的中心区域图。

下面是setRectToRect"挖"出Bitmap中心区域的一块放到目标Bitmap里面。

Android画布Canvas裁剪区域clipRect,Kotlin-CSDN博客文章浏览阅读481次,点赞18次,收藏18次。Android拼接合并图片生成长图代码实现合并两张图片,以第一张图片的宽度为标准,如果被合并的第二张图片宽度和第一张不同,那么就以第一张图片的宽度为准线,对第二张图片进行缩放。Android拼接合并图片生成长图代码实现合并两张图片,以第一张图片的宽度为标准,如果被合并的第二张图片宽度和第一张不同,那么就以第一张图片的宽度为准线,对第二张图片进行缩放。基础上,把剪切的区域从矩形Rect变为圆形的Path,当手指在上面的ImageView移动时候,下面同等大小对应的坐标区域显示"剪切"出来的圆形图。https://blog.csdn.net/zhangphil/article/details/135885485

相关推荐
小范馆1 天前
通过 useEventBus 和 useEventCallBack 实现与原生 Android、鸿蒙、iOS 的事件交互
android·ios·harmonyos
恋猫de小郭1 天前
Flutter 也有类 React Flow 的节点流程编辑器,快来了解下刚刚开源的 vyuh_node_flow
android·前端·flutter
2501_916008891 天前
iOS 26 文件导出与数据分析,多工具组合下的开发者实践指南
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_916008891 天前
iOS混淆实战用多工具组合把IPA加固做成可复用的工程能力(iOS混淆 IPA加固 无源码混淆
android·ios·小程序·https·uni-app·iphone·webview
wangdaoyin20101 天前
UniApp 在手机端(Android)打开选择文件和文件写入
android·前端·uni-app
天花板之恋1 天前
MutableStateFlow、StateFlow、LiveData在Compose中的运用
kotlin·workflow
我命由我123451 天前
Android PDF 操作 - AndroidPdfViewer 显示 PDF 异常清单(数据为 null、数据为空、PDF 文件损坏、非 PDF 文件)
android·java·java-ee·pdf·android studio·android-studio·android runtime
zhilin_tang1 天前
揭开Linux跨平台 adb调试原理神秘面纱
android·linux
撩得Android一次心动1 天前
Android 四大组件——Activity
android
TimeFine1 天前
Android 网络请求超时?可能与连接池和脏连接有关
android