更改操作栏图标位置
Change action bar icon position
我想在工具栏左侧显示菜单图标,并在菜单图标的实际位置显示搜索图标
这是我在主文件夹中的 main.xml 文件
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/my_search"
android:icon="@drawable/ic_search_black_24dp"
android:title="search"
app:showAsAction="always">
</item>
<item
android:id="@+id/my_menu_icon"
android:icon="@drawable/ic_menu_black_24dp"
android:title="side_menu"
app:showAsAction="always">
</item>
</menu>
这是本页的结果:
my result
这是我的 MainActivity.java
:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);//affect the menu file to the main activity and call this last one
return true;
}
}
我更喜欢使用 Toolbar
而不是 ActionBar
,并以 xml 形式自定义布局。您可以在 /src/main/res/values/style.xml
:
中像这样更改 AppTheme
<style name="AppTheme" parent="Base.Theme.AppCompat.Light">
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
别忘了在manifest
中设置AppTheme
,像这样:
<application
android:theme="@style/AppTheme"
//and other properties
</application>
然后你可以在布局中使用 android Toolbar
:
<?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">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fitsSystemWindows="true">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:orientation="horizontal">
<ImageButton
android:id="@+id/menu_btn"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="left"
android:background="?attr/selectableItemBackgroundBorderless"
android:src="@drawable/ic_menu_black_24dp""/>
<TextView
android:id="@+id/title"
android:layout_width="0dp"
android:layout_weight="1"
android:layout_height="match_parent"
android:gravity="left"
android:text="App Title"
android:textSize="16dp"
android:textStyle="bold"/>
<ImageButton
android:id="@+id/search_btn"
android:layout_width="?attr/actionBarSize"
android:layout_height="match_parent"
android:layout_gravity="right"
android:background="?attr/selectableItemBackgroundBorderless"
android:src="@drawable/ic_search_black_24dp"/>
</LinearLayout>
</android.support.v7.widget.Toolbar>
</android.support.design.widget.AppBarLayout>
// and other views
// .
// .
// .
</android.support.design.widget.CoordinatorLayout>
我想在工具栏左侧显示菜单图标,并在菜单图标的实际位置显示搜索图标
这是我在主文件夹中的 main.xml 文件
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/my_search"
android:icon="@drawable/ic_search_black_24dp"
android:title="search"
app:showAsAction="always">
</item>
<item
android:id="@+id/my_menu_icon"
android:icon="@drawable/ic_menu_black_24dp"
android:title="side_menu"
app:showAsAction="always">
</item>
</menu>
这是本页的结果: my result
这是我的 MainActivity.java
:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);//affect the menu file to the main activity and call this last one
return true;
}
}
我更喜欢使用 Toolbar
而不是 ActionBar
,并以 xml 形式自定义布局。您可以在 /src/main/res/values/style.xml
:
<style name="AppTheme" parent="Base.Theme.AppCompat.Light">
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
别忘了在manifest
中设置AppTheme
,像这样:
<application
android:theme="@style/AppTheme"
//and other properties
</application>
然后你可以在布局中使用 android Toolbar
:
<?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">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fitsSystemWindows="true">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:orientation="horizontal">
<ImageButton
android:id="@+id/menu_btn"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="left"
android:background="?attr/selectableItemBackgroundBorderless"
android:src="@drawable/ic_menu_black_24dp""/>
<TextView
android:id="@+id/title"
android:layout_width="0dp"
android:layout_weight="1"
android:layout_height="match_parent"
android:gravity="left"
android:text="App Title"
android:textSize="16dp"
android:textStyle="bold"/>
<ImageButton
android:id="@+id/search_btn"
android:layout_width="?attr/actionBarSize"
android:layout_height="match_parent"
android:layout_gravity="right"
android:background="?attr/selectableItemBackgroundBorderless"
android:src="@drawable/ic_search_black_24dp"/>
</LinearLayout>
</android.support.v7.widget.Toolbar>
</android.support.design.widget.AppBarLayout>
// and other views
// .
// .
// .
</android.support.design.widget.CoordinatorLayout>