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()
}