首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Jetpack Compose之 在Compose中使用Navigation导航

前言 大约在一年半前,我发布了Compose的第一篇文章 Jetpack Compose开篇 之 HelloWorld,连我自己也没想到,这一年半的时间中我竟再也没有看过Compose..., 如今Compose...已经发布了稳定版本,还没学会Compose让我的头发又白了许多~ 使用Navigation在Compose中导航 如果你之前不喜欢Android提倡的”单Activity“应用,那么在Compose中相信你会慢慢习惯的...在页面2中调用popBackStack方法将当前页面出栈便又回到了页面1,这里就不贴页面2的代码了。...age={age}”,由于可选参数必须要设置一个默认值,这里设置年龄的默认值为30,现在 在页面1的点击事件中不再传递年龄参数 navController.navigate("${RouteConfig.ROUTE_PAGETWO...总结 除此之外,Navigation  在Compose中还支持深层链接等,关于Compose的更多用法,欢迎持续关注我~

2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Jetpack Compose for Desktop 使用过程中遇到的几个大坑

    Jetpack Compose for Desktop 使用过程中遇到的几个大坑 最近在用 Jetpack Compose for Desktop 写一些好玩的,用的时候遇到了很多大坑,在这里总结如下:...Binary distribution 无法访问 ClassLoader Resources 我们有时候一定会希望从 jar 内部读取资源,这个时候我们一般会使用 this::class.java.getResource...@See https://github.com/JetBrains/compose-jb/issues/2011 错误的使用二进制流方式从 ClassLoader Resources 中加载字体导致界面整体卡顿...FontStyle.Normal ): Font = LoadedFont(identity, data, weight, style) 然而当你试图从 ClassLoader Resources 中传入字体的二进制流时...在导出 SVG 图片时不要将样式导出到 CSS,而是选择内联 (inline) 样式 2.

    2.6K30

    在 hexo 中无痛使用本地图片

    1 起因 在 hexo 中使用本地图片是件非常让人纠结的事情,在 markdown 里的图片地址似乎永远无法和最后生成的网页保持一致。...这些问题使得我一度不愿意使用本地图片而选择用图床,但被移动运营商无耻的横条广告逼得打算上 https,图床只支持 http 就成了问题。...显然这样在本地的编辑器里完全不能正确识别图片的位置。...比较尴尬的是,这种方法直接放弃了 markdown 原来的语法,使用类似 的语法,。markdown 本来有插入图片的语法不好好支持,专门用一个新的语法来插入本地图片,让我这种强迫症不太能接受。...2 解决方案 CodeFalling/hexo-asset-image 2.1 使用 首先确认 _config.yml 中有 post_asset_folder:true 。

    2.6K100

    安卓软件开发:使用 Hilt 在 Jetpack Compose 和 M3 实现依赖注入App

    本Demo是展示如何结合 Jetpack Compose 和 Hilt,实现一个简单的双屏Demo,使用 Hilt 管理依赖在 UI 中展示数据。...Demo中,Jetpack Compose 和 Hilt 的结合很简单,但有几个技术难点需要注意: 3.1 生命周期管理 虽然Hilt可以处理依赖注入的生命周期,但在Compose中,组件的生命周期可能会因为...使用ViewModel来管理状态是个好办法,可以防止数据意外丢失。...4.2 Compose 中的状态管理和生命周期理解 理解状态的保存、恢复和更新对于构建复杂App非常重要。...如果你还没有尝试过使用 Hilt 和 Jetpack Compose,推荐亲自上手试试,看看它们能为Demo带来怎样的提升! 有任何问题欢迎提问,感谢大家阅读 )

    588162

    CREATE2 在广义状态通道中的使用

    君士坦丁堡硬升级中引入了一个新操作码 CREATE2[1] ,它使用新的方式来计算常见的合约地址,让生成的合约地址更具有可控性,通过 CREATE2 可以延伸出很多新的玩法,这篇文章来探讨下,在广义状态通道中的妙用...状态通道则可以基于特定应用程序的状态进行链下交互(而不仅仅是支付信息), 如果可以部署一个游戏合约定义游戏规则并抵押资金,玩家可以在链下玩游戏(每进行一步游戏签名发给对方), 游戏结束时,只需要把最后的状态提交给合约...刚刚上面介绍的状态通道,都是基于特定目的的通道,抵押的资金只能根据实现定义好的合约逻辑进行分配,而广义状态通道则是使用一个强大的多签钱包,可以根据其他合约定义的规则来进行资金的分配,从而实现更加通用的目的...通过使用 CREATE2,可以在游戏合约不上链的情况下进行游戏,因为只要游戏的规则代码确定了,就可以确定游戏合约的地址,在链下就可以基于这个确定的合约地址进行签名玩游戏,甚至我们根本不需要部署游戏合约,...Counterfactual 官方的一个介绍是,在状态通道中,一个“Counterfactual X” 代表: •X 可以在链上发生,但它并没有。•任何参与者都可以单方面使得 X 在链上发生。

    1.4K20

    原创|Android Jetpack Compose 最全上手指南

    将Jetpack Compose 添加到现有项目 如果你想在现有的项目中使用Jetpack Compose,你需要配置一些必须的设置和依赖: (1)gradle 配置 在app目录下的build.gradle...创建一个支持Jetpack Compose的新应用 比起在现有应用中接入Jetpack Compose ,创建一个支持Jetpack Compose 的新项目则简单了许多,因为Android Studio...在原来的安卓原生布局中,显示图片有相应的控件ImageView,设置本地图片地址或者Bitmap就能展示,在Jetpack Compose 中该如何显示图片呢?...添加间距Spacer 我们看到,图片和文本之间没有间距,传统布局中,我们可以添加Margin属性,设置间距,在Jetpack Compose 中,我们可以使用HeightSpacer()和WidthSpacer...六、Compose 布局实时预览 从Android Studio 4.0 开始,提供了在IDE中预览composable函数的功能,不用像以前那样,要先下载一个模拟器,然后将app状态模拟器上,运行app

    6.4K20

    如何使用 TSX 在 Node.js 中本地运行 TypeScript

    您可以在官方文档中了解有关此功能的更多信息,包括使用转换示例。TSXTSX是我们的ts-node的最新和最改进版本,它使用ESBuild快速将TS文件转译为JS。...最有趣的部分是,TSX被开发为Node的完整替代品,因此您实际上可以将TSX用作TypeScript REPL,只需使用npm i -g tsx全局安装它,在终端中运行tsx,然后就可以原生地编写TSX...TSX作为加载器通过加载器运行一个文件(或所有文件)很简单,只需在package.json中创建一个启动脚本,并使用以下内容:"scripts": { "start": "node --loader...使用TSX作为加载器不允许将其与其他选项一起使用,例如观察模式。扩展功能自Node 20.6版本以来,我们可以直接加载.env文件中存在的环境配置文件。但如何同时使用加载器和配置文件呢?...重要提示:直接从磁盘加载TS文件并使用加载器进行编译比先进行转译然后直接传递JavaScript文件要慢得多,因此建议仅在开发环境中执行此操作。

    2.7K10

    Jetpack Glance Alpha 版现已推出

    现在,我们发布了 Jetpack Glance 的第一个 Alpha 版,让 Widgets 的构建过程变得更加轻松,该版本是建立在 Jetpack Compose 运行时 (Runtime) 之上的新框架...Glance 提供了新式声明性 Kotlin API,其类似于您在 Jetpack Compose 中使用的 API,能够帮助您用更少的代码构建更美观的自适应 App Widgets。...但是,您可以分享应用中的状态或任何其他逻辑,以此来打造一目了然的界面。...可以查看 在 Android 12 中构建新式 Android App Widgets 视频了解更多详细信息。 Glance 使用入门 您可以在 GitHub 上查看 示例,以便快速入门。...也可以在最新的 稳定版 Android Studio 中使用 Glance,但首先需要按照 Jetpack Compose 文档 中的步骤进行设置,因为 Glance 依赖于 Compose 运行时 (

    84210

    安卓软件开发:怎么快速上手JetPackComposeUI框架

    在这个框架中,开发者通过编写函数来描述 UI,不再需要依赖复杂的 XML 布局文件。接下来,通过几个关键步骤,帮助你快速上手 Jetpack Compose,在实际项目中充分发挥它的优势。...二、Jetpack Compose的基础准备 在开始使用 Jetpack Compose 之前,首先需要确保开发环境的配置正确。...启用 Compose:在项目的 build.gradle 文件中启用 Jetpack Compose: buildFeatures { compose true } 3....添加依赖项:在项目的 dependencies 块中添加 Jetpack Compose 的必要依赖项: dependencies { implementation "androidx.compose.ui...四、状态管理与重组 Jetpack Compose 提供了简洁的状态管理机制。开发者只需声明状态,使用 remember 和 mutableStateOf 跟踪状态的变化。

    44000

    谷歌大佬强势分享《Jetpack Compose 权威指南》,带你参透声明式UI的终极奥义!

    是的,这些东西我们依然在 Compose 中运用,从而降低我们的上手难度。...Android Jetpack 的支持 在 Compose 刚刚发布的时候,Android Jetpack 中的很多其他库都第一时间给予了 Compose 支持,从而丰富了 Compose 的开发生态。...上跟 UI 不相关的库 Compose 应该都是支持的,在我写的Hoo中,就使用了Paging、Navigation、ViewModel和LiveData等 Android Jetpack 库,再有协程和...在谷歌官方的 《Jetpack Compose 使用前后对比》 一文说道:Tivi应用在使用了 Compose 后,我们发现 APK 大小缩减了 41%,方法数减少了 17%。...Jetpack Compose应用做一个倒计时器 数据结构 倒计时功能 状态模式 Compose 布局 绘制时钟 4.

    4.6K30

    Compose 线上分享会内容

    使用声明式 API,可以显示声明组件与状态,并且可以很直观的查看状态在组件上的流转。...3、强大的兼容性 原生可以嵌套 Compose,Compose 可以嵌套原生,并且可以无缝的使用 Jetpack 组件,例如 ViewModel、LiveData、Flow 等 Compose 中嵌套原生...View 原理 二、如何学习 Compose 学习一门框架的几个步骤: 官方学习资料: 了解官方走向:Jetpack Compose 路线图[3] 了解 Compose 的样貌:使用 Jetpack...探索 Compose 内核:深入 SlotTable 系统 揭秘 Jetpack Compose 快照系统 实践 | Jetpack Compose 中的状态管理 深度解析 Jetpack Compose...不过话也说回来,Jetpack Compose 容器依然是一个 ViewGroup,没有脱离原生 View 体系,我觉得,问题应该不会太大,最多就是代码使用不当,重组作用域扩大,导致页面卡顿,但这种在开发期间是可以通过调试和监控可发现的

    1.2K10

    2025年Android开发趋势全景解读

    一、界面开发:从"手写代码"到"智能拼装" 1.1 Jetpack Compose实战进化 案例1:电商商品详情页 传统方案需要为手机/平板/折叠屏分别写布局文件,现在通过@OptIn(ExperimentalLayoutApi...模块 性能对比:RecyclerView在折叠屏设备滑动帧率下降至45fps,而LazyColumn稳定60fps 开发效率:某外卖App改用Compose后,详情页开发周期从2周缩短至3天 二、AI融合开发...进阶 完成Google Codelab所有Compose案例 《Compose从入门到实战》电子书 2024Q4 设备端AI集成 在现有项目添加图像分割功能 ML Kit官方文档 + Kaggle微调模型...8以下语法:Android Studio将屏蔽非Java 17项目 5.2 真实案例:某新闻App的惨痛教训 2024年未适配Compose → 2025年被Play商店下架 损失:日活从200万暴跌至...那些能快速掌握Compose、设备端AI、车载开发三大核心技能的程序员,将在新一轮技术浪潮中占据先机。记住:在这个AI生成代码的时代,架构设计能力和硬件理解深度将成为不可替代的竞争力。

    27420

    安卓软件开发:使用AndroidView(MDC)实现高级轮播图App-下篇

    在 MDC 中,状态管理相对来说很直接,比如处理图像选择或动态显示状态时,只需简单通过 setImageResource() 等 API 操作。...但在 Jetpack Compose 中,使用 remember 和 mutableStateOf 可以更方便管理状态,状态变化会自动重新组合 UI。...在 Jetpack Compose 中,实现类似动画效果可以通过 animate*AsState 或 LaunchedEffect 管理 UI 变化。...但近年来,Jetpack Compose 的出现彻底改变了我们构建界面的方式。这两者在开发方式、状态管理、布局处理和性能优化等方面都有明显的区别。...这种手动操作会导致代码更加重复且容易出错,特别是在处理复杂状态时。 Jetpack Compose:自动重新组合 UI Compose 的状态管理很简单。

    60281
    领券