除非折叠

时间:2015-06-06 11:54:59

标签: android material-design android-toolbar android-design-library android-collapsingtoolbarlayout

使用新的设计库,我们应该在CollapsingToolbarLayout上设置工具栏标题,而不是Toolbar本身(至少在使用折叠工具栏时)。但setTitle()仅在以下特定情况下更新标题:

1)当CollapsingToolbarLayout还没有标题时

2)CollapsingToolbarLayout完全崩溃的那一刻

3)CollapsingToolbarLayout开始展开时

我实际上要做的是在完全展开时让标题成为EditText,允许用户为他/她的角色命名,然后显示为标题。我试图通过打电话来强迫这个问题 invalidate()requestLayout()以及CollapsingToolbarLayout个孩子的这两种方法。没有效果。

有什么想法吗?

3 个答案:

答案 0 :(得分:27)

编辑:不再需要此解决方案。 v22.2.1

中修复了错误

我不想留下链接,所以这里是完整的解决方案。

发生错误是因为如果当前标题为null或文本大小已更改,则处理可折叠标题的代码仅更新实际标题。解决方法是更改​​标题文本大小,然后将其更改回来。我使用0.5 sp所以没有太多的跳跃。更改文本大小会强制更新文本,并且不会出现闪烁。只是略微调整文字大小。

这就是我所拥有的

private void setCollapsingToolbarLayoutTitle(String title) {
    mCollapsingToolbarLayout.setTitle(title);
    mCollapsingToolbarLayout.setExpandedTitleTextAppearance(R.style.ExpandedAppBar);
    mCollapsingToolbarLayout.setCollapsedTitleTextAppearance(R.style.CollapsedAppBar);
    mCollapsingToolbarLayout.setExpandedTitleTextAppearance(R.style.ExpandedAppBarPlus1);
    mCollapsingToolbarLayout.setCollapsedTitleTextAppearance(R.style.CollapsedAppBarPlus1);
}

在styles.xml中我有

<style name="ExpandedAppBar" parent="@android:style/TextAppearance.Medium">
    <item name="android:textSize">28sp</item>
    <item name="android:textColor">#000</item>
    <item name="android:textStyle">bold</item>
</style>

<style name="CollapsedAppBar" parent="@android:style/TextAppearance.Medium">
    <item name="android:textSize">24sp</item>
    <item name="android:textColor">@color/white</item>
    <item name="android:textStyle">normal</item>
</style>

<style name="ExpandedAppBarPlus1" parent="@android:style/TextAppearance.Medium">
    <item name="android:textSize">28.5sp</item>
    <item name="android:textColor">#000</item>
    <item name="android:textStyle">bold</item>
</style>

<style name="CollapsedAppBarPlus1" parent="@android:style/TextAppearance.Medium">
    <item name="android:textSize">24.5sp</item>
    <item name="android:textColor">@color/white</item>
    <item name="android:textStyle">normal</item>
</style>

快乐编码。

答案 1 :(得分:5)

好的,我等待Google时有一个解决方法:

  1. 抓住https://gist.githubusercontent.com/blipinsk/3f8fb37209de6d3eea99/raw/b13bd20ebb319d94399f0e2a0bedbff4c044356a/ControllableAppBarLayout.java的要点(我不是原创作者,而是原创作者的荣誉)。这为AppBarLayout添加了一些方法,即展开和折叠

  2. 在调用setTitle()

  3. 的方法中

    collapsingToolbar.setTitle("All Recent");
    getSupportActionBar().setTitle("All Recent");
    collapseThenExpand();
    
    1. 现在创建一个collapseThenExpand()方法:
    2. private void collapseThenExpand() {
        appbar.collapseToolbar();
      
        Handler h = new Handler();
        h.postDelayed(new Runnable() {
          @Override
          public void run() {
            appbar.expandToolbar(true);
          }
        }, 800);
      }
      

      请注意,您可以通过将展开动画设置为false来关闭展开动画。

答案 2 :(得分:0)

在我的解决方案中,我必须为工具栏和折叠工具栏设置标题才能使其正常工作。

所以在OnCreate中:

    toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    collapsingToolbar = (CollapsingToolbarLayout) findViewById(R.id.collapsing_toolbar);

然后当我切换片段时进一步向下,当我选择一个标签时,我为两者设置了标题:

            public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                FragmentManager fm = getSupportFragmentManager();
                FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();

                //TAB1 - THE DEFAULT TAB
                switch (item.getItemId()) {

                        case R.id.tab_rooms:
                            toolbar.setTitle("My Title");
                            collapsingToolbar.setTitle("My Title");
                            fm.popBackStack(null, FragmentManager.POP_BACK_STACK_INCLUSIVE);
                            fragment = new RoomsFragment();
                            transaction.replace(R.id.fragment_container, fragment);
                            transaction.addToBackStack(null);
                            transaction.commit();

                            return true;

                        case R.id.tab_shisha:
                            toolbar.setTitle("My Title2");
                            collapsingToolbar.setTitle("My Title2");
                            fm.popBackStack(null, FragmentManager.POP_BACK_STACK_INCLUSIVE);
                            fragment = new ShishaFragment();
                            transaction.replace(R.id.fragment_container, fragment);
                            transaction.addToBackStack(null);
                            transaction.commit();
                            return true;
                          }

                    return false;
                }

希望能帮助别人!