Android Canvas状态save与restore,Kotlin

Android Canvas状态save与restore,Kotlin

    private fun f1() {
        val bitmap = BitmapFactory.decodeResource(resources, R.mipmap.pic).copy(Bitmap.Config.ARGB_8888, true)
        val canvas = Canvas(bitmap)

        val paint = Paint(Paint.ANTI_ALIAS_FLAG)
        paint.color = Color.RED
        paint.textSize = 50f
        paint.style = Paint.Style.FILL
        paint.textAlign = Paint.Align.LEFT

        val x = 200f
        val y = 200f

        canvas.drawText("hello", x, y, paint)

        canvas.save() //保存矩阵坐标等画布状态

        canvas.rotate(30f, 0f, 0f)

        canvas.drawText("world", x, y, paint)

        //此处没有canvas.restore(),绘制将紧接着上一笔world绘制。
        canvas.drawText("fly", x + 150, y, paint)

        iv1?.setImageBitmap(bitmap)
    }


    private fun f2() {
        val bitmap = BitmapFactory.decodeResource(resources, R.mipmap.pic).copy(Bitmap.Config.ARGB_8888, true)
        val canvas = Canvas(bitmap)

        val paint = Paint(Paint.ANTI_ALIAS_FLAG)
        paint.color = Color.RED
        paint.textSize = 50f
        paint.style = Paint.Style.FILL
        paint.textAlign = Paint.Align.LEFT

        val x = 200f
        val y = 200f

        canvas.drawText("hello", x, y, paint)

        canvas.save() //保存矩阵坐标等画布状态

        canvas.rotate(30f, 0f, 0f)

        canvas.drawText("world", x, y, paint)

        canvas.restore() //恢复到canvas.save()之前的矩阵坐标等画笔状态,接着hello写。
        canvas.drawText("fly", x + 150, y, paint)

        iv2?.setImageBitmap(bitmap)
    }

Android画布Canvas绘图scale & translate,Kotlin-CSDN博客文章浏览阅读440次,点赞4次,收藏11次。文章浏览阅读9.6k次。文章浏览阅读1.8k次。/*Java代码 将Drawable转化为Bitmap */ Bitmap drawableToBitmap(Drawable drawable) { int width = drawable.getIntrinsicWidth();Android Material Design :LinearLayoutCompat添加分割线divider_linearlayout 分割线-CSDN博客。https://blog.csdn.net/zhangphil/article/details/134930229

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangphil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值