使用 AppCompat 支持库的自定义工具栏未显示后退按钮



我正在一个项目中工作,我需要自定义工具栏作为操作栏。 我尝试在我的布局文件中使用自定义工具栏,并在清单文件中将该活动主题定义为 noActionBar 并使用getSupportActionBar().setHomeButtonEnabled(true);我也使用了getSupportActionBar().setDisplayShowHomeEnabled(true);getSupportActionBar().setDefaultDisplayHomeAsUpEnabled(true);但它没有为我显示后退按钮。 然后,我还在清单文件的"活动"部分添加了android:parentActivityName=".MainActivity。 仍然没有显示后退按钮。

这是我的主要活动文件。

public class MainActivity extends AppCompatActivity {
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
   }
   public void next(View view) {
      startActivity(new Intent(this, Main2Activity.class));
   }
}

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:id="@+id/activity_main"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   tools:context="com.example.takmilul.actionbar.MainActivity">
   <Button
      android:id="@+id/next"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:layout_marginTop="40dp"
      android:onClick="next"
      android:text="Next"/>
</LinearLayout>

主2活动文件:

public class Main2Activity extends AppCompatActivity {
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main2);
      Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
      setSupportActionBar(toolbar);
      ActionBar actionBar = getSupportActionBar();
      getSupportActionBar().setDisplayShowHomeEnabled(true);
      getSupportActionBar().setHomeButtonEnabled(true);
      getSupportActionBar().setDefaultDisplayHomeAsUpEnabled(true);
      actionBar.setTitle("Second Activity");
   }
}

activity_main2.xml文件:

<LinearLayout
   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:id="@+id/activity_main2"
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   tools:context="com.example.takmilul.actionbar.Main2Activity">
   <android.support.v7.widget.Toolbar
      android:id="@+id/toolbar"
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:background="@color/colorPrimary"
      app:theme="@style/ThemeOverlay.AppCompat.Dark">
   </android.support.v7.widget.Toolbar>
</LinearLayout>

样式.xml文件:

<resources>
   <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
      <item name="colorPrimary">@color/colorPrimary</item>
      <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
      <item name="colorAccent">@color/colorAccent</item>
   </style>
</resources>

安卓清单.xml文件

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.example.takmilul.actionbar">
   <application
      android:allowBackup="true"
      android:icon="@mipmap/ic_launcher"
      android:label="@string/app_name"
      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=".Main2Activity"
         android:parentActivityName=".MainActivity"
         android:theme="@style/Theme.AppCompat.Light.NoActionBar">
         <meta-data
            android:name="android.support.PARENT_ACTIVITY"
            android:value=".MainActivity" />
      </activity>
   </application>
</manifest>

和 build.gradle 文件,如下所示:

apply plugin: 'com.android.application'
android {
    compileSdkVersion 23
    buildToolsVersion "23.0.3"
    defaultConfig {
        applicationId "com.example.takmilul.actionbar"
        minSdkVersion 16
        targetSdkVersion 23
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner     "android.support.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}
dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile 'com.android.support:appcompat-v7:23.4.0'
}

请帮助我显示后退按钮,然后按该后退按钮转到上一页。

您尚未设置后退按钮的图标。 为其设置导航图标。您可以通过XML文件或Java文件进行设置。在 XML 文件中添加行

app:navigationIcon="?attr/homeAsUpIndicator"

或在 Java 文件中

getSupportActionBar().setHomeAsUpIndicator(getResources().getDrawable(R.drawable.abc_ic_ab_back_mtrl_am_alpha);

希望它对你有用。

只需在activity_main2.xml文件中创建一个按钮:

    <LinearLayout
    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:id="@+id/activity_main2"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.takmilul.actionbar.Main2Activity">
<android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/colorPrimary"
    app:theme="@style/ThemeOverlay.AppCompat.Dark">
    <Button
        android:id="@+id/back"
        android:layout_width="30sp"
        android:layout_height="30sp"
        android:background="@drawable/back_arrow"
        android:layout_marginLeft="10dp"
        android:onClick="back"/>
</android.support.v7.widget.Toolbar>

和主2活动文件:

public class Main2Activity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.content_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);
    ActionBar actionBar = getSupportActionBar();
    getSupportActionBar().setDisplayShowHomeEnabled(true);
    getSupportActionBar().setHomeButtonEnabled(true);
    getSupportActionBar().setDefaultDisplayHomeAsUpEnabled(true);
    actionBar.setTitle("Second Activity");
    }
public void back(View view) {
   finish();
   }
   }

package com.example.saloni;

导入安卓捆绑包;

import android.support.v7.app.AppCompatActivity;

导入android.support.v7.widget.Toolbar;

public class Main2Activity extensions AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.fhg);
    setToolbar();  
    }
    private void setToolbar() {
    setSupportActionBar(((Toolbar) findViewById(R.id.toolbar)));        
    getSupportActionBar().setHomeButtonEnabled(true);
    getSupportActionBar().setHomeAsUpIndicator(R.drawable.back);
    getSupportActionBar().setDisplayHomeAsUpEnabled(true);
}

}

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="windowNoTitle">true</item>
    <item name="windowActionBar">false</item>
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>
    <item name="android:textColorPrimary">#FFFFFF</item>
</style>

最新更新