JetpackCompose从入门到实战学习笔记2——Modifier的简单使用

news2025/1/20 20:08:51

JetpackCompose从入门到实战学习笔记2——Modifier的简单使用

1.Image的使用:

@Composable
fun Image(modifier: Modifier) {
    Row {
        Image(
            painterResource(id = R.mipmap.iv_pic),
            contentDescription = stringResource(R.string.description),
            modifier = modifier
                .size(60.dp)//宽和高同时设置成60
                .clip(CircleShape)//将图片裁剪成圆形
        )
        //设置间距
        Spacer(Modifier.width(20.dp))
        Image(
            painterResource(id = R.mipmap.iv_pic),
            contentDescription = stringResource(R.string.description),
            modifier = Modifier
                .size(width = 100.dp, height = 100.dp)
                .clip(CircleShape)
        )
    }
}

2.Image的效果如下:

在这里插入图片描述

3.Button的使用:

@Composable
fun Button(modifier: Modifier) {
    Row {
        Spacer(Modifier.width(200.dp))
        Text(
            text = stringResource(R.string.description),
            style = typography.bodySmall.copy(color = Color.White),
            textAlign = TextAlign.Center,
            modifier =
            Modifier
                .width(80.dp)
                .clickable(onClick = {})
                .shadow(3.dp, shape = backgroundShape)
                .clip(backgroundShape)
                .background(
                    brush = Brush.verticalGradient(
                        colors = listOf(
                            Color.Red,
                            Color.Blue,
                        ),
                        startY = 0f,
                        endY = 80f
                    )
                )
                .padding(vertical = 10.dp)
        )
    }
}

4.Button的效果预览:

在这里插入图片描述

5.Background的使用:

@Composable
fun background(modifier: Modifier) {
    Row {
        Spacer(Modifier.width(300.dp))
        Box(
            modifier = modifier
                .size(100.dp)
                .background(color = Color.Red)
        )
        {
            Text(text = "纯色", modifier.align(Alignment.Center))
        }
        Spacer(Modifier.width(40.dp))
        Box(
            modifier
                .size(150.dp)
                .background(brush = verticalGradientBrush)
        )
        {
            Text(text = "渐变色", modifier.align(Alignment.Center))
        }
    }
}

    //创建brush渐变色
    private val verticalGradientBrush = Brush.verticalGradient(
        colors = listOf(
            Color.Red,
            Color.Green,
            Color.Blue
        ),
    )

6.Background的效果预览:

在这里插入图片描述

7.fillMaxSize:

@Composable
fun fillMaxSize(modifier: Modifier) {
    Box(
        modifier = modifier
            .fillMaxSize()//宽高同时铺满屏幕
            .background(Color.Red)
    )
    Box(
        modifier = modifier
            .fillMaxHeight()
            .width(60.dp)//高度铺满屏幕
            .background(Color.Blue)
    )
    Box(
        modifier = modifier
            .fillMaxWidth()
            .height(60.dp)
            .background(Color.Green)
    )//宽度铺满屏幕
}

8.fillMaxSize的效果预览:

在这里插入图片描述

9.padding的使用:

@Composable
fun padding(modifier: Modifier) {
    Box(
        modifier = modifier
            .padding(8.dp)
            .border(2.dp, Color.Red, shape = RoundedCornerShape(2.dp))
            .padding(8.dp)

    )
      {
            Spacer(
                modifier = modifier
                    .size(width = 200.dp, height = 20.dp)
                    .background(Color.Red)
            )
        }
}

10.padding的效果预览:

在这里插入图片描述

11.weightModifier的使用:

@Composable
fun weightModifierDemo(modifier : Modifier){
    Row {
        Spacer(Modifier.width(620.dp))//单个效果时设置为100,整体为620
        Column(
            modifier = Modifier
                .width(300.dp)
                .height(200.dp)
        ) {
            Box(
                modifier = modifier
                    .weight(1f)
                    .fillMaxWidth()
                    .background(Color.Green)
            )
            Box(
                modifier = modifier
                    .weight(1f)
                    .fillMaxWidth()
                    .background(Color.Blue)
            )
            Box(
                modifier = modifier
                    .weight(1f)
                    .fillMaxWidth()
                    .background(Color.Red)
            )
        }
    }
}

12.weightModifier的效果预览:

在这里插入图片描述

13.完整的效果如下:

在这里插入图片描述

14.demo的源码地址如下:

https://gitee.com/jackning_admin/compose-modifier-demo

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

阿里P8熬了一个月肝出这份32W字Java面试手册,传到Git上目前star数达到了30K+

互联网行业竞争越来越严峻,面试也是越来越难,一直以来我都想整理一套完美的面试宝典,奈何难抽出时间,这套1000道的Java面试手册我整理了整整1个月,上传到Git上目前star数达到了30K这套互联网Java工程师面试题包括了&am…

【iOS】UITableView的动态Cell高度(Masonry)

动态cell高度评论长度不同引出的问题实现评论长度不同引出的问题 对于之前写的项目的评论部分,由于评论文字字数的不同会导致label高度不同,所以需要设定不同的cell高度来展示。 一开始使用了 CGSize labelSize [label.text boundingRectWithSize:CG…

数据结构与算法_AVL平衡二叉树_四种旋转,插入和删除

1 AVL平衡二叉树的概念 平衡二叉树在BST树基础上加了平衡操作。 BST树特点 :在BST树的基础上,引入了节点“平衡”的概念,任意一个节点的左右子树高度差不超过 1 ,为了维持节点的平衡,引入了四种旋转操作,如…

MySQL的时区引起的前后端数据交互不畅的问题解决

MySQL的时区问题 一、问题起源 在使用swagger2进行代码测试时,执行完成后显示的时间与国内时间少了8个小时 强迫症的原因,就手贱了如下操作 ① 修改MySQL内的时间 set global time_zone 8:00; flush privileges;② show variables like “%time_zone%…

整数除法不用除号

给定两个整数 a 和 b ,求它们的除法的商 a/b ,要求不得使用乘号 *、除号 / 以及求余符号 % 。 注意: 整数除法的结果应当截去(truncate)其小数部分,例如:truncate(8.345) 8 以及 truncate(-2…

【路径规划】(2) A* 算法求解最短路,附python完整代码

大家好,今天和各位分享一下机器人路径规划中非常经典的 A* 算法,感兴趣的点个关注,文末有 python 代码,那我么开始吧。 1. 算法介绍 A* 算法是 1968 年 P.E.Hart[1]等人所提出的在全局地图环境中所有已知情形下求解最短路径问题的…

部分gcc预定义宏和函数栈帧的内存分布

本文简单基于树莓派8,linux4.4.50版本,32位arm cpu 尝试了解函数调用栈的内存分布的形态。使用gcc内置的宏 __builtin_frame_address 来打印栈帧内存上的信息,以及了解一下常用的gcc 内置的宏的输出。 针对 __builtin_frame_address 在gcc官网…

猴子也能学会的jQuery第十二期——jQuery遍历(上)

📚系列文章—目录🔥 猴子也能学会的jQuery第一期——什么是jQuery 猴子也能学会的jQuery第二期——引用jQuery 猴子也能学会的jQuery第三期——使用jQuery 猴子也能学会的jQuery第四期——jQuery选择器大全 猴子也能学会的jQuery第五期——jQuery样式操作…

PIC单片机3——外部中断

//RB2&#xff08;INT2&#xff09;作为外中断 #include <p18cxxx.h>/*18F系列单片机头文件*/ void PIC18F_High_isr(void);/*中断服务函数声明*/ void PIC18F_Low_isr(void); #pragma code high_vector_section0x8 /*高优先级中断响应时&#xff0c;会自动跳转到0x8处…

基于三相坐标系状态方程的感应电动机起动动态计算matlab程序

基于三相坐标系状态方程的感应电动机起动动态计算matlab程序 1 异步电动机动态数学模型的性质 电磁耦合是机电能量转换的必要条件&#xff0c;电流与磁通的乘积产生转矩&#xff0c;转速与磁通的乘积得到感应电动势。无论是直流电动机&#xff0c;还是交流电动机均如此。 交、直…

二十七、CANdelaStudio深入-编辑技巧(一致性检查)

本专栏将由浅入深的展开诊断实际开发与测试的数据库编辑,包含大量实际开发过程中的步骤、使用技巧与少量对Autosar标准的解读。希望能对大家有所帮助,与大家共同成长,早日成为一名车载诊断、通信全栈工程师。 本文介绍CANdelaStudio软件的一致性检查,欢迎各位朋友订阅、评论…

『LeetCode|每日一题』---->最小路径和

目录 1.每日一句 2.作者简介 『LeetCode|每日一题』最小路径和 1.每日一题 2.解题思路 2.1 思路分析 2.2 核心代码 2.3 完整代码 2.4 运行结果 1.每日一句 希望冬天的风能吹散一年里所有的遗憾 2.作者简介 &#x1f3e1;个人主页&#xff1a;XiaoXiaoChen-2716 &#x1f…

Vue3框架中CompositionAPI的基本使用(第十课)

1.Setup函数 理解&#xff1a;Vue3.0中一个新的配置项&#xff0c;值为一个函数。 setup是所有Composition API&#xff08;组合API&#xff09;“ 表演的舞台 ”。 组件中所用到的&#xff1a;数据、方法等等&#xff0c;均要配置在setup中。 setup函数的两种返回值&#x…

kubernetes工作负载之控制器

目录 ​一、概述 二、Deployment 控制器 2.1Deployment 部署应用 2.2Deployment滚动升级 2.2.1应用部署完成 2.2.2更新镜像三种方式 2.3 Deployment 发布失败回滚 2.4Deployment 水平扩容 三、DaemonSet控制器 四、Job控制器 4.1Job一次性执行 4.2定时任务&#xf…

查询:按A分组,满足B时对应的C

1.场景 这种问题我自己归纳为“找对应行”问题&#xff0c;例如有下面一场表&#xff08;学生做题&#xff0c;对每个知识点的得分情况&#xff09; 字段&#xff1a;主键id、user_id、score、is_study、knowledgeName、updateTime场景1&#xff1a;按用户分组&#xff0c;求…

Nginx (7):nginx高可用配置

所谓的高可用&#xff0c;就是虽然nginx可以反向代理&#xff0c;如果某个内部服务器down了&#xff0c;可以使用其他的内部服务器&#xff0c;然而万一nginx挂了呢&#xff1f;&#xff1f;&#xff1f;&#xff1f;布置多个nginx再反向代理nginx&#xff1f;&#xff1f;反向…

数据结构学习笔记(V):树与二叉树

目录 1 树 1.1 树的定义和基本术语 1.定义 2.基本术语 1.2 树的性质 2 二叉树 2.1 二叉树的定义和基本术语 1.定义 2.特殊二叉树 2.2 二叉树性质 2.3 二叉树存储结构 1.顺序存储 2.链式存储 3 二叉树进阶 3.1 二叉树顺序遍历 1.先序遍历 2.中序遍历 3.后序遍…

第十二周总结

这周我来总结一下数论分块和佩尔方程&#xff1a; 已知正整数n&#xff0c;求&#xff0c;对n/i下取整&#xff0c;相当于把一组数分块了&#xff0c;首先我们来找一下规律&#xff1a;n20时 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 …

现代密码学导论-20-流密码

目录 3.6 实际操作和加密方式 3.6.1 流密码 CONSTRUCTION 3.30 使用伪随机函数构造流密码 3.6.2 流密码的同步模式 CONSTRUCTION 3.31 流密码的异步模式 3.6 实际操作和加密方式 现代密码学导论-14-基于伪随机发生器的EAV安全_南鸢北折的博客-CSDN博客 CONSTRUCTION 3.17…

Spring Cloud整合Nacos集群

目录 第一章 微服务架构图 第二章 Spring Cloud整合Nacos集群 第三章 Spring Cloud GateWay 第四章 Spring Cloud Alibaba 整合Sentinel 第五章 Spring Cloud Alibaba 整合SkyWalking链路跟踪 第六章 Spring Cloud Alibaba 整合Seata分布式事务 第七章 Spring Cloud 集成Auth用…