zoukankan      html  css  js  c++  java
  • Android Menu

    Android - Menu

    1.ContextMenu

    上下文菜单,就是长按某个view后弹出菜单。关联的是View。

    效果图:

    1.1选项菜单Menu
    <?xml version="1.0" encoding="utf-8"?>
    <menu xmlns:android="http://schemas.android.com/apk/res/android">
        <group android:checkableBehavior="none">
            <item android:id="@+id/item_context_item1" android:title="Item1"/>
            <item android:id="@+id/item_context_item2" android:title="Item2"/>
            <item android:id="@+id/item_context_item3" android:title="Item3"/>
        </group>
    </menu>
    
    1.2 为View注册上下文菜单
    registerForContextMenu(view);
    
    1.3创建Menu
      @Override
        public void onCreateContextMenu(ContextMenu menu, View v, ContextMenu.ContextMenuInfo menuInfo) {
    
            MenuInflater inflator=new MenuInflater(this);
            inflator.inflate(R.menu.menu_context,menu);
    
            super.onCreateContextMenu(menu, v, menuInfo);
        }
    
    1.4 Item 点击事件
        @Override
        public boolean onContextItemSelected(MenuItem item) {
    
            switch (item.getItemId()){
                case R.id.item_context_item1:
                    toast("Item1");
                    break;
                 ....
            }
            return super.onContextItemSelected(item);
        }
    

    1.5 ListView 注册 ContextMenu

    registerForContextMenu(lv)
    

    通过 AdapterContextMenuInfo 来获取是点击ItemPosition

    @Override
    public boolean onContextItemSelected(MenuItem item) {
    
        AdapterView.AdapterContextMenuInfo menuInfo = (AdapterView.AdapterContextMenuInfo) item.getMenuInfo();
          Toast.makeText(this, "menuInfo.position:" + menuInfo.position, Toast.LENGTH_SHORT).show();
        return super.onContextItemSelected(item);
    }
    

    2.PopupMenu

    // Show Popup Menu
    void showPopupMenu(Context mContext,View view){
    
        // 为View指定 PopupMenu
        PopupMenu pm=new PopupMenu(mContext,view);
        // 指定 Menu 文件
        pm.getMenuInflater().inflate(R.menu.menu_test,pm.getMenu());
        //Item 点击事件
        pm.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                toast(item.getTitle());
                return true;
            }
        });
        pm.show(); //显示
    }
    
  • 相关阅读:
    关于json操作,这里再为大家推荐几款比较实用的json在线工具
    JS操作JSON总结
    HTML WebSocket
    HTML应用程序缓存
    前段也能学习网址
    简述jpg。Gif。png-8.png-24的区别,分别使用场景
    HTML相关问题
    html5移动端知识点总结
    html5本地存储(localStorage)使用介绍
    node环境变量----新全局包管理配置
  • 原文地址:https://www.cnblogs.com/-Tiger/p/9742475.html
Copyright © 2011-2022 走看看