我正在尝试模拟一个带有背景图像和前景图像的火炬视图。它在API 27及以下版本上运行良好,但在API 28上绘制一个矩形。
知道为什么它在Android Pie上不起作用吗?
火炬视图类
class TorchView : View, OnTouchListener { var mBitmapBackground: Bitmap? = null var mBitmapForeground: Bitmap? = null var mMask: Bitmap? = null private var mPosX = 0f private var mPosY = 0f private lateinit var paintMask: Paint private lateinit var paintBackground: Paint private lateinit var paintForeground: Paint private var radius = 150 constructor(context: Context) : super(context) { init() } constructor(context: Context, attrs: AttributeSet) : super(context, attrs) { init() } fun initBitmaps(bitmapBackground: Bitmap, bitmapForeground: Bitmap, radius: Int){ this.radius = radius mBitmapBackground = bitmapBackground mBitmapForeground = bitmapForeground mMask = makeRadGrad() mPosX = (bitmapBackground.width/2 - radius).toFloat() mPosY = (bitmapBackground.height/2 - radius).toFloat() invalidate() } fun init() { paintBackground = Paint() paintMask = Paint() paintMask.xfermode = PorterDuffXfermode(PorterDuff.Mode.CLEAR) paintForeground = Paint() paintForeground.xfermode = PorterDuffXfermode(PorterDuff.Mode.DST_OVER) isFocusable = true isFocusableInTouchMode = true this.setOnTouchListener(this) } public override fun onDraw(canvas: Canvas) { super.onDraw(canvas) val mask = mMask val bitmapForeground = mBitmapBackground val bitmapBackground = mBitmapForeground if(mask != null && bitmapForeground != null && bitmapBackground != null){ canvas.save() canvas.drawBitmap(bitmapBackground, 0f, 0f, paintBackground) canvas.drawBitmap(mask, mPosX, mPosY, paintMask) canvas.drawBitmap(bitmapForeground, 0f, 0f, paintForeground) canvas.restore() } } private fun makeRadGrad(): Bitmap { val gradient = RadialGradient( radius.toFloat(), radius.toFloat(), radius.toFloat(), -0xff0100, 0x00000000, android.graphics.Shader.TileMode.CLAMP ) val p = Paint() p.isDither = true p.shader = gradient val bitmap = Bitmap.createBitmap(radius*2, radius*2, Config.ARGB_8888) val c = Canvas(bitmap) c.drawCircle(radius.toFloat(), radius.toFloat(), radius.toFloat(), p) return bitmap } override fun onTouch(v: View?, event: MotionEvent): Boolean { mPosX = event.x - radius mPosY = event.y - radius invalidate() return true } }
试试这个
public override fun onDraw(canvas: Canvas) {
super.onDraw(canvas)
val mask = mMask
val bitmapForeground = mBitmapBackground
val bitmapBackground = mBitmapForeground
if(mask != null && bitmapForeground != null && bitmapBackground != null){
canvas.save()
canvas.drawBitmap(bitmapBackground, 0f, 0f, paintBackground)
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) {
makeRadGradP(canvas, bitmapForeground)
} else {
canvas.drawBitmap(mask, mPosX, mPosY, paintMask)
canvas.drawBitmap(bitmapForeground, 0f, 0f, paintForeground)
}
canvas.restore()
}
}
private fun makeRadGradP(canvas: Canvas, bm: Bitmap) {
val paint = Paint()
paint.style = Paint.Style.FILL
val shader = BitmapShader(bm, TileMode.CLAMP, TileMode.CLAMP)
paint.shader = shader
val corners = Path()
corners.addCircle(mPosX + radius, mPosY + radius, radius.toFloat(), Path.Direction.CW)
canvas.drawPath(corners, paint)
val gradient = RadialGradient(
mPosX + radius, mPosY + radius, radius.toFloat(), 0x00000000,
Color.parseColor("#df000000"), TileMode.CLAMP
)
val p = Paint()
p.isDither = true
p.shader = gradient
canvas.drawCircle(mPosX + radius, mPosY + radius, radius.toFloat(), p)
}
本文向大家介绍js绘制圆形和矩形的方法,包括了js绘制圆形和矩形的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js绘制圆形和矩形的方法。分享给大家供大家参考。具体如下: 这里使用js来绘制圆形和矩形,支持选择图形的背景颜色,同时可设置圆角矩形、半径、正圆、矩形、正方形这几个选项。或许这些图形你不需要,但重要的是让你学会JavaScript绘制图形的方法,这是要表达的核心。 运行效果
使用closePath()闭合图形 首先我们用上节课的方法绘制一个矩形。 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title></title> </head> <body> <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UT
各位程序员好, 我在代码中遇到了一个似乎无法破解的小问题。它与Java的Jframe;图形区域有关。我将在下面发布的代码是在一个绘图方法上。其目的是绘制ArrayList中的房间,该房间位于另一个类中,因此之前。这种偏离航线的情况不会发生,因此在这里发帖。 获取有关该项目的背景信息是ArrayList,其中包含各种不同大小和颜色的房间。房间本身就是物体。 首先是课程: 下面是用于创建房间的类。 我
可以使用包的相应方法在图像上绘制各种形状,如圆形,矩形,线条,椭圆,多段线,凸起,多段线,多段线。 可以使用类的方法在图像上绘制一个圆形。 以下是这种方法的语法 - 该方法接受以下参数 - mat - Mat对象,表示要在其上绘制圆的图像。 point - 代表圆中心的对象。 radius - 表示圆的半径的整型变量。 scalar - 表示圆的颜色的标量对象(BGR)。 thickness -
虽然HTML5的画布API未提供直接绘制圆形的方法,但我们一定可以通过绘制一个完全闭合的圆弧来创建这样一个方法。 图1-3 绘制圆弧 绘制步骤 按照以下步骤,在画布的中央绘制一个圆: 1. 定义2D画布上下文: window.onload = function(){ var canvas = document.getElementById("myCanvas"); var conte
问题内容: 我发现只能填充矩形,而没有圆角,该怎么办? 问题答案: HTML5画布没有提供绘制带有圆角的矩形的方法。 如何使用和方法? 您也可以使用方法代替方法。