📅  最后修改于: 2021-01-05 08:23:42             🧑  作者: Mango
Android上下文菜单是一个浮动菜单,当用户对元素进行长按时会出现。在上下文菜单上执行的操作仅对所选内容起作用。上下文菜单可以在任何视图上实现,但通常与ListView,GridView或其他视图集合的项一起使用。
通过覆盖onCreateContextMenu()函数来创建上下文菜单。通过调用MenuInflater类的inflate ()方法来扩展菜单资源。要对菜单项执行操作,请覆盖onContextItemSelected()函数。
在此示例中,我们将添加一个ListView并在其项目上实现上下文菜单。长时间单击列表项会显示上下文菜单项,我们可以在这些菜单项上执行相关操作。
创建一个android项目,然后选择基本活动。此活动自动生成菜单选项的代码。
将以下代码添加到布局目录中的activity_main.xml文件中。此代码在创建Basic Activity时自动生成。
在布局目录的content_main.xml文件中添加以下代码。在此文件中,我们添加了一个ListView。
在字符串.xml文件中添加以下代码。
Kotlin ContextMenu
Call
Sms
在菜单目录的menu_main.xml文件中添加以下代码。添加item标记,该标记为上下文菜单创建菜单项。
在MianActivity.kt类中添加以下代码。在此类中,我们创建一个列表视图,并在其项目上实现上下文菜单。要添加上下文菜单的列表项,请使用registerForContextMenu(list)方法。要创建上下文菜单,请重写onCreateContextMenu()并调用MenuInflater类的inflate()方法。
要对上下文菜单的每个项目执行操作,请覆盖onContextItemSelected()函数。
package example.javatpoint.com.kotlincontextmenu
import android.os.Bundle
import android.support.v7.app.AppCompatActivity
import android.view.ContextMenu
import android.view.MenuItem
import android.view.View
import android.widget.ArrayAdapter
import kotlinx.android.synthetic.main.activity_main.*
import kotlinx.android.synthetic.main.content_main.*
import android.widget.Toast
class MainActivity : AppCompatActivity() {
private val contact = arrayOf("Akash","Vikash","John","Rahul","Ajay")
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
setSupportActionBar(toolbar)
val arrayAdapter: ArrayAdapter = ArrayAdapter(this,android.R.layout.simple_list_item_1,contact)
listView.adapter = arrayAdapter
registerForContextMenu(listView)
}
override fun onCreateContextMenu(menu: ContextMenu?, v: View?, menuInfo: ContextMenu.ContextMenuInfo?) {
super.onCreateContextMenu(menu, v, menuInfo)
val inflater = menuInflater
inflater.inflate(R.menu.menu_main, menu)
}
override fun onContextItemSelected(item: MenuItem?): Boolean {
return when (item!!.itemId) {
R.id.call ->{
Toast.makeText(applicationContext, "call code", Toast.LENGTH_LONG).show()
return true
}
R.id.sms ->{
Toast.makeText(applicationContext, "sms code", Toast.LENGTH_LONG).show()
return true
}
else -> super.onOptionsItemSelected(item)
}
}
}