Reverse AppBarLayout.ScrollingViewBehavior












4















I have a ToolBar and Recyclerview wrapped in a Coordinatorlayout. The RecyclerView is populated with messages from our api and are stacked from the bottom. (Like a chat application)



 //Set the layout manager
LinearLayoutManager layoutManager = new LinearLayoutManager(requireContext());
layoutManager.setStackFromEnd(true);
layoutManager.setReverseLayout(true);
binding.listMessages.setLayoutManager(layoutManager);


I'd like to define a custom ReverseScrollBehavior by overriding the AppBarLayout.ScrollingViewBehavior to inverse it's behavior.
So when I scroll up, the toolbar hides and when I scroll back down (to the bottom) the toolbar shows.



<androidx.recyclerview.widget.RecyclerView
android:id="@+id/list_messages"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="none"
app:stackFromEnd="true"
app:reverseLayout="true"
app:layout_behavior="com.rootsoft.kot.utils.ReverseScrollBehavior" />


I'd like to use the ScrollingViewBehavior for this rather then overriding the onTouch



UPDATE



What I'm trying to achieve is to get the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown and when you scroll back down, it hides.
My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"










share|improve this question

























  • I'm just trying to do the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown. My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"

    – Verhelst
    Nov 19 '18 at 13:39













  • @Cheticamp I've already created a ReverseScrollBehavior extending the AppBarLayout.Behavior but I don't know which methods to override in order to achieve the effect that . I'm looking for.

    – Verhelst
    Nov 19 '18 at 13:42











  • I think appbar_scrolling_view_behavior dose the same what you want. When you scroll up, It hides the toolbar.

    – Rumit Patel
    Nov 22 '18 at 13:45











  • @RumitPatel It depends on the context of scrolling up. I mean when the content scrolls up. so when you drag your finger from the center to the bottom, you scroll the content up, I want to hide the toolbar.

    – Verhelst
    Nov 23 '18 at 14:35


















4















I have a ToolBar and Recyclerview wrapped in a Coordinatorlayout. The RecyclerView is populated with messages from our api and are stacked from the bottom. (Like a chat application)



 //Set the layout manager
LinearLayoutManager layoutManager = new LinearLayoutManager(requireContext());
layoutManager.setStackFromEnd(true);
layoutManager.setReverseLayout(true);
binding.listMessages.setLayoutManager(layoutManager);


I'd like to define a custom ReverseScrollBehavior by overriding the AppBarLayout.ScrollingViewBehavior to inverse it's behavior.
So when I scroll up, the toolbar hides and when I scroll back down (to the bottom) the toolbar shows.



<androidx.recyclerview.widget.RecyclerView
android:id="@+id/list_messages"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="none"
app:stackFromEnd="true"
app:reverseLayout="true"
app:layout_behavior="com.rootsoft.kot.utils.ReverseScrollBehavior" />


I'd like to use the ScrollingViewBehavior for this rather then overriding the onTouch



UPDATE



What I'm trying to achieve is to get the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown and when you scroll back down, it hides.
My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"










share|improve this question

























  • I'm just trying to do the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown. My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"

    – Verhelst
    Nov 19 '18 at 13:39













  • @Cheticamp I've already created a ReverseScrollBehavior extending the AppBarLayout.Behavior but I don't know which methods to override in order to achieve the effect that . I'm looking for.

    – Verhelst
    Nov 19 '18 at 13:42











  • I think appbar_scrolling_view_behavior dose the same what you want. When you scroll up, It hides the toolbar.

    – Rumit Patel
    Nov 22 '18 at 13:45











  • @RumitPatel It depends on the context of scrolling up. I mean when the content scrolls up. so when you drag your finger from the center to the bottom, you scroll the content up, I want to hide the toolbar.

    – Verhelst
    Nov 23 '18 at 14:35
















4












4








4


0






I have a ToolBar and Recyclerview wrapped in a Coordinatorlayout. The RecyclerView is populated with messages from our api and are stacked from the bottom. (Like a chat application)



 //Set the layout manager
LinearLayoutManager layoutManager = new LinearLayoutManager(requireContext());
layoutManager.setStackFromEnd(true);
layoutManager.setReverseLayout(true);
binding.listMessages.setLayoutManager(layoutManager);


I'd like to define a custom ReverseScrollBehavior by overriding the AppBarLayout.ScrollingViewBehavior to inverse it's behavior.
So when I scroll up, the toolbar hides and when I scroll back down (to the bottom) the toolbar shows.



<androidx.recyclerview.widget.RecyclerView
android:id="@+id/list_messages"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="none"
app:stackFromEnd="true"
app:reverseLayout="true"
app:layout_behavior="com.rootsoft.kot.utils.ReverseScrollBehavior" />


I'd like to use the ScrollingViewBehavior for this rather then overriding the onTouch



UPDATE



What I'm trying to achieve is to get the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown and when you scroll back down, it hides.
My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"










share|improve this question
















I have a ToolBar and Recyclerview wrapped in a Coordinatorlayout. The RecyclerView is populated with messages from our api and are stacked from the bottom. (Like a chat application)



 //Set the layout manager
LinearLayoutManager layoutManager = new LinearLayoutManager(requireContext());
layoutManager.setStackFromEnd(true);
layoutManager.setReverseLayout(true);
binding.listMessages.setLayoutManager(layoutManager);


I'd like to define a custom ReverseScrollBehavior by overriding the AppBarLayout.ScrollingViewBehavior to inverse it's behavior.
So when I scroll up, the toolbar hides and when I scroll back down (to the bottom) the toolbar shows.



<androidx.recyclerview.widget.RecyclerView
android:id="@+id/list_messages"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="none"
app:stackFromEnd="true"
app:reverseLayout="true"
app:layout_behavior="com.rootsoft.kot.utils.ReverseScrollBehavior" />


I'd like to use the ScrollingViewBehavior for this rather then overriding the onTouch



UPDATE



What I'm trying to achieve is to get the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown and when you scroll back down, it hides.
My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"







android






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 19 '18 at 13:40







Verhelst

















asked Nov 14 '18 at 14:56









VerhelstVerhelst

76621537




76621537













  • I'm just trying to do the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown. My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"

    – Verhelst
    Nov 19 '18 at 13:39













  • @Cheticamp I've already created a ReverseScrollBehavior extending the AppBarLayout.Behavior but I don't know which methods to override in order to achieve the effect that . I'm looking for.

    – Verhelst
    Nov 19 '18 at 13:42











  • I think appbar_scrolling_view_behavior dose the same what you want. When you scroll up, It hides the toolbar.

    – Rumit Patel
    Nov 22 '18 at 13:45











  • @RumitPatel It depends on the context of scrolling up. I mean when the content scrolls up. so when you drag your finger from the center to the bottom, you scroll the content up, I want to hide the toolbar.

    – Verhelst
    Nov 23 '18 at 14:35





















  • I'm just trying to do the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown. My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"

    – Verhelst
    Nov 19 '18 at 13:39













  • @Cheticamp I've already created a ReverseScrollBehavior extending the AppBarLayout.Behavior but I don't know which methods to override in order to achieve the effect that . I'm looking for.

    – Verhelst
    Nov 19 '18 at 13:42











  • I think appbar_scrolling_view_behavior dose the same what you want. When you scroll up, It hides the toolbar.

    – Rumit Patel
    Nov 22 '18 at 13:45











  • @RumitPatel It depends on the context of scrolling up. I mean when the content scrolls up. so when you drag your finger from the center to the bottom, you scroll the content up, I want to hide the toolbar.

    – Verhelst
    Nov 23 '18 at 14:35



















I'm just trying to do the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown. My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"

– Verhelst
Nov 19 '18 at 13:39







I'm just trying to do the inverse of the current appbar_scrolling_view_behavior. Imagine having a chat application where the newest messages are starting from the bottom. When you scroll up, I want to hide the toolbar. The current situation with the AppBarLayout is when you scroll up, the toolbar is shown. My scrollflags are: app:layout_scrollFlags="scroll|enterAlways|snap"

– Verhelst
Nov 19 '18 at 13:39















@Cheticamp I've already created a ReverseScrollBehavior extending the AppBarLayout.Behavior but I don't know which methods to override in order to achieve the effect that . I'm looking for.

– Verhelst
Nov 19 '18 at 13:42





@Cheticamp I've already created a ReverseScrollBehavior extending the AppBarLayout.Behavior but I don't know which methods to override in order to achieve the effect that . I'm looking for.

– Verhelst
Nov 19 '18 at 13:42













I think appbar_scrolling_view_behavior dose the same what you want. When you scroll up, It hides the toolbar.

– Rumit Patel
Nov 22 '18 at 13:45





I think appbar_scrolling_view_behavior dose the same what you want. When you scroll up, It hides the toolbar.

– Rumit Patel
Nov 22 '18 at 13:45













@RumitPatel It depends on the context of scrolling up. I mean when the content scrolls up. so when you drag your finger from the center to the bottom, you scroll the content up, I want to hide the toolbar.

– Verhelst
Nov 23 '18 at 14:35







@RumitPatel It depends on the context of scrolling up. I mean when the content scrolls up. so when you drag your finger from the center to the bottom, you scroll the content up, I want to hide the toolbar.

– Verhelst
Nov 23 '18 at 14:35














1 Answer
1






active

oldest

votes


















0














You need to create a method that will get the height of the screen and scroll events (up and down.) You can also toggle the visibility in the method.
This means you will set visibility to visible in your XML and do something like:



    ChatButton Button;

ChatButtton.setVisibility = View.GONE
ChatButton.setVisibility = View.VISIBLE


to handle the toggle of the visibility based on the scroll events






share|improve this answer
























  • I know how to do it using the scroll listener. I prefer to use the ScrollingViewBehavior method.

    – Verhelst
    Nov 23 '18 at 14:33











Your Answer






StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");

StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53303045%2freverse-appbarlayout-scrollingviewbehavior%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes









0














You need to create a method that will get the height of the screen and scroll events (up and down.) You can also toggle the visibility in the method.
This means you will set visibility to visible in your XML and do something like:



    ChatButton Button;

ChatButtton.setVisibility = View.GONE
ChatButton.setVisibility = View.VISIBLE


to handle the toggle of the visibility based on the scroll events






share|improve this answer
























  • I know how to do it using the scroll listener. I prefer to use the ScrollingViewBehavior method.

    – Verhelst
    Nov 23 '18 at 14:33
















0














You need to create a method that will get the height of the screen and scroll events (up and down.) You can also toggle the visibility in the method.
This means you will set visibility to visible in your XML and do something like:



    ChatButton Button;

ChatButtton.setVisibility = View.GONE
ChatButton.setVisibility = View.VISIBLE


to handle the toggle of the visibility based on the scroll events






share|improve this answer
























  • I know how to do it using the scroll listener. I prefer to use the ScrollingViewBehavior method.

    – Verhelst
    Nov 23 '18 at 14:33














0












0








0







You need to create a method that will get the height of the screen and scroll events (up and down.) You can also toggle the visibility in the method.
This means you will set visibility to visible in your XML and do something like:



    ChatButton Button;

ChatButtton.setVisibility = View.GONE
ChatButton.setVisibility = View.VISIBLE


to handle the toggle of the visibility based on the scroll events






share|improve this answer













You need to create a method that will get the height of the screen and scroll events (up and down.) You can also toggle the visibility in the method.
This means you will set visibility to visible in your XML and do something like:



    ChatButton Button;

ChatButtton.setVisibility = View.GONE
ChatButton.setVisibility = View.VISIBLE


to handle the toggle of the visibility based on the scroll events







share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 21 '18 at 14:06









inspiredMichaelinspiredMichael

1246




1246













  • I know how to do it using the scroll listener. I prefer to use the ScrollingViewBehavior method.

    – Verhelst
    Nov 23 '18 at 14:33



















  • I know how to do it using the scroll listener. I prefer to use the ScrollingViewBehavior method.

    – Verhelst
    Nov 23 '18 at 14:33

















I know how to do it using the scroll listener. I prefer to use the ScrollingViewBehavior method.

– Verhelst
Nov 23 '18 at 14:33





I know how to do it using the scroll listener. I prefer to use the ScrollingViewBehavior method.

– Verhelst
Nov 23 '18 at 14:33




















draft saved

draft discarded




















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53303045%2freverse-appbarlayout-scrollingviewbehavior%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

Guess what letter conforming each word

Run scheduled task as local user group (not BUILTIN)

Port of Spain