菜单 | 显示菜单 | 事件监听 |
---|---|---|
系统菜单 | onCreateOptionsMenu | onOptionsItemSelected |
上下文菜单 | AlertDialog.Builder | setSingleChoiceItems() |
弹出式菜单 | PopupMenu | setOnMenuItemClickListener |
系统菜单
1.在res资源目录下创建一个menu文件夹,在文件夹中创建一个xml文件来作为OptionMenu的布局文件
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item android:id="@+id/blue" android:title="蓝色" app:showAsAction="always"/>
<item android:id="@+id/red" android:title="红色" app:showAsAction="ifRoom"/>
<item android:id="@+id/green" android:title="绿色" />
</menu>
2.Activity重写onCreateOptionsMenu加载资源文件
3.Activity重写onOptionsItemSelected加设置事件监听
(一个Activity只有一个系统菜单)
public class MainActivity extends AppCompatActivity {
private TextView textView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textView =findViewById(R.id.textt);//初始化
}
//Activity重写onCreateOptionsMenu加载资源文件
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.option_menu,menu);
return super.onCreateOptionsMenu(menu);
}
//Activity重写onOptionsItemSelected加设置事件监听
@Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();//获取条目id
switch(id){
case R.id.blue :
textView.setTextColor(Color.parseColor("#2239A2"));
break;
case R.id.red :
textView.setTextColor(Color.parseColor("#A21C31"));
break;
case R.id.green :
textView.setTextColor(Color.parseColor("#1BA233"));
break;
default:
break;
}
return super.onOptionsItemSelected(item);
}
}
上下文菜单
1.1.在res下面创建一个menu文件夹,并新建一个xml文件作为ContextMenu的布局文件,在这里还是接着用上一个
2.Activity重写onCreateConextMenu加载资源文件
3.Activity重写onConextItemSelected设置事件监听
4.为控件添加长按属性并将菜单绑定到这个控件上:registerForContextMenu(控件)
(长按绑定的控件+可以为任意一个view设置上下文菜单)
public class Main2Activity extends AppCompatActivity {
private TextView textView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main2);
textView = findViewById(R.id.myText);
//为控件添加长按属性并将菜单绑定到这个控件上
registerForContextMenu(textView);
}
//Activity重写onCreateConextMenu加载资源文件
@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
getMenuInflater().inflate(R.menu.option_menu,menu);
}
@Override
public boolean onContextItemSelected(MenuItem item) {
int id = item.getItemId();
switch (id) {
case R.id.blue:
textView.setTextColor(Color.parseColor("#2239A2"));
break;
case R.id.green:
textView.setTextColor(Color.parseColor("#1BA233"));
break;
case R.id.red:
textView.setTextColor(Color.parseColor("#A21C31"));
break;
}
return super.onContextItemSelected(item);
}
弹出式菜单
步骤1:在res下面创建一个menu文件夹,并新建一个xml文件作为PoupMenu的布局文件,在这里还是用之前的。
步骤2:把PopupMenu相关逻辑封装到showPopupMenu()方法中,包含PopupMenu的实例化、布局设置、显示、添加MenuItem的点击监听及响应等
步骤3:为控件设置事件监听直接调用showPopupMenu()方法
(弹出菜单,默认弹出的位置在控件view的下方)
布局文件?
<?xml version="1.0" encoding="utf-8"?>
<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:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".Main3Activity"
android:gravity="center">
<TextView
android:id="@+id/textpop"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="弹出菜单"
android:textSize="30sp"
/>
</LinearLayout>
java代码?
//弹出式菜单
public class Main3Activity extends AppCompatActivity {
private TextView textView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main3);
textView = findViewById(R.id.textpop);
textView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
showpopMenu();
}
});
}
private void showpopMenu() {
//创建对象
//参数一:上下文 参数二:菜单显示在指定控件的下方
PopupMenu popupMenu = new PopupMenu(this, textView);
//记载布局
popupMenu.inflate(R.menu.option_menu);
//事件监听
popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem item) {
int id=item.getItemId();
switch (id){
case R.id.blue:
textView.setTextColor(Color.parseColor("#2239A2"));
break;
case R.id.green:
textView.setTextColor(Color.parseColor("#1BA233"));
break;
case R.id.red:
textView.setTextColor(Color.parseColor("#A21C31"));
break;
}
return false;
}
});
popupMenu.show();
}
}