androidandroid-softkeyboardandroid-jetpack-compose-lazy-columnandroid-jetpack-compose

How to automatically scroll LazyColumn when the keyboard goes up or down in Android


I am making a chatting app with android compose.

Usually, when you scroll freely within the chat window and press the text input window to bring up the keyboard, the chat at the bottom of the screen naturally moves up.

I tried to implement it naturally, but it didn't work out well.

I tried using rememberLazyListState() to input scrollOffset using listState.scrollToItem or listState.animationScrollToItem, but it feels quite unnatural.

How can we implement natural LazyColumn scrolling?

[EDIT] I think additional explanation is needed, so I'll attach a photo. enter image description here Can you see the chat slightly overlapping the input window like that before the keyboard comes up? enter image description here

Even when the keyboard comes up, can you see that the chat is still uploaded, overlapping with the input window?

This is how I want it. I want the last chat I was viewing to scroll on the screen even if the keyboard is raised or lowered. The photo was taken from Telegram.


Solution

  • For original setting of LazyColumn, when LazyColumn's viewport size changed, Compose will try to conserve top messages visible on view.

    For some special cases like chat app, when LazyColumn's viewport size changed and you want to make bottom messages visible, you can use field reverseLayout

                     LazyColumn(
                        modifier = Modifier,
                        reverseLayout = true,
                        state = lazyListState
                    ) {
                        ...
                    }
    

    Of course you have to change some of logic to fit your business, but this layout is the best fit for Chat app.

    Hope you find it useful.