Android 彈出菜單示例(Android sample API22)

Android 彈出菜單示例#

這個(gè)示例展示如何使用PopupMenu來現(xiàn)實(shí)和一個(gè)彈出的菜單分俯。

說明

這個(gè)示例展示一個(gè)水果的列表,每一個(gè)列表項(xiàng)均可以點(diǎn)擊,每一個(gè)列表項(xiàng)的右邊有一個(gè)圖片按鈕闲孤,點(diǎn)擊該按鈕,將彈出一個(gè)菜單烤礁。

這個(gè)示例運(yùn)行在Android4.0以上讼积,不支持Android4.0以下版本!

運(yùn)行效果

Paste_Image.png
Paste_Image.png

代碼

latyout/activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<ListView xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/list_fruits"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingLeft="16dp"
    android:paddingRight="16dp"/>

水果列表中每一個(gè)列表項(xiàng)的布局
layout/list_item.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:paddingTop="8dp"
    android:paddingBottom="8dp"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/image_fruit"
        android:layout_width="52dp"
        android:layout_height="52dp"
        android:contentDescription="@string/image_fruit_des" />

    <TextView
        android:layout_marginStart="8dp"
        android:layout_marginLeft="8dp"
        android:gravity="center_vertical"
        android:id="@+id/name_fruit"
        android:layout_width="0dp"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:textAppearance="?android:attr/textAppearanceListItem" />

    <ImageView
        android:id="@+id/popupButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="end|center_vertical"
        android:clickable="true"
        android:contentDescription="@string/image_popup"
        android:padding="8dp"
        android:src="@android:drawable/arrow_down_float" />

</LinearLayout>

values/strings.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <string name="app_name">彈出菜單示例</string>
    <string name="action_settings">設(shè)置</string>
    <string name="image_fruit_des">水果的圖片</string>
    <string name="image_popup">彈出菜單按鈕</string>
    <string name="menu_popup">刪除</string>

</resources>

menu/popup_menu.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<!--彈出刪除菜單-->
<item 
    android:id="@+id/menu_popup_remove"
    android:title="@string/menu_popup"
    />
</menu>

src/你的應(yīng)用的包名/Fruits.java

package com.ddzj.listpopupmenu;
/*
 * 數(shù)據(jù)源
 */
public class Fruits {
    // 水果的圖片
    public static final int[] IMAGE_FRUITS_ID = {R.drawable.ic_apple,R.drawable.ic_apricot,
            R.drawable.ic_banana,R.drawable.ic_blueberry,R.drawable.ic_cherry,
            R.drawable.ic_chestnut,R.drawable.ic_dragonfruit,R.drawable.ic_grape,
            R.drawable.ic_grapefruit,R.drawable.ic_litchi,R.drawable.ic_loquat,
            R.drawable.ic_mango,R.drawable.ic_mulberry,R.drawable.ic_orange,
            R.drawable.ic_other_banana,R.drawable.ic_peach,R.drawable.ic_pineapple,
            R.drawable.ic_plum,R.drawable.ic_strawberry,R.drawable.ic_yangtao};
    // 水果的名字
    public static final String[] FRUITS={"蘋果","杏子","香蕉","藍(lán)莓","櫻桃","栗子",
            "火龍果","葡萄","柚子","荔枝","枇杷","芒果","桑椹","橘子","芭蕉",
            "桃子","鳳梨","李子","草莓","獼猴桃"};
}

src/你的應(yīng)用的包名/MainActivity.java

package com.ddzj.listpopupmenu;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;
import android.widget.PopupMenu;
import android.widget.PopupMenu.OnMenuItemClickListener;
import android.widget.SimpleAdapter;
import android.widget.Toast;

public class MainActivity extends Activity implements OnItemClickListener, OnClickListener {
    
    private ListView mListView; // 用戶展示列表的ListView控件
    private SimpleAdapter mAdapter; // 數(shù)據(jù)與ListView之間的連接橋梁
    private List<Map<String, Object>> mFruitList ; // 存儲數(shù)據(jù)的List
    
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init();
    }

    /*
     * 初始化
     */
    private void init() {
        // TODO Auto-generated method stub
        mListView = (ListView) findViewById(R.id.list_fruits);
        mFruitList = new ArrayList<Map<String,Object>>();
        // 將數(shù)據(jù)添加到mFruitList中
        for (int i = 0,z=Fruits.FRUITS.length; i < z; i++) {
            Map<String, Object> map = new HashMap<String, Object>();
            map.put("image", Fruits.IMAGE_FRUITS_ID[i]);
            map.put("name", Fruits.FRUITS[i]);
            mFruitList.add(map);
        }
        /*
         * 創(chuàng)建適配器
         */
        mAdapter = new FruitAdapter(this, mFruitList, R.layout.list_item, 
                new String[]{"image","name"}, new int[]{R.id.image_fruit,R.id.name_fruit});
        mListView.setAdapter(mAdapter);
        mListView.setOnItemClickListener(this);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    /*
     * 當(dāng)列表中的項(xiàng)被點(diǎn)擊時(shí)脚仔,回調(diào)此方法
     */
    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
        // 彈出吐司勤众,告訴用戶點(diǎn)擊的水果名稱
        Toast.makeText(this, Fruits.FRUITS[position], Toast.LENGTH_SHORT).show();
    }
    
    /*
     * 自定義的適配器,繼承自SimpleAdapter
     */
    class FruitAdapter extends SimpleAdapter{

        public FruitAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from,
                int[] to) {
            super(context, data, resource, from, to);
        }
        /*
         * 重寫getView方法
         */
        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            
            View view = super.getView(position, convertView, parent);
            View popupButton = view.findViewById(R.id.popupButton);
            popupButton.setOnClickListener(MainActivity.this);
            // getItem(position)鲤脏,在數(shù)據(jù)集中得到與指定位置對應(yīng)的數(shù)據(jù)項(xiàng)们颜。即mFruitList中對應(yīng)位置的數(shù)據(jù)
            // setTag(getItem(position));這里的是將getItem(position)返回的數(shù)據(jù)存儲在popupButton中,
            // 以便后面可以通過getTag()得到該數(shù)據(jù)并將其從mFruitList中移除
            popupButton.setTag(getItem(position));
            return view;
        }
    }
    
    /*
     * 當(dāng)列表項(xiàng)中最右邊的向下按鈕被點(diǎn)擊時(shí)猎醇,回調(diào)此方法
     */
    @Override
    public void onClick(final View v) {
        // Causes the Runnable to be added to the message queue. The runnable will be run on the user interface thread.
        v.post(new Runnable() {
            
            @Override
            public void run() {
                // 彈出一個(gè)菜單
                showPopupMenu(v);
            }
        });
    }

    private void showPopupMenu(View v) {
        final Object tag = v.getTag(); // 得到我們存儲在v中的數(shù)據(jù)
        PopupMenu popupMenu = new PopupMenu(MainActivity.this, v);
        popupMenu.getMenuInflater().inflate(R.menu.popup_menu, popupMenu.getMenu());
        popupMenu.setOnMenuItemClickListener(new OnMenuItemClickListener() {
            
            @Override
            public boolean onMenuItemClick(MenuItem item) {
                mFruitList.remove(tag); // 從mFruitList中移除
                mAdapter.notifyDataSetChanged(); // 提醒適配器數(shù)據(jù)改變窥突,要求刷新列表
                return true;
            }
        });
        popupMenu.show(); // 顯示彈出菜單
    }
}

圖片資源

ic_grape.png

ic_grapefruit.png

ic_litchi.png

ic_loquat.png

ic_mango.png

ic_mulberry.png

ic_orange.png

ic_other_banana.png

ic_peach.png

ic_pineapple.png

ic_plum.png

ic_strawberry.png

ic_yangtao.png

ic_apple.png

ic_apricot.png

ic_banana.png

ic_blueberry.png

ic_cherry.png

ic_chestnut.png

ic_dragonfruit.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市硫嘶,隨后出現(xiàn)的幾起案子阻问,更是在濱河造成了極大的恐慌,老刑警劉巖沦疾,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件称近,死亡現(xiàn)場離奇詭異,居然都是意外死亡哮塞,警方通過查閱死者的電腦和手機(jī)刨秆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來忆畅,“玉大人衡未,你說我怎么就攤上這事。” “怎么了缓醋?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵剔交,是天一觀的道長。 經(jīng)常有香客問我改衩,道長,這世上最難降的妖魔是什么驯镊? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任葫督,我火速辦了婚禮,結(jié)果婚禮上板惑,老公的妹妹穿的比我還像新娘橄镜。我一直安慰自己,他們只是感情好冯乘,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布洽胶。 她就那樣靜靜地躺著,像睡著了一般裆馒。 火紅的嫁衣襯著肌膚如雪姊氓。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天喷好,我揣著相機(jī)與錄音翔横,去河邊找鬼。 笑死梗搅,一個(gè)胖子當(dāng)著我的面吹牛禾唁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播无切,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼荡短,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了哆键?” 一聲冷哼從身側(cè)響起掘托,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎洼哎,沒想到半個(gè)月后烫映,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡噩峦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年锭沟,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片识补。...
    茶點(diǎn)故事閱讀 40,680評論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡族淮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情祝辣,我是刑警寧澤贴妻,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站蝙斜,受9級特大地震影響名惩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜孕荠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一娩鹉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧稚伍,春花似錦弯予、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至垦搬,卻和暖如春呼寸,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背悼沿。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工等舔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人糟趾。 一個(gè)月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓慌植,卻偏偏與公主長得像,于是被迫代替她去往敵國和親义郑。 傳聞我的和親對象是個(gè)殘疾皇子蝶柿,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容