“玩弄一下”Android Jetpack Compose 中的 Snackbar
compose
compose - Docker Compose是一个用于定义和运行多容器Docker应用程序的工具,通过Compose文件格式简化应用部署过程。
项目地址:https://gitcode.com/gh_mirrors/compose/compose
免费下载资源
·
开始写Compose的时候,真的有点不习惯。思考方式和以前完全不同,有点类似ReactNative。 写习惯了之后,还真有点欲罢不能,行云流水~
Snackbar感觉就是Toast Plus版,可以自定义视图,还可以进行交互,可以用在很多地方实现意想不到的效果。
主要的实现思路有两部步:
1.Snackbar的控制逻辑
2.Snackbar的UI部分
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
actionBar?.hide()
setContent {
ContentView(Modifier.fillMaxSize())
}
}
}
@Composable
fun ContentView(modifier: Modifier) {
val context = LocalContext.current
val snackBarState = remember {
SnackbarHostState()
}
val coroutineScope = rememberCoroutineScope()
Surface(
color = Color.DarkGray,
modifier = modifier.fillMaxSize()
) {
Box(modifier = modifier.fillMaxSize()) {
Button(
modifier = modifier
.align(Alignment.Center)
.wrapContentSize()
,
onClick = {
coroutineScope.launch {//showSnackbar为suspend函数,要在协成调用
snackBarState.showSnackbar("")
}
},
colors = ButtonDefaults.buttonColors(
backgroundColor = Color.White,
contentColor = Color.Black
)
) {
Text(text = "显示SnackBar", fontSize = 16.sp)
}
SnackbarHost(
modifier = modifier.align(Alignment.BottomCenter),
hostState = snackBarState
) {
// custom snackBar
CustomSnackBar(
title = "我是绿色大米呀",
content = "关注点一波~下次不迷路哦!",
profileImageResource = R.drawable.head,
actionImageResource = R.drawable.back_black_bg,
onAction = {}
)
}
}
}
}
@Composable
fun CustomSnackBar(
modifier: Modifier = Modifier,
title: String,
content: String,
profileImageResource: Int,
actionImageResource: Int,
onAction: () -> Unit
) {
Snackbar(
elevation = 0.dp,//去掉阴影
backgroundColor = Color.Transparent
) {
Box(
modifier = modifier
.fillMaxWidth()
.wrapContentHeight()
) {
Column(
modifier = modifier
.padding(top = 10.dp)
.fillMaxWidth()
.clip(RoundedCornerShape(10.dp))
.background(
Brush.verticalGradient(
colors = listOf(
Color(android.graphics.Color.parseColor("#0ac1ff")),
Color(android.graphics.Color.parseColor("#fb2c38"))
)
)
)
.padding(start = 78.dp, top = 8.dp, bottom = 12.dp, end = 8.dp),
horizontalAlignment = Alignment.Start
) {
Text(
modifier = modifier.
padding(top = 5.dp),
text = title,
color = Color.White,
fontWeight = FontWeight.Bold,
fontSize = 22.sp
)
Spacer(modifier = modifier.padding(vertical = 2.dp))
Text(
text = content,
color = Color.White,
fontStyle = FontStyle.Italic,
fontSize = 15.sp
)
}
Column(
modifier = modifier
.padding(start = 16.dp),
horizontalAlignment = Alignment.CenterHorizontally
) {
Card(
elevation = 6.dp,
shape = RoundedCornerShape(8.dp)
) {
Image(
painter = painterResource(profileImageResource),
contentScale = ContentScale.Crop,
contentDescription = null,
modifier = modifier.size(50.dp)
)
}
}
Image(
painter = painterResource(actionImageResource),
contentDescription = null,
contentScale = ContentScale.Fit,
modifier = modifier
.align(Alignment.BottomEnd)
.padding(bottom = 10.dp, end = 10.dp)
.size(23.dp)
.rotate(180f)
.clickable(
interactionSource = MutableInteractionSource(),
indication = null,
onClick = onAction
)
)
}
}
}
不知道为什么,我的这个Snackbar一直出现在屏幕顶部,我想让它出现在底部,不知道哪里写错了,知道怎么处理的jym留言给我哦~
作者:我是绿色大米呀
本文转自 [https://juejin.cn/post/7186945452058050619]
最后
如果想要成为架构师或想突破20~30K薪资范畴,那就不要局限在编码,业务,要会选型、扩展,提升编程思维。此外,良好的职业规划也很重要,学习的习惯很重要,但是最重要的还是要能持之以恒,任何不能坚持落实的计划都是空谈。
如果你没有方向,这里给大家分享一套由阿里高级架构师编写的《Android八大模块进阶笔记》,帮大家将杂乱、零散、碎片化的知识进行体系化的整理,让大家系统而高效地掌握Android开发的各个知识点。
相对于我们平时看的碎片化内容,这份笔记的知识点更系统化,更容易理解和记忆,是严格按照知识体系编排的。
全套视频资料:
一、面试合集
二、源码解析合集
三、开源框架合集
欢迎大家一键三连支持,若需要文中资料,直接点击文末CSDN官方认证微信卡片免费领取↓↓↓
GitHub 加速计划 / compose / compose
33.27 K
5.15 K
下载
compose - Docker Compose是一个用于定义和运行多容器Docker应用程序的工具,通过Compose文件格式简化应用部署过程。
最近提交(Master分支:2 个月前 )
501b5acd
Add `jhrotko` to Core Maintainers.
Signed-off-by: Laura Brehm <laurabrehm@hey.com>
9 天前
f51bc4cd
Signed-off-by: Guillaume Lours <705411+glours@users.noreply.github.com>
10 天前
更多推荐
已为社区贡献4条内容
所有评论(0)