继续创造,加快成长!这是我参与「日新方案 10 月更文挑战」的第25天,点击检查活动详情
Android完成选项菜单子菜单
首要为大家详细介绍了Android完成选项菜单子菜单
菜单简介:
菜单在桌面使用中运用非常广泛,几乎一切的桌面使用都有菜单。可是跟着手机的开展,关于手机桌面菜单的运用减少了许多,一般来说咱们把菜单都放到使用中是完成,桌面使用的菜单与手机使用的菜单的不同之处便是,桌面菜单一般可见,而手机不可见,一般需求用户按下手机上的MENU键时,才会弹出菜单的相关使用,这里简略的来说下菜的简略运用情况,经过一个小案例来讲解。
一般菜单的创立有两种方式,一种是在Java代码中创立,一种是在XML中创立,本次首要讲解XML中创立菜单的案例,由于一般推荐运用的都是XML方式来创立菜单,比较Java代码,他更便于维护,可扩展性强,耦合度底。
案例完成,用户输入文字,能够经过菜单挑选字体的巨细,字体的色彩等
完成过程:
1.首先在资源文件夹的menu下创立菜单xml
menu_main.xml
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/menuFont"
android:title="字体巨细">
<menu>
<group
android:id="@+id/groupFont"
android:checkableBehavior="none">
<item
android:id="@+id/font_10"
android:title="10" />
<item
android:id="@+id/font_12"
android:title="12" />
<item
android:id="@+id/font_14"
android:title="14" />
<item
android:id="@+id/font_16"
android:title="16" />
<item
android:id="@+id/font_18"
android:title="18" />
</group>
</menu>
</item>
<item
android:id="@+id/menuColor"
android:icon="@mipmap/ic_launcher"
android:title="字体色彩">
<menu>
<group
android:id="@+id/groupColor"
android:checkableBehavior="none">
<item
android:id="@+id/red"
android:title="赤色" />
<item
android:id="@+id/blue"
android:title="蓝色" />
<item
android:id="@+id/green"
android:title="绿色" />
</group>
</menu>
</item>
</menu>
关于上面的xml文件中:
‘<‘item …/>元素:定义菜单项。
‘<‘group…/>子元素:将多个'<‘item…/>定义的菜单项包装成一个菜单组,'<‘gruop…/>
子元素用于控制整组菜单的行为,该元素可指定如下的常用属性:
- checkableBehavior:指定该组菜单的挑选行为。能够指定为none(不可选)、
- all(多选)和single(单选)三个值
- menuCategory:对菜单进行分类,指定菜单的优先级。有效值为container、
- system、secondary和alternative
- visible:指定该组件菜单是否可见。
- enable:指定该组菜单是否可用。
一般'<‘item …/>元素用于定义菜单项,'<‘item …/>元素又可包括'<‘menu…/>元素,位
于'<‘item…/>元素内部的'<‘menu…/>便是他的子菜单。
关于'<‘item…/>元素可用指定如下常用属性:
android:id: 为菜单项指定一个唯一的标识
android:title: 指定菜单项的标题
android:icon: 指定菜单项的图标
android:alphabeticShortcut: 为菜单项指定字符快捷键
android:numericShortcut: 为菜单项指定数字快捷键
android:checkable: 设置该次啊单项是否可选
android:checked: 设置该菜单项是否已选中
android:visible: 设置该菜单项是否可见
android:enable: 设置该菜单项是否可用
2.设置与菜单项相关的Activity,在activity中重写onCreateOptionsMenu(Menu menu)、
如果需求菜单项的监听事情,则需求重写
onOptionsItemSelected(MenuItem item)
MainActivity.java
public class MainActivity extends AppCompatActivity {
private EditText mEdt;
private TextView mTv;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mEdt = (EditText) findViewById(R.id.mEdt);
mTv = (TextView) findViewById(R.id.mInput);
}
/**
* 经过该办法增加菜单项或子菜单项
* @param menu
* @return
*/
@Override
public boolean onCreateOptionsMenu(Menu menu) {
//方式一增加菜单布局
MenuInflater inflater = new MenuInflater(this);
//将解析到的布局增加到menu中
inflater.inflate(R.menu.menu_main, menu);
//方式二增加菜单布局
// getMenuInflater().inflate(R.menu.menu_main,menu);
return super.onCreateOptionsMenu(menu);
}
/**
* 设置菜单项的点击事情
* @param item
* @return
*/
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menuColor:
Toast.makeText(this, "你挑选了修正色彩", Toast.LENGTH_SHORT).show();
break;
case R.id.menuFont:
Toast.makeText(this, "你挑选了修正字体", Toast.LENGTH_SHORT).show();
break;
}
return super.onOptionsItemSelected(item);
}
}
根本的布局便是这样了,看看整体布局

字体巨细下的子菜单:

字体色彩下的子菜单:

3.开始完成功用了,这里我只贴上功用完成的办法:onOptionsItemSelected(MenuItem item)
@Override
public boolean onOptionsItemSelected(MenuItem item) {
//先判断点击的是哪个id
switch (item.getItemId()) {
case R.id.font_10:
mEdt.setTextSize(10 * 2);
break;
case R.id.font_12:
mEdt.setTextSize(12 * 2);
break;
case R.id.font_14:
mEdt.setTextSize(14 * 2);
break;
case R.id.font_16:
mEdt.setTextSize(16 * 2);
break;
case R.id.font_18:
mEdt.setTextSize(18 * 2);
break;
case R.id.blue:
mEdt.setTextColor(Color.BLUE);
break;
case R.id.red:
mEdt.setTextColor(Color.RED);
break;
case R.id.green:
mEdt.setTextColor(Color.GREEN);
break;
}
return super.onOptionsItemSelected(item);
}
运行结果:

简略的菜单布局就这些了,关于菜单还有另一种办法,那便是上下文菜单,有关上下文菜单,