我正在使用android.support.v7.widget.Toolbar
这是我的工具栏布局
<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" >
<ImageButton
android:id="@+id/scannerSettingsButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end"
android:background="@android:drawable/ic_menu_preferences"
/>
<ToggleButton
android:id="@+id/scannerButton"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="#00000000"
android:layout_gravity="end"
android:textOn="SCAN"
android:textOff="STOP"/>
<ProgressBar
android:id="@+id/progress_spinner"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:indeterminate="true"
android:layout_marginBottom="15dp"
android:layout_marginTop="15dp"
android:layout_gravity="end"
/>
</android.support.v7.widget.Toolbar>
这是工具栏布局中的我的图标
我想要一个下拉菜单,当用户点击@id/scannerSettingsButton
时,会出现一个下拉菜单,这是一个带有最右边红色的扳手风格的图标。
以下是下拉菜单的示例
知道如何向我的ImageButton
添加下拉菜单吗?
由于
答案 0 :(得分:1)
像这样创建你的menu.xml文件
<menu
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/menu1"
android:icon="@mipmap/ic_launcher"
android:title="menu"
app:showAsAction="ifRoom|withText" >
<menu>
<item
android:id="@+id/submenu1"
android:title="sub_menu1" />
<item
android:id="@+id/submenu2"
android:title="sub_menu2" />
<item
android:id="@+id/submenu3"
android:title="sub_menu3" />
</menu>
</item>
</menu>
覆盖onCreateOptionsMenu
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_toolbar,menu);
return true;
}
覆盖onOptionsItemSelected
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
switch (id) {
case R.id.submenu1:
//add your method
return true;
case R.id.submenu2:
//add your method
return true;
default:
return super.onOptionsItemSelected(item);
}
}