1. ホーム
  2. android

[解決済み] CollapsingToolbarLayoutのタイトルを折りたたみ時のみ表示する。

2022-04-25 14:55:48

質問

試してみたところ setExpandedTitleColorsetCollapsedTitleColor (透明への切り替え)がうまくいきません。 私が探しているものを実現する内蔵のメソッドも見当たりません。

CollapsingToolbarLayoutが完全に折りたたまれたときだけタイトルを表示し、それ以外は非表示にする必要があります。

何かヒントがあれば教えてください。

解決方法は?

を追加することができます。 OnOffsetChangedListenerAppBarLayout を決定する。 CollapsingToolbarLayout が折りたたまれたり展開されたりして、そのタイトルを設定します。

ジャワ

final CollapsingToolbarLayout collapsingToolbarLayout = (CollapsingToolbarLayout) findViewById(R.id.collapsingToolbarLayout);
AppBarLayout appBarLayout = (AppBarLayout) findViewById(R.id.appBarLayout);
appBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
    boolean isShow = true;
    int scrollRange = -1;

    @Override
    public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
        if (scrollRange == -1) {
            scrollRange = appBarLayout.getTotalScrollRange();
        }
        if (scrollRange + verticalOffset == 0) {
            collapsingToolbarLayout.setTitle("Title");
            isShow = true;
        } else if(isShow) {
            collapsingToolbarLayout.setTitle(" ");//careful there should a space between double quote otherwise it wont work 
            isShow = false;
        }
    }
});


コトリン

var isShow = true
var scrollRange = -1
appBarLayout.addOnOffsetChangedListener(AppBarLayout.OnOffsetChangedListener { barLayout, verticalOffset ->
    if (scrollRange == -1){
        scrollRange = barLayout?.totalScrollRange!!
    }
    if (scrollRange + verticalOffset == 0){
        collapsingToolbarLayout.title = "Title Collapse"
        isShow = true
    } else if (isShow){
        collapsingToolbarLayout.title = " " //careful there should a space between double quote otherwise it wont work
        isShow = false
    }
})