是否可以使用Android中的Actionbar sherlock在Action菜单项中实现切换按钮

时间:2013-02-19 13:02:21

标签: android android-actionbar actionbarsherlock

我有一个应用程序,它在操作菜单项中有切换按钮,虽然我正在使用Actionbar Sherlock,我不知道,如何在操作菜单项中放置切换按钮。我不想将其作为自定义布局放置在操作栏中,但我想将其作为菜单项放置。如果有人找到解决方案,请帮帮我。

目的,如果我更改切换按钮的状态,它将根据ALphabets对人进行排序,并在出生日期再次进行排序。

提前致谢!

4 个答案:

答案 0 :(得分:36)

只需将其添加为普通菜单按钮,使用布尔变量检查其状态,并在更改排序模式时更改图标和标题

boolean birthSort=false;
@Override
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
    case R.id.menu_toggle:

        if(birthSort){
            //change your view and sort it by Alphabet
            item.setIcon(icon1)
            item.setTitle(title1)
            birthSort=false;
        }else{
            //change your view and sort it by Date of Birth
            item.setIcon(icon2)
            item.setTitle(title2)
            birthSort=true;
        }
        return true;



    }
    return super.onOptionsItemSelected(item);


}

不要忘记将其添加到xml中,就像任何其他菜单按钮一样,如果要在溢出或外部显示它,请配置android:showAsAction

<menu xmlns:android="http://schemas.android.com/apk/res/android">

<item android:id="@+id/menu_toogle"
    android:showAsAction="ifRoom"
    android:title="Share"
     />
</menu>

答案 1 :(得分:3)

其他方法是为ActionBar使用自定义布局:

基本上,您定义了包含切换的布局

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content">
  <ToggleButton
    android:id="@+id/actionbar_service_toggle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textOn="Logging On"
    android:textOff="Logging Off" />
</RelativeLayout>

替代方案1: 然后在您的活动片段容器中执行以下操作:

ActionBar actionBar = getSupportActionBar();
actionBar.setCustomView(R.layout.actionbar_top);
actionBar.setDisplayOptions(ActionBar.DISPLAY_SHOW_HOME | ActionBar.DISPLAY_SHOW_CUSTOM);
...
ToggleButton button = (ToggleButton) findViewById(R.id.actionbar_service_toggle);

请注意,您正在使用真正的ToggleButton,并且您在代码中将其作为真实对象ToggleButton进行处理,与重新实现自己的切换(主题,可靠性,视图层次结构,本机支持)相比,它具有许多优点。 ..)。

源代码here


替代方案2: 另一种方法是将自定义视图嵌入到常规菜单视图中:

<menu xmlns:android="http://schemas.android.com/apk/res/android" >
    <item
        android:id="@+id/myswitch"
        android:title=""
        android:showAsAction="always"
        android:actionLayout="@layout/actionbar_service_toggle" />   
</menu>

答案 2 :(得分:2)

如果像我一样actionLayout不适合您,请尝试使用app:actionLayout="@layout/actionbar_service_toggle"代替android:actionLayout="@layout/actionbar_service_toggle"以及app:showAsAction="always"代替android:showAsAction="always" 这是因为如果使用appCompat,则不会使用android命名空间。

所以这是最终版本:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content">
  <ToggleButton
    android:id="@+id/actionbar_service_toggle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:textOn="Logging On"
    android:textOff="Logging Off" />
</RelativeLayout>

<?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/myswitch"
        android:title=""
        app:showAsAction="always"
        app:actionLayout="@layout/actionbar_service_toggle" />   
</menu>

答案 3 :(得分:1)

在菜单中创建xml文件:

menu.xml文件

 <menu 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" tools:context="si.ziga.switchinsideab.MainActivity">
<item android:id="@+id/switchId" android:title="" android:showasaction="always" android:actionlayout="@layout/switch_layout">
   <item android:id="@+id/action_settings" android:orderincategory="100" android:title="@string/action_settings" app:showasaction="never">
</item></item></menu>

然后导航到您的布局文件夹,制作一个新的xml文件 并将其命名为switch_layout.xml 这是代码: switch_layout.xml

<!--?xml version="1.0" encoding="utf-8"?-->
<relativelayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="match_parent" android:orientation="horizontal">
 <switch android:id="@+id/switchAB" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerhorizontal="true" android:layout_centervertical="true">
</switch></relativelayout>

在您的MainActivity类中复制并粘贴此代码:
MainActivity.java

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

switchAB = (Switch)menu.findItem(R.id.switchId)
.getActionView().findViewById(R.id.switchAB);7

或关注此事link