Rob*_*Rob 5 android kotlin android-jetpack-compose
找不到任何示例代码。因为我没有看到任何手势类,所以我只是去了常规文档和那些关于 Activity setup a 的中心GestureRecognizerCompat
,这不起作用。设置它有效,但不会检测滑动或点击(在模拟器中)。在 SwiftUI 中有手势处理程序。在 Compose Slack Channel 上询问并被告知寻找FooGestureDetector
可组合的功能。
寻找一些示例代码。终于有一个 Compose 教程了,它的内容很好,但是当你完成后,你的应用程序做的很少。我还查看了 GitHub 上的示例项目,该项目用于为新闻站点创建帖子。有一些有趣的东西,但没有手势。
主要目标只是拥有多个Card
s 并能够通过它们滑动(la ViewPager
(1/2) 在 Compose 中也不可用)。
我确实设法检测到对视图的点击,如下所示:
@Composable
fun PreviewPane(name: String, info:String) {
val pagenumber = +state { 0 }
CustomTheme{
Column(
crossAxisSize = LayoutSize.Expand,
modifier = Spacing(16.dp)
) {
Clickable(onClick = { Log.d("DEMO", "click detected..")}) {
Text(text = name, style = TextStyle(fontWeight = FontWeight.Bold))
Text(text = info)
Text(text = "${pagenumber.value}")
}
Row {
Button(text = "Back", onClick = {
if (pagenumber.value > 0) pagenumber.value--
Log.d("DEMO", "button clicked..")
})
Button(text = "Next", onClick = {
pagenumber.value++
Log.d("DEMO", "button clicked..")
})
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
这有效,我确实看到了日志消息(注意我没有用Click
指令包装按钮)。但我真正想要的是外部视图的滑动检测,它包含所有这些组件。
@Rob如果您只需要查看分页器,您可以检查ViewPager的Gist,我为ViewPager创建一个示例,请从下面的Gist和示例中复制ComposeViewPager.kt.kt。
注意:我从Leland Richardson Git 存储库获取此代码并根据我的需要进行修改。
前任:
val listItem = arrayListOf<String>("One", "Two", "Three", "Four", "Five")
@Composable
fun FullViewPagerSample() {
Box {
ViewPager(
items = listItem
) { listItem, itemWidthInDp ->
ViewItem(
item = listItem,
normalWidth = itemWidthInDp
)
}
}
}
@Composable
fun ViewPagerSample() {
val configuration = ConfigurationAmbient.current
val screenWidth = configuration.screenWidthDp.dp
val posterWidthDp = screenWidth * 0.6f
Box {
ViewPager(
items = listItem, width = posterWidthDp
) { listItem, itemWidthInDp ->
ViewItem(
item = listItem,
normalWidth = itemWidthInDp
)
}
}
}
@Composable
fun ViewPagerSampleWithYDeltaAnimation() {
val configuration = ConfigurationAmbient.current
val screenWidth = configuration.screenWidthDp.dp
val posterWidthDp = screenWidth * 0.6f
Box {
ViewPager(
items = listItem, width = posterWidthDp, bottomYDelta = 50f
) { listItem, itemWidthInDp ->
ViewItem(
item = listItem,
normalWidth = itemWidthInDp
)
}
}
}
@Composable
fun ViewItem(
item: String,
normalWidth: Dp,
modifier: Modifier = Modifier,
isScrollable: Boolean = true
) {
ScrollableColumn(
modifier = modifier
.width(normalWidth)
.padding(10.dp)
.clip(RoundedCornerShape(10.dp))
.background(Color.Red),
contentPadding = PaddingValues(posterPadding),
isScrollEnabled = isScrollable,
horizontalAlignment = Alignment.CenterHorizontally
) {
Text(
item,
fontSize = 24.sp,
color = Color.White
)
}
}
Run Code Online (Sandbox Code Playgroud)
结果会是这样的,
归档时间: |
|
查看次数: |
1712 次 |
最近记录: |