使用新的设计库,我们应该在CollapsingToolbarLayout
上设置工具栏标题,而不是Toolbar
本身(至少在使用折叠工具栏时)。但setTitle()
仅在以下特定情况下更新标题:
1)当CollapsingToolbarLayout
还没有标题时
2)CollapsingToolbarLayout
完全崩溃的那一刻
3)CollapsingToolbarLayout
开始展开时
我实际上要做的是在完全展开时让标题成为EditText
,允许用户为他/她的角色命名,然后显示为标题。我试图通过打电话来强迫这个问题
invalidate()
或requestLayout()
以及CollapsingToolbarLayout
个孩子的这两种方法。没有效果。
有什么想法吗?
答案 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时有一个解决方法:
抓住https://gist.githubusercontent.com/blipinsk/3f8fb37209de6d3eea99/raw/b13bd20ebb319d94399f0e2a0bedbff4c044356a/ControllableAppBarLayout.java的要点(我不是原创作者,而是原创作者的荣誉)。这为AppBarLayout
添加了一些方法,即展开和折叠
在调用setTitle()
:
collapsingToolbar.setTitle("All Recent");
getSupportActionBar().setTitle("All Recent");
collapseThenExpand();
collapseThenExpand()
方法:
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;
}
希望能帮助别人!