前言 Jetpack Compose光下拉刷新,官方就提供了三种不同的方式,使用的依赖也不相同,特别的混乱。 所以在网络上看到的示例可能找不到依赖就是这个原因。....fillMaxWidth() .height(200.dp), onRefresh = { isRefreshing = true // 在协程作用域中启动异步任务...Text(text = index.toString()) } } } } PullToRefreshContainer 把libs.version.toml中的...) 替换为 implementation(libs.androidx.material3.android) 两者的对比 material3是标准的库,能保证在各个平台上迁移代码,而material3-android...https://developer.android.google.cn/jetpack/androidx/releases/compose-material3?
前言 Jetpack Compose 中的列表组件相对于之前的View方式要简单很多。...modifier = Modifier.padding(16.dp).height(30.dp), ) { Text(text) } } 注意 竖向Grid布局中的子项...,也就是上面的GridItem中的根组件的宽度是自动使用父的,设置宽度不会生效。...modifier = Modifier.padding(16.dp).height(30.dp), ) { Text(text) } } 注意 竖向Grid布局中的子项...,也就是上面的GridItem中的根组件的高度是自动使用父的,设置高度不会生效。
前言 Jetpack Compose中想更新界面上的任何东西都需要重组,重组本质就是再执行一次当前函数。...触发重组方式有 State值改变 调用方法刷新 State 创建State有以下几种方式 注意 只有在Kotlin中才能生效,在Java中是不行的。..." //还有一种更常用的写法,使用by关键字,by是kotlin的语法糖 var user:User by mutableStateOf(User()) //State的by是对stete.value的包装...//不会更新 list[index].name = "new value" //会更新 list[index] = list[index].copy(name = "new value") List的中括号...调用方法 在Composable函数中使用currentRecomposeScope获得RecomposeScope对象,在需要的地方执行recomposeScope.invalidate()即可重组所在作用域
前言 在 Compose 中,Modifier 的调用顺序是有影响的。...修饰符列表 https://android-dot-google-developers.gonglchuangl.net/jetpack/compose/modifiers-list?...hl=zh-cn 背景 Modifier.background(Color.Green)) 内外边距和背景 在 Compose 中,背景色使用 Modifier.background() 进行设置。...在 Compose 中,Margin 和 Padding 都用 Modifier.padding() 来设置。...通常情况下,父容器需要使用相应的布局修饰符,如 Box 中的 BoxScope、Column 中的 ColumnScope 或 Row 中的 RowScope。
https://developer.android.google.cn/jetpack/compose/designsystems/material3?...Compose 中的一个重要概念,用于向整个组合树(Compose tree)提供特定类型的值。...在 Compose 中,组合树是由各种组合函数(如 @Composable 标记的函数)构成的层级结构,用于描述应用程序的 UI 层次结构。...这使得在组合树中任何地方都能够访问到这些值,而不需要手动传递它们。...总的来说,CompositionLocalProvider 用于在组合树中传递局部值,使得这些值对于整个组合树中的任何组件都可用,而不需要显式传递。
图片的区域添加着色。...id = R.drawable.logo), contentDescription = null, contentScale = ContentScale.Crop, ) 背景剪裁 图片的背景是不会被剪裁的...github.com/coil-kt/coil Coil官方文档:https://coil-kt.github.io/coil 基本图片 添加依赖 implementation("io.coil-kt:coil-compose...modifier = Modifier.clip(CircleShape).size(60.dp) ) } 加载GIF 添加引用 implementation("io.coil-kt:coil-compose...builder = { crossfade(true)//淡出效果 }), contentDescription = null ) 自带的加载中
这些可组合项的功能与视图系统中的 ViewPager类似。...官方文档: https://android-dot-google-developers.gonglchuangl.net/jetpack/compose/layouts/pager?...text = "Page: $page", modifier = Modifier.fillMaxWidth() ) } 页面切换添加效果 该示例实现了切换时页面从半透明到不透明的效果...androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.snapshotFlow import androidx.compose.ui.Alignment...如需在屏幕外加载更多页面,请将 beyondBoundsPageCount 设置为大于零的值。
前言 Jetpack Compose中的页面跳转和传值和之前没什么不同。 要注意的是 组件内尽量不要进行页面的跳转,组件可以设置回调方法,在Activity中进行页面跳转操作。...页面跳转 val intent = Intent(baseContext, AppDetailActivity::class.java) startActivity(intent) 这里要注意的是,获取上下文使用的是...在 Android 中,可以通过 Intent 来传递自定义对象,前提是该对象必须实现 Serializable接口。...Serializable接口允许对象在不同组件间进行序列化和反序列化,以便通过 Intent 进行传递。
,不要错过 :-)Jetpack Compose 中的状态State是什么在 Jetpack 中,state表示一个和 UI 状态相关的值。...通过修改状态更新可组合项目随着我们越多地使用 Compose 自带的可组合项(如Scaffolds、BottomSheet、Drawer等),我们会意识到在 Jetpack Compose 中状态是无处不在的...这是 Jetpack Compose 中很常见的修改状态的模式。...附加内容:在 Jetpack Compose 中,如何使用 Kotlin 的 Flow、RxJava 或者 LiveData 表示状态?...Jetpack Compose 允许我们使用 LiveData、RxJava 的观察者、Kotlin 的 Flow 来表示 Jetpack Compose 中的状态。
前言 除了布局组件外,Jetpack Compose 还提供了一系列其他常用的 UI 组件。...https://developer.android.google.cn/jetpack/compose/components?...图片的区域添加着色。...contentScale = ContentScale.Crop, modifier = Modifier.clip(CircleShape).size(60.dp) ) } 加载中动画...val keyboardController = LocalSoftwareKeyboardController.current // 在需要隐藏键盘的地方调用这个函数 fun hideKeyboard
处理点击事件 Box( modifier = Modifier.clickable { // 处理点击事件 } ) Modifier.combinedClickable 在单击事件之外...中处理所有手势事件的入口,类似传统视图的 onTouch 。...,这有时候和我们的页面不太搭,这里就禁用该效果。...import android.annotation.SuppressLint import androidx.compose.foundation.clickable import androidx.compose.foundation.interaction.MutableInteractionSource...import androidx.compose.runtime.remember import androidx.compose.ui.Modifier import androidx.compose.ui.composed
前言 ViewModel 和 remember 是 Jetpack Compose 中用于管理数据的两种不同机制。...remember/rememberSaveable 在Compose中,remember和rememberSaveable都是用于保存可组合函数的状态的方法,但它们在如何保存状态以及在什么情况下会重新计算状态上有所不同...mutableStateOf/mutableStateListOf mutableStateOf 是 Jetpack Compose 中的一个函数,用于创建可变的状态。...总的来说: mutableStateOf 的作用是在 Jetpack Compose 中创建可变的状态,以便动态更新 UI,并确保 UI 反映最新的状态值。...,能不能让我们的ViewModel的实例在一个类中是同一个实例呢?
Compose 在社区中的反响 我们看到 许多公司已经在大规模采纳 Compose 为其应用开发最新、最具创造性的功能。...与此同时,Twitter 也已经在应用的不同部分使用了 Jetpack Compose 并从中受益,因为 "Compose 让我们更容易定义自己的组件,并使它们的 API 更明确、灵活和直观。"...我们很高兴地看到这些团队在大规模和复杂的生产环境中仔细地评估并使用了 Compose,所带来的结果也不仅是让界面开发更清晰有趣,也带来了更多工程上的收益。...在 I/O 演讲 Jetpack Compose 中常见的性能问题 中,Compose 团队介绍了常见的性能错误以及这些错误的解决方法。...Codelab 全新的 Compose 性能说明文档 更新的 自定义输入文档 I/O 演讲视频: Jetpack Compose 中常见的性能问题 以及 Compose 中的惰性布局 对于新手开发者,
前言 Jetpack Compose 提供了一系列用于构建用户界面的布局组件,这些组件可以帮助您创建各种复杂的布局结构。...对应关系 View Jetpack Compose FrameLayout Box& Modifier RelativeLayout Box & Modifier LinearLayout Row, Column...ConstraintLayout ConstraintLayout 移植到了 Compose 中 RecyclerView LazyColumn or LazyRow ScrollView Modifier.verticalScroll...() or Modifier.horizontalScroll() 层叠布局 Box: Box 是一个简单的布局组件,用于在单个平面上叠加子元素。...功能和用途: Surface 是一个基本的容器,用于在屏幕上绘制内容。它提供了绘制颜色、形状、边框等的基本功能。 通常用于创建自定义的UI元素,例如背景、容器等。
随着 Jetpack Compose 的流行,越来越多的开发者开始转向这种全新的声明式 UI 框架。作为一名聋人独立开发者,我一直在探索新的技术和工具,提高自己的技能和工作效率。...在这篇文章中,我分享使用 Jetpack Compose 和 Material 3 实现一个高级的 NimNavBottomApp 的开发过程,为大家提供开发灵感和实践经验。...3.2 徽章的动态更新 需要根据用户的操作或者后端的反馈,动态更新每个导航项的通知徽章。为此,通过一个Map存储每个页面的通知数量,根据页面的变化动态显示或隐藏徽章。...四、学习笔记 在这个Demo开发过程中,我掌握了如何在 Jetpack Compose 中处理复杂的状态管理,虽然学习成本较高,但掌握了 Compose 的核心思想,很方便开发。...无论是徽章通知的处理,还是底部导航栏与页面内容的同步显示,Jetpack Compose 都提供了简洁高效的解决方案。 有任何问题欢迎提问,感谢大家阅读 )
如下是官方使用 Baseline Profiles 在应用启动上提升的百分比,来自 《 Performance best practices for Jetpack Compose[1]》: 官方提供的数据非常吸引人...在模块目录中的结构如下,与 AndroidManifest.xml 同级: 2、编译时 在编译阶段,AGP 会将所有的依赖的 baseline-profile.txt 合并成一个文件,然后编译输出...,在我之前的文章中有介绍 AGP 4.2.x 版本是支持正式版 Compose 的,但在看 4.2.x 版本源码的时候,是没有 ART Profiles 相关的 task 的,这也说明,在 AGP 4.2...不过也有解决办法,那就是在高版本的 AGP 中打包,然后将 apk 里 assets 下的 baseline.prof 文件提取出来,放入到自己项目即可。...参考资料 [1] Performance best practices for Jetpack Compose: https://www.youtube.com/watch?
Jetpack Compose for Desktop 使用过程中遇到的几个大坑 最近在用 Jetpack Compose for Desktop 写一些好玩的,用的时候遇到了很多大坑,在这里总结如下:...@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....改用其他类型图片,如 PNG @see https://github.com/JetBrains/compose-jb/issues/1217 SVG 图片宽高比被错误计算导致 SVG 图片缩放不符合预期
Kotlin中的Jetpack Compose是用于构建Android用户界面的声明式UI工具包。它通过Kotlin语言来编写界面,旨在简化和加速UI开发过程。...下面我们来看看关于Jetpack Compose的核心概念、主题和样式、导航和预览功能: 核心概念 1、 声明式UI: Jetpack Compose采用了声明式编程范式,允许开发者描述UI的外观和状态...} 3、 State管理: Jetpack Compose的核心思想之一是界面应该响应状态的变化。...使用Compose中的状态机制(例如remember和mutableStateOf),可以轻松创建动态和响应式UI。...Compose有自己的导航组件,用于在不同屏幕之间导航。
关于DNSStager DNSStager是一个基于Python开发的开源项目,可以帮助广大研究人员使用DNS来隐藏和传输Payload。...DNSStager可以创建一个恶意DNS服务器,并负责处理我们域名相关的DNS请求,然后将Payload隐藏在响应中的指定记录请求中,比如说“AAAA”记录或“TXT”记录,而且DNSStager还会使用各种不同的算法来对...DNSStager能够生成基于C或Golang的自定义代理,主要负责解析一系列域名、获取Payload、解码Payload,并将其注入至内存中。...DNSStager核心功能 在IPv6记录中隐藏和解析Payload; 在TXT记录中隐藏和解析Payload; 使用异或编码器编码Payload; 使用Base64编码器编码Payload; 纯C开发的代理...,支持自定义配置; 纯Golang开发的代理,支持自定义配置; 支持在每个DNS请求间隔一定休眠时间; 更多功能即将上线… 工具要求 我们可以使用下列命令来安装DNSStager所需的Python依赖:
介绍 在当前的数字时代,安全至关重要。在我们作为开发人员的工作中,我们经常处理密码等机密数据。必须使用正确的密码加密和隐藏方法来保护这些敏感数据。...Python 中许多可访问的技术和模块可以帮助我们实现这一目标。通过对可用实现的基本思想和示例的解释,本文研究了在 Python 中隐藏和加密密码的最佳技术和方法。...隐藏密码:使用获取通行证模块 保护密码的第一步是防止用户输入密码时它们显示在屏幕上。Python 中的 getpass 模块提供了一种简单有效的方法来实现这一目标。...结论 保护密码是应用程序安全性的一个关键方面。通过在 Python 中实现有效的密码隐藏和加密技术,我们可以显著增强应用程序的安全性并保护用户凭据。...从在输入过程中隐藏密码到散列、加盐和采用安全加密算法,有多种方法可用于保护密码。必须了解每种技术的优缺点和局限性,并根据应用的具体要求适当地应用它们。
领取专属 10元无门槛券
手把手带您无忧上云