Android canvas drawDoubleRoundRect使用

canvas.drawDoubleRoundRect(RectF outer, float[] outerRadii, RectF inner, float[] innerRadii, Paint paint)

作用是用指定画笔绘制两个圆角矩形。

outer:外部矩形

outerRadii:外部矩形的四个圆角半径。8个值,floatArrayOf(左上,左上,右上,右上,右下,右下,左下,左下)比如:floatArrayOf(50f,50f,10f,10f,10f,10f,0f,0f)

inner:内部矩形

innerRadii:内部矩形的四个圆角半径

paint:画笔,默认是Paint.Style.FILL

如果要绘制这样效果图如何实现?

package com.lxm.note.canvas.d3

import android.content.Context
import android.graphics.*
import android.os.Build
import android.util.AttributeSet
import android.view.View
import androidx.annotation.RequiresApi


/**
 * Desc
 */
@RequiresApi(Build.VERSION_CODES.Q)
class CanvasView @JvmOverloads constructor(
    context: Context, attrs: AttributeSet? = null, defStyleAttr: Int = 0
) : View(context, attrs, defStyleAttr) {
    private val mPaint: Paint = Paint(Paint.ANTI_ALIAS_FLAG)
    init {
        setLayerType(LAYER_TYPE_SOFTWARE, null)
        mPaint.color = Color.GREEN
    }

    override fun draw(canvas: Canvas) {
        super.draw(canvas)

        val saved = canvas.saveLayer(null, null, Canvas.ALL_SAVE_FLAG)
        val outer: RectF  = RectF(100f,100f,500f,300f)
        val outerRadii  = floatArrayOf(50f,50f,10f,10f,10f,10f,0f,0f)

        val inner: RectF  = RectF(150f,150f,450f,250f)
        val innerRadii  = floatArrayOf(10f,10f,10f,10f,10f,10f,0f,0f)
        canvas.drawDoubleRoundRect(outer, outerRadii, inner ,innerRadii , mPaint)
        canvas.restoreToCount(saved)
    }
}

activity_date3.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <com.lxm.note.canvas.d3.CanvasView
        android:id="@+id/canvasView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
</LinearLayout>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值