所有活动都使用相同的工具栏-我缺少的东西

时间:2018-06-30 09:29:55

标签: android android-layout android-activity toolbar android-toolbar

我想要的东西:我想为所有活动保留相同的工具栏。

我尝试过的事情:我做了一个BaseActivity,并且里面有工具栏。我正在将其他活动扩展到BaseActivity。

问题是什么:运行应用程序时。我找不到其他活动的工具栏。

下面是我的代码。

BaseActivity.java

    public class BaseActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_base);
        Toolbar toolbar = findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.toolbar_menu, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {

        switch (item.getItemId()){
            case R.id.menu_lang_english:
                Toast.makeText(this, "English", Toast.LENGTH_SHORT).show();
                break;

            case R.id.menu_lang_french:
                Toast.makeText(this, "French", Toast.LENGTH_SHORT).show();
                break;
        }
        return super.onOptionsItemSelected(item);
    }
}

activity_base.xml

    <?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".BaseActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/AppTheme.AppBarOverlay">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            app:popupTheme="@style/AppTheme.PopupOverlay" />

    </android.support.design.widget.AppBarLayout>

</android.support.design.widget.CoordinatorLayout>

MainActivity.java

    public class MainActivity extends BaseActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
}

activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!" />

</LinearLayout>

styles.xml

<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
</style>

<style name="AppTheme.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
</style>

<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />

<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:roundIcon="@mipmap/ic_launcher_round"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity
        android:name=".BaseActivity"
        android:label="@string/title_activity_base"
        android:theme="@style/AppTheme.NoActionBar"></activity>
</application>

我得到的输出

Output Image

2 个答案:

答案 0 :(得分:0)

您的屏幕只能同时具有一种布局,MainActivity setContentView()被覆盖。

您可以使用Fragment代替Activtiy

答案 1 :(得分:0)

一种执行此操作的方法是在activity_base.xml中添加一个Framelayout。此布局将成为放置特定屏幕的占位符。因此,您所有的特定屏幕都将具有相同的工具栏和外观。

现在从您的具体屏幕上,您将不会呼叫setContentView()。而是调用类似putContentViewInTemplate(R.layout.activity_main.xml);的名称。这会将模板中的content_frame替换为实际屏幕。这是一个简单的实现,

protected void putContentViewInTemplate(int id) {
    mRootTemplate = (ViewGroup)findViewById(R.id.content_frame);
    mRootTemplate.addView(getViewFromLayout(id), 0);
}

请注意,您正在将屏幕布局插入到主模板activity_base.xml中。当然,您需要在activity_base.xml中添加content_frame。

<FrameLayout app:layout_behavior="@string/appbar_scrolling_view_behavior"
            android:id="@+id/content_frame"
            android:layout_width="match_parent"
            android:layout_height="match_parent">