本文前三步演示了為Toolbar添加返回鍵並實現返回的步驟,第四步給出了設置返回鍵顏色的方法。
1.在xml布局中引用toolbar:
<android.support.design.widget.AppBarLayout android:layout_alignParentTop="true" 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>
2.為ToolBar添加返回鍵:
public class NavAboutActivity extends AppCompatActivity { @Override protected void onCreate(@Nullable Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_nav_about); android.support.v7.widget.Toolbar toolbar=findViewById(R.id.toolbar); setSupportActionBar(toolbar); getSupportActionBar().setDisplayHomeAsUpEnabled(true);//添加默認的返回圖標 getSupportActionBar().setHomeButtonEnabled(true); //設置返回鍵可用 } }
3.實現點擊返回鍵結束當前界面
有兩種實現方法.
第一種僅需要在清單文件中聲明返回的父Activity,用這種方式有過渡動畫,比直接監聽按鈕后調用finish()的做法自然:
<application ... > ... <!-- The main/home activity (it has no parent activity) --> <activity android:name="com.example.myfirstapp.MainActivity" ...> ... </activity> <!-- A child of the main activity --> <activity android:name="com.example.myfirstapp.MyChildActivity" android:label="@string/title_activity_child" android:parentActivityName="com.example.myfirstapp.MainActivity" > <!-- Parent activity meta-data to support 4.0 and lower --> <meta-data android:name="android.support.PARENT_ACTIVITY" android:value="com.example.myfirstapp.MainActivity" /> </activity> </application>
第二種是直接實現按鈕的監聽事件,調用finish()方法:
@Override
public boolean onOptionsItemSelected(MenuItem item) {
if(item.getItemId()==android.R.id.home){
finish();
}
return super.onOptionsItemSelected(item);
}
4.設置返回鍵顏色
在style.xml的相應Style中添加屬性:
<item name="colorControlNormal">@android:color/white</item>
參考: