gpt4 book ai didi

android - 折叠工具栏布局展开点击事件而不是滚动

转载 作者:行者123 更新时间:2023-11-29 20:11:50 25 4
gpt4 key购买 nike

我有一个简单的工具栏,右侧有一个信息图标项。单击该项目时,我想用动画扩展工具栏。使用新 View 和 FAB 按钮。就像 Textra SMS 所做的那样。

在展开的工具栏外单击时,我想折叠工具栏。

我正在寻找如何使用 CollapsingToolbarLayout 来处理这个问题?是否可以?我在网上找到的所有示例都随着 View 的滚动而折叠/展开(Recyclerview、Scrollview 等...)。但我不希望我的工具栏在 ScrollView 时移动。

使用CollapsingToolbarLayout 是个好方法吗?还是我需要自己做所有事情?

最佳答案

CollapsingToolbarLayout 似乎非常适合这个目的(而且我实际上相信它会使您的布局看起来比 Textra SMS 应用程序中的布局好得多)。

您将需要一些东西:

  1. 一种禁用 CollapsingToolbarLayout 的方法。我认为最好的方法(至少是迄今为止我发现的最好的方法)是使用自定义 CoordinatorLayout 而不是常规的 CoordinatorLayout

    public class DisableableCoordinatorLayout extends CoordinatorLayout {
    private boolean mPassScrolling = true;

    public DisableableCoordinatorLayout(Context context) {
    super(context);
    }

    public DisableableCoordinatorLayout(Context context, AttributeSet attrs) {
    super(context, attrs);
    }

    public DisableableCoordinatorLayout(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    }

    @Override
    public boolean onStartNestedScroll(View child, View target, int nestedScrollAxes) {
    return mPassScrolling && super.onStartNestedScroll(child, target, nestedScrollAxes);
    }

    public void setPassScrolling(boolean passScrolling) {
    mPassScrolling = passScrolling;
    }
    }
  2. 您实际上需要禁用您的 CollapsingToolbarLayout(您不希望您的 CollapsingToolbarLayout 对滚动使用react):

    mDisableableCoordinatorLayout.setPassScrolling(false);
  3. 您需要使用您的 AppBarLayout 展开 CollapsingToolbarLayout onOptionsMenu 项目点击

    mAppBarLayout.setExpanded(true, true);
  4. 您还需要使用 AppBarLayout 在外部单击时折叠 CollapsingToolbarLayout(以您喜欢的任何方式实现外部单击)

    mAppBarLayout.setExpanded(false, true);

关于android - 折叠工具栏布局展开点击事件而不是滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34659501/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com