เมนูแบบเลื่อนลง / ป๊อปอัปที่กำหนดเองของ Android


127

ฉันจะทำเมนูแบบเลื่อนลง / ป๊อปอัพที่กำหนดเองได้อย่างไร?

ฉันต้องการให้มันทำงานเหมือนเมนูป๊อปอัพ (ยึดกับมุมมอง) และทำบางอย่างเมื่อฉันคลิกรายการจากเมนู

ฉันจะเพิ่มรายการในเมนูด้วยรหัสรักษาความสูงของเมนูและทำให้เลื่อนได้อย่างไรหากมีมากกว่า 5 รายการ ฉันไม่จำเป็นต้องเพิ่มรูปภาพใด ๆ เพียงแค่ข้อความ

ใส่คำอธิบายภาพที่นี่

คำตอบ:


316

ปรับปรุง : การสร้างเมนูป๊อปอัพในหุ่นยนต์ที่มี Kotlin ดูคำตอบของฉันที่นี่

ในการสร้างเมนูป๊อปอัปใน Android ด้วย Java:

สร้างไฟล์เค้าโครงactivity_main.xmlภายใต้res/layoutไดเร็กทอรีซึ่งมีเพียงปุ่มเดียว

ชื่อไฟล์: activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    xmlns:tools="http://schemas.android.com/tools"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:paddingBottom="@dimen/activity_vertical_margin"  
    android:paddingLeft="@dimen/activity_horizontal_margin"  
    android:paddingRight="@dimen/activity_horizontal_margin"  
    android:paddingTop="@dimen/activity_vertical_margin"  
    tools:context=".MainActivity" >  

    <Button  
        android:id="@+id/button1"  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:layout_alignParentLeft="true"  
        android:layout_alignParentTop="true"  
        android:layout_marginLeft="62dp"  
        android:layout_marginTop="50dp"  
        android:text="Show Popup" />  

</RelativeLayout>  

สร้างไฟล์popup_menu.xmlภายใต้res/menuไดเร็กทอรี

ประกอบด้วยสามรายการดังที่แสดงด้านล่าง

ชื่อไฟล์: poupup_menu.xml

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

    <item  
        android:id="@+id/one"  
        android:title="One"/>  

    <item  
        android:id="@+id/two"  
        android:title="Two"/>  

    <item  
        android:id="@+id/three"  
        android:title="Three"/>  

</menu>  

คลาส MainActivity ซึ่งแสดงเมนูป๊อปอัพเมื่อคลิกปุ่ม

ชื่อไฟล์: MainActivity.java

public class MainActivity extends Activity {  
    private Button button1;  

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

        button1 = (Button) findViewById(R.id.button1);
        button1.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                //Creating the instance of PopupMenu
                PopupMenu popup = new PopupMenu(MainActivity.this, button1);
                //Inflating the Popup using xml file
                popup.getMenuInflater()
                    .inflate(R.menu.popup_menu, popup.getMenu());

                //registering popup with OnMenuItemClickListener
                popup.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
                    public boolean onMenuItemClick(MenuItem item) {
                        Toast.makeText(
                            MainActivity.this,
                            "You Clicked : " + item.getTitle(),
                            Toast.LENGTH_SHORT
                        ).show();
                        return true;
                    }
                });

                popup.show(); //showing popup menu
            }
        }); //closing the setOnClickListener method
    }
}

ในการเพิ่มแบบเป็นโปรแกรม:

PopupMenu menu = new PopupMenu(this, view);

menu.getMenu().add("One");
menu.getMenu().add("Two");
menu.getMenu().add("Three");

menu.show();

ไปที่ลิงค์นี้เพื่อสร้างเมนูโดยใช้โปรแกรม


เฮ้ขอบคุณ !! จะทำอย่างไรหากต้องการเพิ่มรายการในเมนู?. ฉันสามารถทำได้ด้วยรหัส?
stanete

ยินดีต้อนรับ .. ใช่คุณสามารถเพิ่มรายการอื่น ๆ ใน popup_menu.xml
Shylendra Madda

3
ตกลงฉันพบวิธีการเพิ่มรายการ: menu.getMenu (). add ("item"); แต่ฉันจะปรับแต่งเมนูได้อย่างไร?
stanete

1
ตอนนี้ยังสามารถใช้ในเวอร์ชันที่ต่ำกว่าเช่น 3.0 (รังผึ้ง) โดยใช้ไลบรารีการสนับสนุนที่เข้ากันได้กับ v7 ..
AndroidMech

1
<item android: id = "@ + id / google_plus" android: title = "@ string / menu_google_plus" android: icon = "@ drawable / add_by_gp" android: showAsAction = "ifRoom | withText" /> นี่คือวิธีที่ฉันเพิ่ม แต่ฉันมองไม่เห็นภาพพร้อมข้อความ
Mr.G

8

ฉันรู้ว่านี่เป็นคำถามเก่า แต่ฉันพบคำตอบอื่นที่ได้ผลดีกว่าสำหรับฉันและดูเหมือนจะไม่ปรากฏในคำตอบใด ๆ

สร้างเค้าโครง xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:paddingTop="5dip"
    android:paddingBottom="5dip"
    android:paddingStart="10dip"
    android:paddingEnd="10dip">

<ImageView
    android:id="@+id/shoe_select_icon"
    android:layout_width="30dp"
    android:layout_height="30dp"
    android:layout_gravity="center_vertical"
    android:scaleType="fitXY" />

<TextView
    android:id="@+id/shoe_select_text"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:textSize="20sp"
    android:paddingStart="10dp"
    android:paddingEnd="10dp"/>

</LinearLayout>

สร้าง ListPopupWindow และแผนที่ที่มีเนื้อหา:

ListPopupWindow popupWindow;
List<HashMap<String, Object>> data = new ArrayList<>();
HashMap<String, Object> map = new HashMap<>();
    map.put(TITLE, getString(R.string.left));
    map.put(ICON, R.drawable.left);
    data.add(map);
    map = new HashMap<>();
    map.put(TITLE, getString(R.string.right));
    map.put(ICON, R.drawable.right);
    data.add(map);

จากนั้นเมื่อคลิกแสดงเมนูโดยใช้ฟังก์ชันนี้:

private void showListMenu(final View anchor) {
    popupWindow = new ListPopupWindow(this);

    ListAdapter adapter = new SimpleAdapter(
            this,
            data,
            R.layout.shoe_select,
            new String[] {TITLE, ICON}, // These are just the keys that the data uses (constant strings)
            new int[] {R.id.shoe_select_text, R.id.shoe_select_icon}); // The view ids to map the data to

    popupWindow.setAnchorView(anchor);
    popupWindow.setAdapter(adapter);
    popupWindow.setWidth(400);
    popupWindow.setOnItemClickListener(new AdapterView.OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
            switch (position){
                case 0:
                    devicesAdapter.setSelectedLeftPosition(devicesList.getChildAdapterPosition(anchor));
                    break;
                case 1:
                    devicesAdapter.setSelectedRightPosition(devicesList.getChildAdapterPosition(anchor));
                    break;
                default:
                    break;
            }
            runOnUiThread(new Runnable() {
                @Override
                public void run() {
                    devicesAdapter.notifyDataSetChanged();
                }
            });
            popupWindow.dismiss();
        }
    });
    popupWindow.show();
}

6

ทาง Kotlin

fun showPopupMenu(view: View) {
    PopupMenu(view.context, view).apply {
                menuInflater.inflate(R.menu.popup_men, menu)
                setOnMenuItemClickListener { item ->
                    Toast.makeText(view.context, "You Clicked : " + item.title, Toast.LENGTH_SHORT).show()
                    true
                }
            }.show()
}

UPDATE:ในโค้ดด้านบนฟังก์ชันใช้จะส่งกลับthisซึ่งไม่จำเป็นเพื่อให้เราสามารถใช้งานได้runซึ่งไม่ส่งคืนอะไรเลยและเพื่อให้ง่ายขึ้นเรายังสามารถลบวงเล็บปีกกาของวิธีการ showPopupMenu ได้

เรียบง่ายยิ่งขึ้น:

fun showPopupMenu(view: View) = PopupMenu(view.context, view).run {
            menuInflater.inflate(R.menu.popup_men, menu)
            setOnMenuItemClickListener { item ->
                Toast.makeText(view.context, "You Clicked : ${item.title}", Toast.LENGTH_SHORT).show()
                true
            }
            show()
        }

3

ขั้นแรกสร้างโฟลเดอร์ชื่อ“ menu” ในโฟลเดอร์“ res”

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >

    <item
        android:id="@+id/search"
        android:icon="@android:drawable/ic_menu_search"
        android:title="Search"/>
    <item
        android:id="@+id/add"
        android:icon="@android:drawable/ic_menu_add"
        android:title="Add"/>
    <item
        android:id="@+id/edit"
        android:icon="@android:drawable/ic_menu_edit"
        android:title="Edit">
        <menu>
            <item
                android:id="@+id/share"
                android:icon="@android:drawable/ic_menu_share"
                android:title="Share"/>
        </menu>
    </item>

</menu>

จากนั้นสร้างชั้นกิจกรรมของคุณ:

public class PopupMenu1 extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.popup_menu_1);
    }

    public void onPopupButtonClick(View button) {
        PopupMenu popup = new PopupMenu(this, button);
        popup.getMenuInflater().inflate(R.menu.popup, popup.getMenu());

        popup.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
            public boolean onMenuItemClick(MenuItem item) {
                Toast.makeText(PopupMenu1.this,
                        "Clicked popup menu item " + item.getTitle(),
                        Toast.LENGTH_SHORT).show();
                return true;
            }
        });

        popup.show();
    }
}
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.