Android Material Design:PopupMenu



Android Material Design:PopupMenu

Android Material Design 引入的PopupMenu类似过去的上下文菜单,但是更灵活。
如图所示:


现在给出实现上图PopupMenu的代码。
本例是一个普通的Button触发弹出PopupMenu。

测试的MainActivity.java :

package zhangphil.materialdesign;

import android.app.Activity;
import android.os.Bundle;
import android.support.v7.widget.PopupMenu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.Toast;

public class MainActivity extends Activity {

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

		final Button button = (Button) findViewById(R.id.button);
		button.setOnClickListener(new View.OnClickListener() {

			@Override
			public void onClick(View v) {
				showPopupMenu(button);
			}
		});
	}

	private void showPopupMenu(View view) {
		// View当前PopupMenu显示的相对View的位置
		PopupMenu popupMenu = new PopupMenu(this, view);

		// menu布局
		popupMenu.getMenuInflater().inflate(R.menu.main, popupMenu.getMenu());

		// menu的item点击事件
		popupMenu.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
			@Override
			public boolean onMenuItemClick(MenuItem item) {
				Toast.makeText(getApplicationContext(), item.getTitle(), Toast.LENGTH_SHORT).show();
				return false;
			}
		});

		// PopupMenu关闭事件
		popupMenu.setOnDismissListener(new PopupMenu.OnDismissListener() {
			@Override
			public void onDismiss(PopupMenu menu) {
				Toast.makeText(getApplicationContext(), "关闭PopupMenu", Toast.LENGTH_SHORT).show();
			}
		});

		popupMenu.show();
	}
}

MainActivity.java需要的activity_main布局文件只含一个普通的Android Button,在次不再赘述。


位于menu目录下的main.xml:

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools" >

    <item
        android:id="@+id/action_open"
        android:orderInCategory="100"
        android:title="打开"
        app:showAsAction="never"/>
    <item
        android:id="@+id/action_new"
        android:orderInCategory="100"
        android:title="新建"
        app:showAsAction="never"/>
    <item
        android:id="@+id/action_del"
        android:orderInCategory="100"
        android:title="删除"
        app:showAsAction="never"/>

</menu>

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Android PopupMenu 样式可以通过自定义布局文件来实现。以下是一个简单的例子: 首先,在 res/layout 文件夹下创建一个新的布局文件,例如 popup_menu.xml,然后添加以下代码: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical" android:background="@android:color/white" android:padding="8dp"> <TextView android:id="@+id/item1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="8dp" android:textColor="@android:color/black" android:text="Item 1"/> <TextView android:id="@+id/item2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="8dp" android:textColor="@android:color/black" android:text="Item 2"/> <TextView android:id="@+id/item3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="8dp" android:textColor="@android:color/black" android:text="Item 3"/> </LinearLayout> ``` 然后在你的 Activity 中,使用以下代码来创建 PopupMenu 并设置自定义布局文件: ```java PopupMenu popupMenu = new PopupMenu(this, view); // 设置自定义布局文件 popupMenu.setContentView(R.layout.popup_menu); // 获取布局文件中的 TextView TextView item1 = popupMenu.getContentView().findViewById(R.id.item1); TextView item2 = popupMenu.getContentView().findViewById(R.id.item2); TextView item3 = popupMenu.getContentView().findViewById(R.id.item3); // 设置 TextView 的点击事件 item1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理点击事件 popupMenu.dismiss(); } }); item2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理点击事件 popupMenu.dismiss(); } }); item3.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 处理点击事件 popupMenu.dismiss(); } }); // 显示 PopupMenu popupMenu.show(); ``` 这样就可以自定义 PopupMenu 的样式了。你可以根据自己的需求修改布局文件以及设置点击事件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值