利用Jetpack Compose实现绘制五角星效果
作者:安安安安卓 时间:2023-04-10 06:20:48
说明
compose中我们的所有ui操作,包括一些行为,例如:点击、手势等都需要使用Modifier来进行操作。因此对Modifier的理解可以帮助我们解决很多问题的
自定义星行Modifier
本文我们打算自定义一个Modifier,通过这个modifier我们可以实现用一个操作符就画出五角星的效果
原理
我们实现绘制五角星的原理如下图,首先我们会虚构两个圆,将内圆和外圆角度平分五份,然后依次连接内圆和外圆的切点的坐标,然后使用path绘制完成。
实现
代码中的实现涉及到自定义绘制,难度并不大。需要注意的点:
composse中角度的锚点是弧度(Math.PI)、而原生的锚点是角度(360)
默认的原点在左上角,我们绘制的时候需要主动移动到组合的中心点
path的绘制使用Fill可以填充闭合路径图形,使用Stroke可以绘制线性闭合路径图形
代码
fun Modifier.customDraw(
color: Color,
starCount: Int = 5,
checked: Boolean = false,
) =
this.then(CustomDrawModifier(color, starCount, checked = checked))
class CustomDrawModifier(
private val color: Color,
private val starCount: Int = 5,//星的数量
private var checked: Boolean = false,
) :
DrawModifier {
override fun ContentDrawScope.draw() {
log("$size")
val radiusOuter = if (size.width > size.height) size.height / 2 else size.width / 2 //五角星外圆径
val radiusInner = radiusOuter / 2 //五角星内圆半径
val startAngle = (-Math.PI / 2).toFloat() //开始绘制点的外径角度
val perAngle = (2 * Math.PI / starCount).toFloat() //两个五角星两个角直接的角度差
val outAngles = (0 until starCount).map {
val angle = it * perAngle + startAngle
Offset(radiusOuter * cos(angle), radiusOuter * sin(angle))
}//所有外圆角的顶点
val innerAngles = (0 until starCount).map {
val angle = it * perAngle + perAngle / 2 + startAngle
Offset(radiusInner * cos(angle), radiusInner * sin(angle))
}//所有内圆角的顶点
val path = Path()//绘制五角星的所有内圆外圆的点连接线
(0 until starCount).forEachIndexed { index, _ ->
val outerX = outAngles[index].x
val outerY = outAngles[index].y
val innerX = innerAngles[index].x
val innerY = innerAngles[index].y
// drawCircle(Color.Red, radius = 3f, center = outAngles[index])
// drawCircle(Color.Yellow, radius = 3f, center = innerAngles[index])
if (index == 0) {
path.moveTo(outerX, outerY)
path.lineTo(innerX, innerY)
path.lineTo(outAngles[(index + 1) % starCount].x,
outAngles[(index + 1) % starCount].y)
} else {
path.lineTo(innerX, innerY)//移动到内圆角的端点
path.lineTo(outAngles[(index + 1) % starCount].x,
outAngles[(index + 1) % starCount].y)//连接到下一个外圆角的端点
}
if (index == starCount - 1) {
path.close()
}
}
translate(size.width / 2, size.height / 2) {
drawPath(path, color, style = if (checked) Fill else Stroke(width = 5f))
}
}
}
最终实现效果
来源:https://blog.csdn.net/ymeddmn/article/details/124211249
标签:Jetpack,Compose,五角星
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
微信跳一跳辅助Java代码实现
2022-03-31 19:12:03
解析ScrollView--仿QQ空间标题栏渐变
2021-06-20 22:44:54
![](https://img.aspxhome.com/file/2023/6/98656_0s.gif)
Java BigDecimal案例详解
2021-09-15 12:03:43
![](https://img.aspxhome.com/file/2023/9/63509_0s.png)
Java利用过滤器实现完善登录功能
2021-07-20 15:07:05
![](https://img.aspxhome.com/file/2023/8/79868_0s.png)
mybatis输出SQL格式化方式
2021-06-18 18:19:45
Android SQLite数据库版本升级的管理实现
2023-11-09 23:58:44
Android ScrollView无法填充满屏幕的解决办法
2022-01-07 03:20:55
![](https://img.aspxhome.com/file/2023/9/97879_0s.jpg)
Android使用手势监听器GestureDetector遇到的不响应问题
2022-02-27 23:52:40
![](https://img.aspxhome.com/file/2023/0/88710_0s.jpg)
android传送照片到FTP服务器的实现代码
2021-07-09 22:59:32
Java深入探究Object类的方法
2022-11-24 06:48:53
![](https://img.aspxhome.com/file/2023/4/67014_0s.png)
java字符串比较获取字符串出现次数的示例
2022-03-22 16:05:39
微信公众平台开发教程(三) 基础框架搭建
2022-08-12 00:33:50
![](https://img.aspxhome.com/file/2023/5/84485_0s.png)
Android编程实现画板功能的方法总结【附源码下载】
2023-08-05 10:45:07
![](https://img.aspxhome.com/file/2023/6/126736_0s.png)
SpringBoot应用线上重启脚本的命令详解
2022-02-05 18:21:52
c# this关键字用法代码详解
2022-06-07 15:22:09
C#中事件只能在内部调用的原因分析
2023-08-09 05:07:00
详解Android studio中正确引入so文件的方法
2022-06-17 23:21:32
![](https://img.aspxhome.com/file/2023/7/138857_0s.png)
Java8 HashMap遍历方式性能探讨
2022-01-31 08:48:11
Android 高版本API方法在低版本系统上的兼容性处理
2022-08-22 08:51:53
windows下java环境变量的设置方法
2022-12-01 03:13:14