179 lines
5.9 KiB
Java

/*
* Copyright (C) 2022 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.settingslib.collapsingtoolbar;
import android.app.ActionBar;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Toolbar;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;
import com.android.settingslib.utils.BuildCompatUtils;
import com.google.android.material.appbar.AppBarLayout;
import com.google.android.material.appbar.CollapsingToolbarLayout;
import com.google.android.material.color.DynamicColors;
/**
* A base Activity that has a collapsing toolbar layout is used for the activities intending to
* enable the collapsing toolbar function.
*/
public class CollapsingToolbarAppCompatActivity extends AppCompatActivity {
private class DelegateCallback implements CollapsingToolbarDelegate.HostCallback {
@Nullable
@Override
public ActionBar setActionBar(Toolbar toolbar) {
return null;
}
@Nullable
@Override
public androidx.appcompat.app.ActionBar setActionBar(
androidx.appcompat.widget.Toolbar toolbar) {
CollapsingToolbarAppCompatActivity.super.setSupportActionBar(toolbar);
return CollapsingToolbarAppCompatActivity.super.getSupportActionBar();
}
@Override
public void setOuterTitle(CharSequence title) {
CollapsingToolbarAppCompatActivity.super.setTitle(title);
}
}
private CollapsingToolbarDelegate mToolbardelegate;
private int mCustomizeLayoutResId = 0;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
if (BuildCompatUtils.isAtLeastS()) {
DynamicColors.applyToActivityIfAvailable(this);
}
setTheme(com.android.settingslib.widget.theme.R.style.Theme_SubSettingsBase);
if (mCustomizeLayoutResId > 0 && !BuildCompatUtils.isAtLeastS()) {
super.setContentView(mCustomizeLayoutResId);
return;
}
View view = getToolbarDelegate().onCreateView(getLayoutInflater(), null, this);
super.setContentView(view);
}
@Override
public void setContentView(int layoutResID) {
final ViewGroup parent = (mToolbardelegate == null) ? findViewById(R.id.content_frame)
: mToolbardelegate.getContentFrameLayout();
if (parent != null) {
parent.removeAllViews();
}
LayoutInflater.from(this).inflate(layoutResID, parent);
}
@Override
public void setContentView(View view) {
final ViewGroup parent = (mToolbardelegate == null) ? findViewById(R.id.content_frame)
: mToolbardelegate.getContentFrameLayout();
if (parent != null) {
parent.addView(view);
}
}
@Override
public void setContentView(View view, ViewGroup.LayoutParams params) {
final ViewGroup parent = (mToolbardelegate == null) ? findViewById(R.id.content_frame)
: mToolbardelegate.getContentFrameLayout();
if (parent != null) {
parent.addView(view, params);
}
}
/**
* This method allows an activity to replace the default layout with a customize layout. Notice
* that it will no longer apply the features being provided by this class when this method
* gets called.
*/
protected void setCustomizeContentView(int layoutResId) {
mCustomizeLayoutResId = layoutResId;
}
@Override
public void setTitle(CharSequence title) {
getToolbarDelegate().setTitle(title);
}
@Override
public void setTitle(int titleId) {
setTitle(getText(titleId));
}
@Override
public boolean onSupportNavigateUp() {
if (getSupportFragmentManager().getBackStackEntryCount() > 0) {
getSupportFragmentManager().popBackStackImmediate();
}
// Closes the activity if there is no fragment inside the stack. Otherwise the activity will
// has a blank screen since there is no any fragment.
if (getSupportFragmentManager().getBackStackEntryCount() == 0) {
finishAfterTransition();
}
return true;
}
@Override
public void onBackPressed() {
super.onBackPressed();
// Closes the activity if there is no fragment inside the stack. Otherwise the activity will
// has a blank screen since there is no any fragment. onBackPressed() in Activity.java only
// handles popBackStackImmediate(). This will close activity to avoid a blank screen.
if (getSupportFragmentManager().getBackStackEntryCount() == 0) {
finishAfterTransition();
}
}
/**
* Returns an instance of collapsing toolbar.
*/
@Nullable
public CollapsingToolbarLayout getCollapsingToolbarLayout() {
return getToolbarDelegate().getCollapsingToolbarLayout();
}
/**
* Return an instance of app bar.
*/
@Nullable
public AppBarLayout getAppBarLayout() {
return getToolbarDelegate().getAppBarLayout();
}
private CollapsingToolbarDelegate getToolbarDelegate() {
if (mToolbardelegate == null) {
mToolbardelegate = new CollapsingToolbarDelegate(new DelegateCallback());
}
return mToolbardelegate;
}
}