更改可折叠工具栏标题的正确方法

Correct way to change Collapseable Toolbar title

当我更改折叠的 collapsingToolbar 的标题时,标题没有改变。

我试过 getSupportActionBar.setTitle 和 collapseToolbar.setTitle,但没有用。告诉我,有什么问题?

我相信 this 问题描述了您遇到的情况。我也有这个问题,今天解决了。本质上,处理折叠文本的代码仅在当前文本为空或文本大小发生变化时更新文本。目前这是一个已关闭的错误,补丁计划在设计库的未来版本中发布。现在使用我的解决方法,即仅更改文本的大小然后再将其改回。

这就是我的

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>

编辑:以下代码来自折叠工具栏布局中用于控制该视图文本的 collapsingtext 助手。

        if(availableWidth > 0.0F) {
            updateDrawText = this.mCurrentTextSize != newTextSize;
            this.mCurrentTextSize = newTextSize;
        }

        if(this.mTextToDraw == null || updateDrawText) {
            this.mTextPaint.setTextSize(this.mCurrentTextSize);
            CharSequence title = TextUtils.ellipsize(this.mText, this.mTextPaint, availableWidth, TruncateAt.END);
            if(this.mTextToDraw == null || !this.mTextToDraw.equals(title)) {
                this.mTextToDraw = title;
            }

            this.mTextWidth = this.mTextPaint.measureText(this.mTextToDraw, 0, this.mTextToDraw.length());
        }

有问题的行是 updateDrawText = this.mCurrentTextSize != newTextSize;,它设置布尔值以确定我们是否更改此行中的文本 if(this.mTextToDraw == null || updateDrawText) { 因此,当折叠工具栏布局重新计算其视图时,设置文本的决定因素是文字大小。如果您没有更改文本大小,那么您的折叠工具栏布局标题将不会更改,直到它从折叠位置折叠或展开

定义你的风格,比如:

<style name="CollapsedAppBarTopic" parent="@android:style/TextAppearance.Medium">
    <item name="android:textSize">20sp</item>
    <item name="android:textStyle">normal</item>
</style>

然后在你xml:

<android.support.design.widget.CollapsingToolbarLayout
    android:id="@+id/cardview_collapsing_toolbar"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layout_scrollFlags="scroll|exitUntilCollapsed"
    android:fitsSystemWindows="false"
    app:contentScrim="?attr/colorPrimary"
    app:expandedTitleMarginEnd="48dp"
    app:expandedTitleMarginStart="16dp"
    app:expandedTitleMarginBottom="16dp"
    app:expandedTitleTextAppearance="@style/CollapsedAppBarTopic"
    >