草庐IT

Android CollapsingToolbarLayout 折叠监听器

coder 2023-05-07 原文

我将 CollapsingToolBarLayoutAppBarLayoutCoordinatorLayout 一起使用,它们完全可以正常工作。我将我的 Toolbar 设置为在向上滚动时固定,我想知道是否有办法更改工具栏的标题文本,当 CollapsingToolBarLayout 它已折叠。

总结一下,当滚动展开时,我想要两个不同的标题

提前谢谢大家

最佳答案

我分享了基于@Frodio Beggins 和@Nifhel 代码的完整实现:​​

public abstract class AppBarStateChangeListener implements AppBarLayout.OnOffsetChangedListener {

    public enum State {
        EXPANDED,
        COLLAPSED,
        IDLE
    }

    private State mCurrentState = State.IDLE;

    @Override
    public final void onOffsetChanged(AppBarLayout appBarLayout, int i) {
        if (i == 0) {
            if (mCurrentState != State.EXPANDED) {
                onStateChanged(appBarLayout, State.EXPANDED);
            }
            mCurrentState = State.EXPANDED;
        } else if (Math.abs(i) >= appBarLayout.getTotalScrollRange()) {
            if (mCurrentState != State.COLLAPSED) {
                onStateChanged(appBarLayout, State.COLLAPSED);
            }
            mCurrentState = State.COLLAPSED;
        } else {
            if (mCurrentState != State.IDLE) {
                onStateChanged(appBarLayout, State.IDLE);
            }
            mCurrentState = State.IDLE;
        }
    }

    public abstract void onStateChanged(AppBarLayout appBarLayout, State state);
}

然后你就可以使用它了:

appBarLayout.addOnOffsetChangedListener(new AppBarStateChangeListener() {
    @Override
    public void onStateChanged(AppBarLayout appBarLayout, State state) {
        Log.d("STATE", state.name());
    }
});

关于Android CollapsingToolbarLayout 折叠监听器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31682310/

有关Android CollapsingToolbarLayout 折叠监听器的更多相关文章

  1. ruby - Sublime Text 3 多行法折叠 - 2

    所以...SublimeText具有折叠方法的内置功能,但是一旦方法声明跨越多行,它就会失去这种能力。有谁知道插件或使它工作的方法吗?具体来说,我在使用ruby​​时遇到了这个问题(我的团队遵守关于行长度的严格风格指南),但语言应该无关紧要。 最佳答案 无需单击出现在函数定义第一行旁边的装订线中的向下箭头,您需要做的就是将光标放在函数的一个缩进行上(不是缩进的函数参数,而是在函数定义本身)并使用CtrlShift[键绑定(bind)(在OSX上使用⌘Alt[)折叠函数及其参数。使用CtrlShift](⌘Alt]在OSX上)展开,或

  2. ruby-on-rails - Rails 是否支持监听 UDP 套接字的简洁方式? - 2

    在Rails中,什么是集成更新模型某些元素的UDP监听过程的最佳方式(特别是它将向其中一个表添加行)。简单的答案似乎是在同一个进程中使用UDP套接字对象启动一个线程,但我什至不清楚我应该在哪里做适合Rails方式的事情。有没有一种巧妙的方法来开始收听UDP?具体来说,我希望能够编写一个UDPController并在每个数据报消息上调用一个特定的方法。理想情况下,我希望避免在UDP上使用HTTP(因为它会浪费一些在这种情况下非常宝贵的空间),但我完全控制消息格式,因此我可以为Rails提供它需要的任何信息。 最佳答案 Rails是一个

  3. ruby-on-rails - 有没有办法阻止 Rails 的内置服务器默认监听 0.0.0.0? - 2

    我在不受信任的网络(咖啡店、邻居的开放式wifi、DEFCON)上进行了大量的Web开发,当随机的、肯定有错误的软件(比如我正在开发的Rails应用程序)在0.0上绑定(bind)一个端口时,我会感到紧张.0.0并开始接受所有来者的请求。我知道我可以使用-b选项指定绑定(bind)到服务器的地址,但我想全局更改默认值,以便它始终以这种方式运行,除非我另有说明。当然我也可以运行某种会阻止连接的防火墙,但最好不要一开始就监听。是否有“.railsrc”文件或类似文件——至少是每个项目的设置文件,但最好是一些全局设置文件——我可以使用它来强制服务器默认仅绑定(bind)到127.0.0.1?

  4. ruby - 在 vim 中自动折叠 ruby - 2

    有没有一种方法可以设置vim自动折叠ruby​​源文件,但只在方法级别折叠而不考虑它们定义的级别?所以它会折叠,当我有:classMyClassdefmethod...endend而且当我有:moduleFirstModulemoduleSecondModuleclassMyClassdefmethod...endendendend我已经尝试过foldmethod=syntax和各种折叠级别,但它没有考虑定义方法的深度。此外,我不希望方法中的任何内容都被折叠(如果block、每个block等)。我认为foldmethod=expr是我最好的选择,但我还没有弄清楚折叠表达式的工作原理,而

  5. 映射过滤器并折叠C ++ - 2

    我有一个通常适合Java流的问题,但是我目前正在使用C++11。我在Java中解决此问题的方式是:intsolution=myList.stream()//myListisanarraylistofMyClass.mapToInt(MyClass::GetInt).sum();在探索C++标准库后,我了解到std::transform和std::accumulate存在。我唯一的问题是std::transform似乎只能从类型映射T输入T,我需要从类型中映射的地方T输入V(整数),在我积累之前。理想情况下,我希望能够将这种逻辑链接在一起,而不是拥有存储每个步骤中间结果的临时阵列。有没有惯用的C

  6. javascript - 窗口上的事件监听器不会删除 - 2

    这个问题在这里已经有了答案:JavaScript:removeeventlistener(10个答案)关闭7年前。我需要删除在窗口上设置的事件监听器,但它不起作用,监听器一直在滚动时触发。我试过设置有和没有lodashthrottle的听众,但它没有任何区别。这是我的代码:setupListener(){window.addEventListener('resize',_.throttle(this.handler.bind(this),750));window.addEventListener('scroll',_.throttle(this.handler.bind(this),7

  7. javascript - 是否使用 ".click()"异步触发事件监听器? - 2

    我有以下代码(我的HTML中有一个):(function(){'usestrict';document.getElementById(7).addEventListener("click",function(){console.log('clicked');})console.log('before');document.getElementById(7).click();console.log('after')}());当它在Firefox41控制台中运行时,我会预料到之前之后点击因为代码会同步运行,然后在完成脚本后响应事件队列中的点击事件。相反,我得到了之前点击在之后这表明事件正在

  8. javascript - 如何将拖放事件监听器附加到 React 组件 - 2

    我正在构建一个允许将本地文件拖放到div上的组件。然后会输出有关已删除文件的信息。我的问题是在创建组件时我不知道如何正确附加事件监听器drop和dragover。我的App组件是我所有逻辑所在的地方(拖放和拖动的处理程序),我创建了一个单独的组件,文件将被放置在该组件上-dropZone组件。我尝试使用componentDidMount将事件监听器放在我的App组件上的dropZone标记上,如果我的dropZone组件已呈现,则在其上放置一个事件监听器:componentDidMount(){constdropZone=document.getElementById('dropZon

  9. javascript - 如何找出是否有正在监听键盘事件的 Javascript 代码? - 2

    如何确定是否有Javascript代码监听/拦截键盘事件,并理想地找到代码中的确切行/位置(例如在ChromeDev工具中)? 最佳答案 我的答案是针对Chrome浏览器如果您需要查看在对象上注册的事件监听器,那么您可以使用getEventListeners(object)如果您需要监控事件,请使用monitorEvents()您可以阅读moreabouttheseAPI您还可以从开发工具中观察这些事件 关于javascript-如何找出是否有正在监听键盘事件的Javascript代码?

  10. javascript - 提交表单的事件监听器 - 2

    我为表单提交编写了一个事件监听器,这导致我出现了一些问题。在文本字段内按“输入”时,一切正常。但是,我有一个跨度(带有背景图像)也可以通过单击事件提交表单。这无法正常工作,我不明白为什么。这是基本的HTML:这是事件监听器的JS:functionevtSubmit(e){//codee.preventDefault();};varmyform=document.myForm;if(myform.addEventListener){myform.addEventListener('submit',evtSubmit,false);}这是“跨度”及其点击事件的JS:varsearchBut

随机推荐