如何在Android开发中利用Shape让你的Composable开发事半功倍

虽然2023年4月Graphics-Shapes库就已经被发布^[1], 但是相关的资料仍寥寥无几, 近日浏览 Fun with shapes in Compose ^[2]这篇文章的时候, 才发觉已经可以用shape来实现很多的功能了.

Shape是什么?

简单来说, 借助Compose, 您可以创建由多边形组成的形状^[3]. 这么说可能不太直观, 那么我们可以下Shape都可以创建出什么样的内容:

虽然不能直接处理任意两个形状之间的变换问题,(当然, 这个问题是设计时的问题.) 但是对于多边形结构之间的变化来说, 却能帮助我们简化大量的操作.

Shape能做到什么?

正如前文中所说, Shape可以帮助我们完成多边形之间的变化.

我们先看一下, 首先展示的的6种预设的情况.

然后是作为clip裁剪显示图片的效果, 这里添加了缩放和选择的效果, 如果有需要的话可以根据实际情况添加需要的效果.

下面就是对开始和结束多边形的设置了. 需要注意的是, 部分预设的情况是可以自定义形状的.^[4]

下面我们依次显示不同预设效果都可以如何进行条件.

需要注意的是, 在实际使用的过程中, 如果直接在DrawScope 中使用的话, radius , width , height 需要设置为实际View的大小, 而如果将其构建出来提供给类似clip中使用的话, radius , width , height则需要设置为比例的情况.^[5]

RoundedPolygonType.Common

kotlin 复制代码
fun RoundedPolygon(
    @IntRange(from = 3) numVertices: Int,
    radius: Float = 1f,
    centerX: Float = 0f,
    centerY: Float = 0f,
    rounding: CornerRounding = CornerRounding.Unrounded,
    perVertexRounding: List<CornerRounding>? = null
) = RoundedPolygon(
    ...
)

RoundedPolygonType.CIRCLE

kotlin 复制代码
fun RoundedPolygon.Companion.circle(
    @IntRange(from = 3) numVertices: Int = 8,
    radius: Float = 1f,
    centerX: Float = 0f,
    centerY: Float = 0f
): RoundedPolygon {
    ...
}

RoundedPolygonType.PILL

kotlin 复制代码
fun RoundedPolygon.Companion.pill(
    width: Float = 2f,
    height: Float = 1f,
    smoothing: Float = 0f,
    centerX: Float = 0f,
    centerY: Float = 0f,
): RoundedPolygon {
    ...
}

RoundedPolygonType.PILL_STAR

kotlin 复制代码
fun RoundedPolygon.Companion.pillStar(
    width: Float = 2f,
    height: Float = 1f,
    numVerticesPerRadius: Int = 8,
    @FloatRange(
        from = 0.0, fromInclusive = false, to = 1.0, toInclusive = false
    ) innerRadiusRatio: Float = .5f,
    rounding: CornerRounding = CornerRounding.Unrounded,
    innerRounding: CornerRounding? = null,
    perVertexRounding: List<CornerRounding>? = null,
    @FloatRange(from = 0.0, to = 1.0) vertexSpacing: Float = 0.5f,
    centerX: Float = 0f,
    centerY: Float = 0f
): RoundedPolygon {
    ...
}

RoundedPolygonType.RECTANGLE

kotlin 复制代码
fun RoundedPolygon.Companion.rectangle(
    width: Float = 2f,
    height: Float = 2f,
    rounding: CornerRounding = CornerRounding.Unrounded,
    perVertexRounding: List<CornerRounding>? = null,
    centerX: Float = 0f,
    centerY: Float = 0f
): RoundedPolygon {
    ...
}

RoundedPolygonType.STAR

kotlin 复制代码
fun RoundedPolygon.Companion.star(
    numVerticesPerRadius: Int,
    radius: Float = 1f,
    innerRadius: Float = .5f,
    rounding: CornerRounding = CornerRounding.Unrounded,
    innerRounding: CornerRounding? = null,
    perVertexRounding: List<CornerRounding>? = null,
    centerX: Float = 0f,
    centerY: Float = 0f
): RoundedPolygon {
    ...
}

Final

Demo: https://github.com/clwater/AndroidComposeCanvas

1\]:[developer.android.com/jetpack/and...](https://link.juejin.cn?target=https%3A%2F%2Fdeveloper.android.com%2Fjetpack%2Fandroidx%2Freleases%2Fgraphics%23graphics-shapes-1.0.0-alpha01 "https://developer.android.com/jetpack/androidx/releases/graphics#graphics-shapes-1.0.0-alpha01") \[2\]:[medium.com/androiddeve...](https://link.juejin.cn?target=https%3A%2F%2Fmedium.com%2Fandroiddevelopers%2Ffun-with-shapes-in-compose-8814c439e1a0 "https://medium.com/androiddevelopers/fun-with-shapes-in-compose-8814c439e1a0") \[3\]:[developer.android.com/jetpack/com...](https://link.juejin.cn?target=https%3A%2F%2Fdeveloper.android.com%2Fjetpack%2Fcompose%2Fgraphics%2Fdraw%2Fshapes "https://developer.android.com/jetpack/compose/graphics/draw/shapes") \[4\]:[developer.android.com/jetpack/com...](https://link.juejin.cn?target=https%3A%2F%2Fdeveloper.android.com%2Fjetpack%2Fcompose%2Fgraphics%2Fdraw%2Fshapes%3Fhl%3Dzh-cn%23custom-polygons "https://developer.android.com/jetpack/compose/graphics/draw/shapes?hl=zh-cn#custom-polygons") \[5\]: 当前使用的版本为1.0.0-alpha05, 不保证后续此特性继续保留.

相关推荐
DogDaoDao5 小时前
Android 硬件编码器参数完全指南:MediaCodec 深度解析
android·音视频·视频编解码·h264·硬编码·视频直播·mediacodec
JohnnyDeng946 小时前
Android 自定义 View:Canvas 绘图与事件分发深度解析
android
Android小码家9 小时前
Framework之Launcher小窗开发
android·framework·虚拟屏·小窗
赏金术士9 小时前
第七章:状态管理实战与架构总结
android·ui·kotlin·compose
颂love10 小时前
MySQL的执行流程
android·数据库·mysql
云起SAAS15 小时前
抖音小游戏源码 - 消消乐 | 含激励广告+成就系统 | 开箱即用商业级消除游戏模板
android·游戏·广告联盟·看激励广告联盟流量主·抖音小游戏源码 - 消消乐
大貔貅喝啤酒16 小时前
基于Windows下载安装Android Studio 3.3.2版本教程(2026详细图文版)
android·java·windows·android studio
程序员码歌16 小时前
OpenSpec 到 Superpowers:AI 编码从说清到做对
android·前端·人工智能
2501_9151063216 小时前
深入解析无源码iOS加固原理与方案,保护应用安全
android·安全·ios·小程序·uni-app·cocoa·iphone
黄林晴20 小时前
重磅官宣:Android UI 开发正式进入 Compose-first 时代
android·google io