向 Compose View 添加滑动手势处理

Rob*_*Rob 5 android kotlin android-jetpack-compose

找不到任何示例代码。因为我没有看到任何手势类,所以我只是去了常规文档和那些关于 Activity setup a 的中心GestureRecognizerCompat,这不起作用。设置它有效,但不会检测滑动或点击(在模拟器中)。在 SwiftUI 中有手势处理程序。在 Compose Slack Channel 上询问并被告知寻找FooGestureDetector可组合的功能。

寻找一些示例代码。终于有一个 Compose 教程了,它的内容很好,但是当你完成后,你的应用程序做的很少。我还查看了 GitHub 上的示例项目,该项目用于为新闻站点创建帖子。有一些有趣的东西,但没有手势。

主要目标只是拥有多个Cards 并能够通过它们滑动(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指令包装按钮)。但我真正想要的是外部视图的滑动检测,它包含所有这些组件。

Mut*_*ran 4

@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)

结果会是这样的,

在此输入图像描述