一文讲完Jetpack常用修饰符

Jetpack Compose系列(4) - 修饰符

修饰符

Modifier,即JetpackCompose中的修饰符,可以用来修饰以下内容:

· 更改可组合项的大小、布局、行为和外观

· 添加信息,如无障碍标签

· 处理用户输入

· 添加高级互动,如使元素可点击、可滚动、可拖动或可缩放

修饰符是标准的Kotlin对象,可以通过调用某个Modifier类函数来创建修饰符,例如:

@Preview(showBackground = true)
@Composable
fun DefaultPreview() {Column(modifier = Modifier.padding(35.dp)){Text(text = "Hello")Text(text = "Modifier")}
}

对应生成的padding值为15dp的两个Text列表效果为:

image.gif
相信到这里你已经开始明白,Modifier可以像原先View体系中的XML文件里设置padding等扩展函数来调节布局效果,当然也可以调节width和height一系列属性,下面就让我们来熟悉这些你以后经常使用到的扩展函数:

背景(background)和透明度(alpha)

· background(color: Color, shape: Shape?):设置背景及背景形状,shape可以指定形状,例如可以使用RoundedCornerShape来指定圆角大小。

· alpha(alpha: Float):设置透明度,范围值从0到1。

如果是渐变背景,可以使用background(brush: Brush, shape: Shape?, alpha: Float?)。其中Brush参数就是我们指定的渐变,例如使用verticalGradient创建的竖直方向渐变:

@Composable
fun CustomView() {Column(modifier = Modifier.background(Brush.verticalGradient(listOf(Color.Blue,Color.Red))).alpha(0.3f)){Text(text = "Hello")Text(text = "Modifier")}
}

对应生成的效果为:

image.gif
需要注意的是,这里设置的alpha透明度指的是{}里的对象的透明度,而如果要修改背景透明度则要把alpha设置进background()内,例如:

image.gif

在设置Brush的时候,你会发现可以设置很多函数:

image.gif

这些函数可以做到横向渐变、线性渐变、扫描渐变,外加指定开始结束位置等等,这里就不多做介绍了。

大小 ( size ) 和宽高

· width(width: dp): 设置宽度,单位dp。

· height(height: dp): 设置高度,单位dp。

· size(width: dp,height: dp) :同时设置宽高,单位dp。

下面两段代码是等价的:

Column(modifier = Modifier.background(Color.Red).width(60.dp).height(120.dp)){Text(text = "Hello")Text(text = "Modifier")
}
Column(modifier = Modifier.background(Color.Red).size(60.dp,120.dp)){Text(text = "Hello")Text(text = "Modifier")
}

实现效果也是一致的:

image.gif

边框 (border) 和点击

· border(width: Dp, color: Color, shape: Shape?):添加边框,color参数指定颜色,shape参数指定粗细和形状。

· clickable():让任意控件变的可点击,且会附加水波纹效果。

@Composable
fun CustomView() {Column(modifier = Modifier.background(Color.Red).width(60.dp).height(120.dp).clickable (onClick = {Log.i("clickEvent"," get clicked ! ")})){Text(text = "Hello")Text(text = "Modifier")}
}

点击列表,对应的控制台输出日志为:

image.gif
当然,clickable()也有其他参数可以设置不可点击等:

Modifier.clickable(
enabled: Boolean = true, // 是否可点击状态,默认可点击,false则不可点击
onClickLabel: String? = null, // 语义/可访问性标签
role: Role? = null, // 点击元素的类型,例如Button、Checkbox、Image等。用于可访问性服务。
onClick: () -> Unit // 响应点击事件
)

· combinedClickable:可设置长按,多次点击,普通点击监听等。注意:这是实验性的API随时可能删除(使用时会要求方法和方法被调用处带上@ExperimentalFoundationApi)。示例如下:

@ExperimentalFoundationApi
@Composable
fun CustomView() {Column(modifier = Modifier.background(Color.Red).width(60.dp).height(120.dp).combinedClickable (onLongClick = {Log.i("clickEvent"," onLongClick event happened ! ")},onDoubleClick = {Log.i("clickEvent"," onDoubleClick event happened ! ")},onClick = {Log.i("clickEvent"," onClick event happened ! ")})){Text(text = "Hello")Text(text = "Modifier")}
}

对应日志也能在控制台正确输出:

image.gif
· onFocusChanged():监听焦点变化事件。

· focusable():设置焦点。

· requiredWidth(width: Dp):强制设置宽度,可以忽略父元素的宽高限制。

· requiredHeight(height: Dp):强制设置高度,可以忽略父元素的宽高限制。

· heightIn(min: Dp, max: Dp ),设置高度的最大最小值。widthIn同理。

· padding(all: Dp): 在元素周围留出空间,即内边距。

· rotate(degrees: Float):设置旋转度数。

· scale(scaleX: Float, scaleY: Float):设置缩放,如果是负数可以实现镜像效果。

· horizontalScroll(),允许子元素在宽度大于最大限制时横向滚动。(指超出屏幕宽度后,我们还可以水平方向滚动)

· verticalScroll(),允许子元素在宽度大于最大限制时垂直滚动。

例如:

Row(Modifier.horizontalScroll(rememberScrollState())) {Box(Modifier.size(700.dp, 50.dp).background(Color.Red)){Text("123")}
}

对应输出效果为:

image.gif
这时这个红色的条目是可以左右拖动的。

· fillMaxHeight(fraction: Float = 1f):子布局填充父项允许的所有可用高度,效果类似于XML中的match_parent,默认值1f。fillMaxSize 和 fillMaxWidth同理。

例如如下代码:

Box(Modifier.requiredSize(100.dp).background(Color.Red)) {Box(Modifier.fillMaxWidth(0.6f).fillMaxHeight(0.5f).background(color = Color.Yellow))
}

对应的效果为:

image.gif
· wrapContentSize:组件的控件宽高若是小与定义的最小宽高,会将组件进行排列的设置(看名字是不是想起了wrap_content)。

· sizeIn(minWidth: Dp ,minHeight: Dp ,maxWidth: Dp ,maxHeight: Dp):设置宽高的最小值和最大值,宽度在minWidth ~ maxWidth之间,高度在minHeight ~ maxHeight之间。

Column {Box(Modifier.sizeIn(minWidth = 50.dp, minHeight = 50.dp).size(20.dp).background(Color.Black))Box(Modifier.sizeIn(minWidth = 50.dp, minHeight = 50.dp).wrapContentSize(Alignment.TopCenter).size(20.dp)//设置的size小于最小宽高,最终渲染出来的就是20*20的,对齐方式为TopCenter.background(Color.Red))
}

对应的效果为:

image.gif
由代码可知,黑色的Box设置的size小于最小宽高,最终渲染出来的就是5050的长宽。红色的Box设置了wrapContentSize,设置的size小于最小宽高,最终渲染出来的就是2020的长宽,同时对齐方式为TopCenter。

当然,也可以单独设置宽高wrap:

//设置宽度wrapContentWidth(align: Alignment.Horizontal = Alignment.CenterHorizontally,unbounded: Boolean = false)
//设置高度wrapContentHeight(align: Alignment.Vertical = Alignment.CenterVertically,unbounded: Boolean = false)

我们修改上述代码中的两个属性:

Column {Box(Modifier.sizeIn(minWidth = 50.dp, minHeight = 50.dp).wrapContentHeight(Alignment.CenterVertically).height(20.dp)//高20dp,宽50dp,垂直居中.background(Color.Black))Box(Modifier.sizeIn(minWidth = 50.dp, minHeight = 50.dp).wrapContentWidth(Alignment.CenterHorizontally).width(20.dp)//宽20dp,高50dp,水平居中.background(Color.Red))
}

对应的效果展示为:

image.gif

修饰符顺序

修饰符函数的顺序非常重要,每个函数都会对上一个函数返回的 Modifier 进行更改。

例如:

Column {Box(Modifier.size(100.dp).background(Color.Red).padding(25.dp))Box(Modifier.size(100.dp).padding(25.dp).background(Color.Yellow))
}

对应的效果为:

image.gif
观察代码,不难发现,如果先设置背景,然后设置padding值,那么padding值是在其背景的基础上进行的。如果是先设置padding值,那么后设置的背景是针对padding之后的布局进行设置的。原因很简单,仅仅是因为每个函数都会对上一个函数返回的Modifier 进行更改。当然,点击事件也会受到影响,但也只是影响点击区域,这点不难理解,不做赘述了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/450052.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024年【低压电工】复审考试及低压电工作业考试题库

题库来源:安全生产模拟考试一点通公众号小程序 低压电工复审考试参考答案及低压电工考试试题解析是安全生产模拟考试一点通题库老师及低压电工操作证已考过的学员汇总,相对有效帮助低压电工作业考试题库学员顺利通过考试。 1、【单选题】()是保证电气作…

第二十四天| 77. 组合

Leetcode 77. 组合 题目链接:77 组合 题干:给定两个整数 n 和 k,返回范围 [1, n] 中所有可能的 k 个数的组合。你可以按 任何顺序 返回答案。 思考:回溯法。把回溯法的搜索过程抽象为树形结构。 每次从集合中选取元素&#xff0…

【开源】基于JAVA+Vue+SpringBoot的河南软件客服系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 系统管理人员2.2 业务操作人员 三、系统展示四、核心代码4.1 查询客户4.2 新增客户跟进情况4.3 查询客户历史4.4 新增服务派单4.5 新增客户服务费 五、免责说明 一、摘要 1.1 项目介绍 基于JAVAVueSpringBootMySQL的河…

【Python小游戏】五子棋小游戏(完整代码)

文章目录 写在前面Tkinter简介五子棋小游戏游戏介绍程序设计运行结果注意事项写在后面写在前面 本期内容:基于tkinter开发一个五子棋小游戏 实验环境 python3.11及以上pycharmtkinterTkinter简介 Tkinter是Python中最常用的图形用户界面(GUI)库之一,用于创建窗口、对话框…

Map和Set的封装

目录 一、底层原理 二、红黑树的节点 三、仿函数 四、迭代器 4.1、迭代器的定义: 4.2、*:解引用操作 4.3、->:成员访问操作符 4.4、!、 4.5、迭代器的: 4.6、迭代器的-- 五、Map 六、Set 七、红黑树源码 一、底层原理 我们要知道&#…

vue 阿里图标库引入分享

上篇文章分享了element-ui icon 组件的实现原理,文章当中有涉及到了阿里图标库的使用,当时未做详细使用说明,此篇文章是对上篇文章的补充哈。 本篇文章主要分为以下两部分: 一、阿里图标库使用 1.1 阿里图标库地址:…

029 命令行传递参数

1.循环输出args字符串数组 public class D001 {public static void main(String[] args) {for (String arg : args) {System.out.println(arg);}} } 2.找打这个类的路径,打开cmd cmd C:\Users\Admin\IdeaProjects\JavaSE学习之路\scanner\src\com\yxm\demo 3. 编译…

华为机考入门python3--(7)牛客7-取近似值

分类:数字 知识点: str转float float(str) 向上取整 math.ceil(float_num) 向下取整 math.floor(float_num) 题目来自【牛客】 import math def round_to_int(float_num): # 如果小数点后的数值大于等于0.5,则向上取整&#xf…

Unity 读取指定目录所占内存大小

public static class TxxTool{#region 读取文件大小private static List<string> DirList new List<string>();public static long GetFileSize(string path){DirList new List<string>();DirList.Add(path);GetAllDirecotries(path);long fileSize 0;for…

c语言--求第n个斐波那契数列(递归、迭代)

目录 一、概念二、用迭代求第n个斐波那契数1.分析2.完整代码3.运行结果4.如果求第50个斐波那契数呢&#xff1f;看看会怎么样。4.1运行结果&#xff1a;4.2画图解释 三、用迭代的方式求第n个斐波那契数列1.分析2.完整代码3.运行结果4.求第50个斐波那契数4.1运行结果4.2运行结果…

MySQL进阶之锁(表级锁,元数据锁,意向锁)

表级锁 介绍 表级锁&#xff0c;每次操作锁住整张表。锁定粒度大&#xff0c;发生锁冲突的概率最高&#xff0c;并发度最低。应用在MyISAM、 InnoDB、BDB等存储引擎中。 对于表级锁&#xff0c;主要分为以下三类&#xff1a; 表锁 元数据锁&#xff08;meta data lock&…

1元竟能驱动170万次AI推理?面壁智能MiniCPM 2B大模型,部署教程 移动端 安卓 苹果 ios android

在科技日新月异的今天,我们似乎习惯了“更新换代”的节奏。但你有没有想过,那些陪伴我们多年的老手机,也能摇身一变成为AI神器?面壁智能的MiniCPM 2B大模型,就给我们带来了这样的惊喜。 你可能不知道,这个仅有20亿参数的大模型,却拥有“越级打怪”的实力。与业内知名的…