Jetpack Compose 中的 X 和 Y 偏移、模糊、不透明度和阴影颜色?

Ars*_*ius 16 android canvas shadow android-jetpack android-jetpack-compose

由于 Jetpack Compose 有此限制,我正在寻找解决此问题的解决方案?

也许 Canvas 可以解决这个问题?如果有人可以提供如何利用X 和 Y 偏移、模糊和不透明度等附加参数以及自定义实现(画布或其他东西)在 Jetpack Compose 中为 、 、 等Card渲染Box阴影Column的代码片段,我真的很感激?Row

Ars*_*ius 24

由于这个代码片段,我设法找到了解决方案

@RequiresApi(Q)
fun Modifier.advancedShadow(
    color: Color = Color.Black,
    alpha: Float = 1f,
    cornersRadius: Dp = 0.dp,
    shadowBlurRadius: Dp = 0.dp,
    offsetY: Dp = 0.dp,
    offsetX: Dp = 0.dp
) = drawBehind {

    val shadowColor = color.copy(alpha = alpha).toArgb()
    val transparentColor = color.copy(alpha = 0f).toArgb()

    drawIntoCanvas {
        val paint = Paint()
        val frameworkPaint = paint.asFrameworkPaint()
        frameworkPaint.color = transparentColor
        frameworkPaint.setShadowLayer(
            shadowBlurRadius.toPx(),
            offsetX.toPx(),
            offsetY.toPx(),
            shadowColor
        )
        it.drawRoundRect(
            0f,
            0f,
            this.size.width,
            this.size.height,
            cornersRadius.toPx(),
            cornersRadius.toPx(),
            paint
        )
    }
}
Run Code Online (Sandbox Code Playgroud)

  • 感谢您的回答!您可以将默认的“alpha”值更新为“1f”吗?我花了一些时间试图理解为什么它不起作用=) (2认同)