Android Kotlin создает собственное всплывающее меню

Я пытаюсь создать всплывающее меню так же, как это при нажатии кнопки в Android, используя Koltin. Я искал SOF, и Google не нашел никаких предложений. Может кто-нибудь предоставить пример кода для достижения этого с помощью kotlin.

3 ответа

Решение

Наконец то я это сделал, может кому то помочь

Шаг 1. Сначала создайте activity_main.xml содержит кнопку с именем my_button

Шаг 2. Затем возьмите header_menu.xml в res/menu:

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

    <item
        android:id="@+id/header1"
        android:title="H1" />
    <item
        android:id="@+id/header2"
        android:title="H2" />
    <item
        android:id="@+id/header3"
        android:title="H3" />

</menu>

Шаг 3. Наконец, в MainActivity.java используйте его так:

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        val clickListener = View.OnClickListener { view ->
            when (view.id) {
                R.id.my_button -> {
                    showPopup(view)
                }
            }
        }

        my_button.setOnClickListener(clickListener)
    }

    private fun showPopup(view: View) {
        var popup: PopupMenu? = null;
        popup = PopupMenu(this, view)
        popup.inflate(R.menu.header_menu)

        popup.setOnMenuItemClickListener(PopupMenu.OnMenuItemClickListener { item: MenuItem? ->

            when (item!!.itemId) {
                R.id.header1 -> {
                    Toast.makeText(this@MainActivity, item.title, Toast.LENGTH_SHORT).show();
                }
                R.id.header2 -> {
                    Toast.makeText(this@MainActivity, item.title, Toast.LENGTH_SHORT).show();
                }
                R.id.header3 -> {
                    Toast.makeText(this@MainActivity, item.title, Toast.LENGTH_SHORT).show();
                }
            }

            true
        })

        popup.show()
    }

Следуя хорошему и чистому принципу Kotlin: Вы также можете сделать это:

1) в вашем XML-файле: (но "onClick" в xml можно использовать и во время выполнения Java)

<Button 
  ........
  android:onClick="showPopUp"
  ....../>

2) в вашем файле.kt: (используя лямбда-выражение kotlin)

fun showPopUp(view: View) {
    val popupMenu = PopupMenu(this, view)
    val inflater = popupMenu.menuInflater
    inflater.inflate(R.menu.header_menu, popupMenu.menu)
    popupMenu.show()

    popupMenu.setOnMenuItemClickListener {
        when(it.itemId) {
            R.id.header1 -> {
                Toast.makeText(this@MainActivity, item.title, Toast.LENGTH_SHORT).show();
            }
            R.id.header2 -> {
                Toast.makeText(this@MainActivity, item.title, Toast.LENGTH_SHORT).show();
            }
            R.id.header3 -> {
                Toast.makeText(this@MainActivity, item.title, Toast.LENGTH_SHORT).show();
            }
            ...........
        }
        true
    }
}

для людей, которые ненавидят xml:

          private fun showOverflowMenu(context: Context, anchor: View) {
        val menu = PopupMenu(context, anchor)

        menu.menu.apply {
            add("Rename").setOnMenuItemClickListener {
                // TODO rename
                true
            }
            add("change context").setOnMenuItemClickListener {
                // change stuff
                true
            }

            add("delete").setOnMenuItemClickListener {
                // TODO delete some stuff
                true
            }
        }

        menu.show()
    }
Другие вопросы по тегам