Android Compose Bloom 项目实战 (二) : 欢迎页

news2025/1/7 6:56:09

1. 前言

上一篇文章我们讲到了Compose Bloom项目开发之前的一些配置及沉浸式状态栏的修改。
这篇文章接着上文,会介绍欢迎页的开发。

需要实现的页面效果如下所示
在这里插入图片描述

2. 分析页面组件

根据UI图,我们可以可知,该页面是由背景和前面部分部分组成的。

3. 实现背景部分

3.1 创建 WelcomePage

首先,我们需要先创建WelcomePage.kt

@Composable
fun WelcomePage() {
}

3.2 将MainActivity设置为WelcomePage

class MainActivity : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        WindowCompat.setDecorFitsSystemWindows(window, false)
        val controller = WindowCompat.getInsetsController(window, window.decorView)
        controller?.isAppearanceLightStatusBars = true

        setContent {
            BloomTheme {
                WelcomePage()  // <-------- 设置为WelcomePage
            }
        }
    }
}

3.3 添加背景色

由设计稿可知,页面的背景色是pink100

@Preview
@Composable
fun WelcomePage() {
    Box(modifier = Modifier.fillMaxSize().background(color = pink100)){

    }
}

我们使用快捷键 ctrl + shift + F5 (Windows,其他系统请自行百度),可以预览到效果
在这里插入图片描述

3.3.2 设置白色的不规则形状图片

我们之前添加的资源文件里,ic_light_welcome_bg.xml就是白色的不规则形状图片
在这里插入图片描述

将其设置到页面中

@Composable
private fun BackgroundImage() {
    Image(
        painter = rememberVectorPainter(
            image = ImageVector.vectorResource(id = R.drawable.ic_light_welcome_bg)
        ),
        modifier = Modifier.fillMaxSize(),
        contentDescription = ""
    )
}

效果如下所示
在这里插入图片描述

4. 实现前面部分

4.1 添加树叶图片

我们查看之前添加的资源文件里,ic_light_welcome_illos.xml就是树叶的图片

在这里插入图片描述
我们将图片设置到页面中

@Composable
fun LeafImage() {
    Image(
        painter = rememberVectorPainter(
            image = ImageVector.vectorResource(id = R.drawable.ic_light_welcome_illos)
        ),
        contentDescription = ""
    )
}

可以看到效果
在这里插入图片描述
发现这个页面是在最顶端,我们期望改变一下它的位置,可以给他设置padding

在Compose里面,没有margin,而是通过padding的调用顺序,从而实现margin和padding的效果

这里我们用到了Column布局,设置了align(Alignment.End))靠右摆放,所以把Modifier抽取了出来

@Composable
fun WelComeContent() {
    Column(modifier = Modifier.fillMaxSize()) {
        LeafImage(Modifier
            .padding(top = 88.dp, start = 88.dp)
            .align(Alignment.End))
    }
}

@Composable
fun LeafImage(modifier: Modifier) {
    Image(
        painter = rememberVectorPainter(
            image = ImageVector.vectorResource(id = R.drawable.ic_light_welcome_illos)
        ),
        modifier = modifier,
        contentDescription = ""
    )
}

效果如下
在这里插入图片描述

4.2 添加Bloom标题

Bloom这几个字也是用图片实现的,我们把它加上

Spacer(modifier = Modifier.height(48.dp))
BloomTitle(modifier = Modifier.align(Alignment.CenterHorizontally))

@Composable
fun BloomTitle(modifier: Modifier) {
    Image(
        modifier = modifier,
        painter = rememberVectorPainter(
            image =
            ImageVector.vectorResource(id = R.drawable.ic_light_logo),
        ), contentDescription = ""
    )
}

效果如下
在这里插入图片描述

4.3 添加副标题

Spacer(modifier = Modifier.height(8.dp))
BloomSubTitle(modifier = Modifier.align(Alignment.CenterHorizontally))

@Composable
fun BloomSubTitle(modifier: Modifier) {
    Text(
        text = "Beautiful home garden solutions",
        style = subtitle1,
        color = gray,
        modifier = modifier
    )
}

效果如下所示
在这里插入图片描述

4.4 添加注册账号按钮

Spacer(modifier = Modifier.height(40.dp))
CreateAccountButton()

@Composable
fun CreateAccountButton() {
    Button(
        onClick = { },
        modifier = Modifier
            .padding(horizontal = 16.dp)
            .fillMaxWidth()
            .height(48.dp)
            .clip(medium),
        colors = ButtonDefaults.buttonColors(pink900)
    ) {
        Text(text = "Create Account", style = button, color = white)
    }
}

效果如下
在这里插入图片描述

4.5 添加登录按钮

Spacer(modifier = Modifier.height(24.dp))
LoginButton()

@Composable
fun LoginButton() {
    Text(text = "Log in", style = button, color = pink900)
}

最终效果如下
在这里插入图片描述

至此,我们就完成了欢迎页的界面,下一篇文章我们将接着介绍登录页界面的实现。(待更新)

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

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

相关文章

IDEA配置tomcat,快速部署tomcat

Tomcat简介 Tomcat是Apache 软件基金会&#xff08;Apache Software Foundation&#xff09;的Jakarta 项目中的一个核心项目&#xff0c;由Apache、Sun 和其他一些公司及个人共同开发而成。由于有了Sun 的参与和支持&#xff0c;最新的Servlet 和JSP 规范总是能在Tomcat 中得…

地震数据处理研究(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

Kubernetes集群coredns缓存容器bind: address already in use错误导致集群服务无法互通解决

coredns缓存nodelocal dns cache :53: bind: address already in use错误处理起因分析问题处理问题重启Node local dns起因 事情起因是Kubernetes集群内的服务无法互相访问了 分析问题 因为Kubernetes集群内的服务都是通过service、pod的名称作为域名到coredns解析Cluster I…

ubuntu 18.04安装python3.7.5,并将 python 设定为python3, pip设定为pip3

ubuntu 18.04安装python3.7.5&#xff0c;并将 python 设定为python3&#xff0c; pip设定为pip3环境&#xff1a;Ubuntu 18.04.1安装步骤&#xff1a;一、安装python3.7二、安装pip3三、更改python为 python3指向&#xff0c;更改pip为pip3指向四、注意点&#xff0c;必须改回…

基于java+ssm+easyui灵悟酒店系统

✌博主介绍✌:一个致力于全战开发的代码热爱者 基于javassmeasyui灵悟酒店系统一、前言介绍&#xff1a;二、系统设计&#xff1a;2.1 系统整体架构&#xff1a;2.2 系统功能设计&#xff1a;三、功能截图&#xff1a;3.1 首页&#xff1a;3.2 用户登陆&#xff1a;3.2.1 登陆后…

【Android App】三维处理中三维投影OpenGL功能的讲解及实战(附源码和演示 超详细必看)

运行有问题或需要源码请点赞关注收藏后评论区留言~~~ 一、OpenGL的讲解 OpenGL定义了一个跨语言&#xff0c;跨平台的图形程序接口&#xff0c;对Android开发者来说&#xff0c;OpenGL就是用来绘制三维图形的技术手段&#xff0c;当然OpenGL不仅仅能够展现静止的三维图形&…

深入理解地址翻译 CSAPP

地址翻译, 用自己的话说一遍, 然后自己在draw.io画图理解. 术语 页表就是一个 页表条目&#xff08;Page Table Entry PTE)的数组&#xff0c;每一项(每个PTE)是[有效位&#xff0c;物理地址]. 我们是用VPN来标识每个PTE,但记住这些VPN并不是页表的一部分&#xff0c;不会储…

基础知识——进制 与 进制转换 (C++ 程序)

目录 一、进制的定义 二、表示方法 1、当进制数 ≤ 10时 2、当进制数&#xff1e;10时 三、进制的计算 1、整数 2、小数 3、非十进制数 4、非十进制转十进制 四、十进制转非十进制数 1、整数部分 2、小数部分 3、整小混合 五、程序实现 1、十进制 转 其它进制 …

Unity 3D 动画系统(Mecanim)|| Unity 3D 人形角色动画(Avatar)

Unity 3D 动画系统&#xff08;Mecanim&#xff09; Mecanim 动画系统是 Unity 公司推出的全新动画系统&#xff0c;具有重定向、可融合等诸多新特性&#xff0c;可以帮助程序设计人员通过和美工人员的配合快速设计出角色动画&#xff0c;其主界面如下图所示。 Unity 公司计划…

wy的leetcode刷题记录_Day50

wy的leetcode刷题记录_Day50 声明 本文章的所有题目信息都来源于leetcode 如有侵权请联系我删掉! 时间&#xff1a;2022-11-23 前言 补 目录wy的leetcode刷题记录_Day50声明前言1742. 盒子中小球的最大数量题目介绍思路代码收获700. 二叉搜索树中的搜索题目介绍思路代码收获…

Maven问题相关 1 存在jar 却无法映射

这是一个比较新手的问题了&#xff0c;可能刚接触这个问题的小伙伴会纳闷&#xff0c;我这个本地仓库明明有却怎么映射失败吗?不科学啊。尤其是面临公司项目很多依赖的情况下&#xff0c;会出现大量这种情况&#xff0c;就算是项目经理过来。也可能会卧槽&#xff0c;我电脑上…

基于python的CLI应用程序开发(第一节):简单了解一下Typer

Typer开发(第一节)&#xff1a;简单了解一下Typer 文章目录Typer开发(第一节)&#xff1a;简单了解一下Typer1. 简介2. 安装3. 在编辑器中使用Typer4. 简单应用15. 简单应用26. 命令参数7.其它1. 简介 Typer 是一个python用于构建 CLI 应用程序的库,简单说就是开发控制台程序&…

Idea+maven+spring-cloud项目搭建系列--8整合Zookeeper

本文为 Ideamavenspring-cloud项目搭建系列&#xff0c;maven项目的创建可以参考&#xff1a; https://blog.csdn.net/l123lgx/article/details/121467823 本文使用了nacos 作为微服务的注册与发现&#xff0c;nacos 阿里云服务器的安装可以参考&#xff1a;https://blog.csdn.…

构建用于签名/加密双证书测试体系的可执行命令

注意事项 生成证书请求的填写 范例Subject: C CN, ST Beijing, L Beijing, O MSI, OU msi, CN ca, emailAddress cagmssl.com 前面的步骤存在错误&#xff0c;后面改用脚本进行证书生成&#xff0c;阅读时请跳过前面错误的内容 错误的内容 -> 开始 CA 生成私钥 op…

了解mysql脏页落盘过程

脏页落盘 什么是脏页&#xff1f; 对数据的修改&#xff0c;首先改内存中的缓冲池的页&#xff0c;由于缓冲区的数据跟磁盘中的数据不一致&#xff0c;所以称缓冲区的页为脏页。 脏页如何写入到磁盘&#xff1f; 不是每次更新都触发脏页落盘&#xff0c;而是通过CheckPoint机…

计及调频成本和荷电状态恢复的多储能系统调频功率双层优化【蓄电池经济最优目标下充放电】(基于matlab+yalmip+cplex的蓄电池出力优化)

摘要&#xff1a;针对电网中不同类型储能电站调频成本、剩余调频 能力存在差异、储能电站内部储能单元 SOC 过高或过低 的问题&#xff0c;提出计及调频成本和 SOC 恢复的多储能系统调 频功率双层优化策略&#xff0c;该策略包含调频功率优化层和 SOC 优化层&#xff1a;在调频…

覆盖libc.so.6的惨痛教训

覆盖libc.so.6的惨痛教训背景问题原因解决1、当前session未断开2、OS崩溃重启&#xff0c;所有ssh session断开惨痛教训1、对于上产环境的内核依赖库文件不能随意覆盖、删除。2、 scp 文件覆盖问题总结参考背景 发生时间: 2022年11月28日08:55:20 偷了个懒&#xff0c;在安装t…

Allegro走线自动关闭其它飞线操作指导

Allegro走线自动关闭其它飞线操作指导 Allegro在走线时候有一个自动关闭其它网络飞线的功能,具体操作如下 点击add connect命令 在option里面选择Auto-blank other rats 未勾选的状态 勾选后的状态,其它网络的飞线都被关闭了 This section is describe what the functio…

楼盘vr虚拟样板间,为售楼中心带来财气

房企也进入业绩冲刺期。为了完成销售目标&#xff0c;扩大市场销售面积&#xff0c;各大房企必将加大楼盘推出&#xff0c;降价冲销量已成常态。虚拟样板间采用创意化的营销策略&#xff0c;在激烈的竞争中脱颖而出。 所谓的VR虚拟样板间就是&#xff0c;利用数字化技术把建成或…

使用AWS的API Gateway实现websocket

问题 最近业务上面需要使用到WebSocket长连接来解决某些业务场景。 一图胜千言 注意&#xff1a;这里承担WebSocket服务器的是AWS API Gateway&#xff1b;后面的EC2业务服务&#xff0c;其实都是REST接口服务。 这里主要关注API Gateway和REST业务服务怎么实现API Gateway要…