9

我希望拥有与图片中的移动版 chrome 浏览器类似的菜单项功能。我想在一行中有后退、前进、刷新菜单项。如何实现类似的菜单项?是否有任何参考或是否有任何技巧可以带来此功能?

在此处输入图像描述

我的应用程序仅针对平板电脑。这是我当前的操作栏菜单项:

<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
    android:id="@+id/favorite"
    android:showAsAction="always"
    android:title="Happy"/>
<item
    android:id="@+id/share_button"
    android:icon="@drawable/share"
    android:showAsAction="always"
    android:title="Share"/>
<item
    android:id="@+id/hola_button"          
    android:showAsAction="always"
    android:title="Hola"/>
<item
    android:icon="@drawable/more_actions"
    android:showAsAction="always">
    <menu>
        <item
            android:id="@+id/back_button"
            android:icon="@drawable/back"
            android:title="back"/>
        <item
            android:id="@+id/forward_button"
            android:icon="@drawable/forward"
            android:title="forward"/>
        <item
            android:id="@+id/refresh_button"
            android:icon="@drawable/refresh"
            android:title="refresh"/>          
    </menu>
 </item>
 </menu>
4

3 回答 3

1

编辑:

截图溢出菜单

这个例子是作为一个溢出菜单(因为 ABS 放弃了溢出主题)。你可以膨胀任何类型的布局组合。此类从 PopUpWindow 扩展而来,不使用典型的 onCreateOptions。它使用 ABS-CustomView 和 PopUpWindow 来创建菜单。

来自 android 参考:可用于显示任意视图的弹出窗口。弹出窗口是一个浮动容器,出现在当前活动的顶部。

布局看起来类似于您请求的布局。此视图锚定到 ActionBar,但您可以在任何您想要的地方显示它。弹出窗口支持许多开箱即用的显示功能。

可定制的溢出菜单

public class OverflowMenu extends PopupWindow {

private View mContentView;

public OverflowMenu(Context context, int resourceId) {
    super(context);
    mContentView = LayoutInflater.from(context).inflate(resourceId, null);
    setContentView(mContentView);
    setHeight(WindowManager.LayoutParams.WRAP_CONTENT);
    setWidth(WindowManager.LayoutParams.WRAP_CONTENT);

    // Handle touchevents
    setOutsideTouchable(true);
    setFocusable(true);
    setBackgroundDrawable(new BitmapDrawable());
}

/**
 * Attach the OverflowMenu View to the ActionBar's Right corner
 * @param actionBarView
 */
public void show(View actionBarView) {
    int x = actionBarView.getMeasuredWidth() - mContentView.getMeasuredWidth();
    showAsDropDown(actionBarView, x, 0);
}

/**
 * Return mContentView, 
 *  used for mContentView.findViewById();
 * @return
 */
public View getView(){
    return mContentView;
}
}

主要活动

public class MainActivity extends SherlockActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_mai n);

    final ActionBar actionBar = getSupportActionBar();
    actionBar.setCustomView(R.layout.actionbar);
    actionBar.setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM);

    final OverflowMenu menu = new OverflowMenu(this,R.layout.menu_overflow);

    final ImageButton overflowBtn = (ImageButton) actionBar.getCustomView().findViewById(R.id.actionbar_overflow);
    overflowBtn.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View v) {
            menu.show(actionBar.getCustomView());
        }
    });
  }


 }
于 2013-01-22T21:21:10.997 回答
1

这看起来像一个带有列表视图和自定义列表头的自定义对话框

或者

一个简单布局下方的列表视图,对话框顶部有 3 个按钮。

您可以在操作栏菜单项单击上显示相同的内容。

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    super.onCreateOptionsMenu(menu);
    getSupportMenuInflater().inflate(R.menu.menu_items, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {

    switch (item.getItemId()) {
    case android.R.id.show_dlg:

    // Show your custom dialog
        break;
    }

    return super.onOptionsItemSelected(item);

}

此外,本教程将有助于作为膨胀自定义菜单的参考 http://www.codeproject.com/Articles/173121/Android-Menus-My-Way

于 2013-01-22T18:39:02.083 回答
0

您可以使用以下内容将菜单项添加到页面:

OptionCommand command = new OptionCommand();
command.setActionView(view);
command.setIcon(canvas.getContext().getResources().getDrawable(android.R.drawable.ic_menu_search));
command.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM | MenuItem.SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW);
canvas.getActivity().getOptionCommands().add(command);
于 2013-01-17T17:07:44.917 回答