Android中自定义PoupWindow的实现

需求,通过点击悬浮按钮,弹出一个含有两个按钮的框,供用户进行操作。

首先自定义一个布局文件service_layout.xml,代码如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <ImageButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/paizhao" />

    <ImageButton
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/paizhao" />
</LinearLayout>

效果如下:


然后在Activity中加入这个弹窗,代码如下:

private FloatingActionButton floatingActionButton=null;

private WebView webView=null;
private View serviceView=null;
private PopupWindow popupWindow=null;

@Override
protected void onCreate(Bundle savedInstanceState) {
	super.onCreate(savedInstanceState);
	setContentView(R.layout.activity_home); 
	//初始化悬浮按钮
	floatingActionButton=(FloatingActionButton)findViewById(R.id.fab);
	//设置弹出框
	serviceView= LayoutInflater.from(HomeActivity.this).inflate(R.layout.service_popu,null);
	popupWindow=new PopupWindow();
	popupWindow.setContentView(serviceView);//设置要弹出的界面
	popupWindow.setWidth(DrawerLayout.LayoutParams.WRAP_CONTENT);//设置弹出框的尺寸为适应控件
	popupWindow.setHeight(DrawerLayout.LayoutParams.WRAP_CONTENT);
	popupWindow.setFocusable(true);
	popupWindow.setAnimationStyle(R.style.PopupServiceAnimation);//设置弹出的动作,要不然太强硬
	popupWindow.setFocusable(true);
	popupWindow.setTouchable(true);

	floatingActionButton.setOnClickListener(new View.OnClickListener() {
		@Override
		public void onClick(View view) {
			//获取悬浮窗的坐标位置
			int[] location = new int[2];
			floatingActionButton.getLocationOnScreen(location);
			int x = location[0];
			int y = location[1];
			popupWindow.showAtLocation(floatingActionButton, Gravity.NO_GRAVITY,x,y-500);
		}
	});
}
代码可能不能直接执行,仅供参考,最后实现的效果如下:




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值