安卓目录res/menu中showAsAction用法

本文详细介绍了Android中Action Bar的showAsAction属性的五个值的作用,包括ifRoom、never、always、withText和collapseActionView,并给出了如何正确设置这些属性的示例代码。此外,还解释了如何解决常见的错误提示,并提供了menu使用的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、showAsAction的属性值:

1、ifRoom    会显示在Item中,但是如果已经有4个或者4个以上的Item时会隐藏在溢出列表中。当然个数并不仅仅局限于4个,依据屏幕的宽窄而定    
2、 never    永远不会显示。只会在溢出列表中显示,而且只显示标题,所以在定义item的时候,最好把标题都带上。    

3、always    无论是否溢出,总会显示。    
4、 withText    withText值示意Action bar要显示文本标题。Action bar会尽可能的显示这个标题,但是,如果图标有效并且受到Action bar空间的限制,文本标题有可能显示不全。    
5、collapseActionView      声明了这个操作视窗应该被折叠到一个按钮中,当用户选择这个按钮时,这个操作视窗展开。否则,这个操作视窗在默认的情况下是可见的,并且即便在用于不适用的时候,也要占据操作栏的有效空间。
一般要配合ifRoom一起使用才会有效果。

二、使用中遇到的错误及解决方案

(错误提示Should use app:showAsAction with the appcompat library with xmlns:app="http://schemas.android.com/apk/res-auto

由此可以知道showAsAction在app: namespace下,而不是android: namespace下,于是将android:showAsAction改为app:showAsAction,同时引入xmlns:app="http://schemas.android.com/apk/res-auto" 一个完整的xml例子如下:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    tools:context=".MainActivity">
    <item android:id="@+id/action_material"
        android:title="11"
        android:orderInCategory="100"
        app:showAsAction="always" />

    <item android:id="@+id/action_circles"
        android:title="22"
        android:icon="@mipmap/ic_launcher"
        android:orderInCategory="100"
        app:showAsAction="withText" />

    <item android:id="@+id/action_water_drop"
        android:title="33"
        android:orderInCategory="100"
        app:showAsAction="never" />

</menu>


三、menu用法:

1、再在res/menu中建xml文件如上图代码

2、在activity中需用到

onCreateOptionsMenu()和onOptionsItemSelected两个函数

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    getMenuInflater().inflate(R.menu.demo, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    int id = item.getItemId();

    switch (id){
        case R.id.list:
            Toast.makeText(this, "listview", Toast.LENGTH_SHORT).show();
            return true;
        case R.id.recycler:
            Toast.makeText(this, "recycler", Toast.LENGTH_SHORT).show();
            return true;
        case R.id.scroll:
            Toast.makeText(this, "scroll", Toast.LENGTH_SHORT).show();
            return true;
    }

    return super.onOptionsItemSelected(item);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值