首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >尊重LazyColumn的MotionEvent.ACTION_SCROLL

尊重LazyColumn的MotionEvent.ACTION_SCROLL
EN

Stack Overflow用户
提问于 2022-03-03 13:12:12
回答 1查看 93关注 0票数 0

如何强制组成‘LazyColumn’像传统的可滚动元素,如RecyclerView或ListView?

当想用鼠标滚动时很有用,例如用vysor。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-04-26 11:03:27

解决方案是在修饰符中添加筛选器。

代码语言:javascript
复制
const val VERTICAL_SCROLL_MULTIPLIER = -4

// Helps with scrolling with mouse wheel (just like recycler view/list view without compose)
@ExperimentalComposeUiApi
@Composable
fun MyLazyColumn(
    modifier: Modifier = Modifier,
    state: LazyListState, // rememberLazyListState()
    content: LazyListScope.() -> Unit
) {
    LazyColumn(
        state = state,
        modifier = modifier
            .pointerInteropFilter {
                if (it.action == MotionEvent.ACTION_SCROLL) {
                    state.dispatchRawDelta(it.getAxisValue(MotionEvent.AXIS_VSCROLL) * VERTICAL_SCROLL_MULTIPLIER)
                }
                false
            },
        content = content
    )
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71337795

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档