android popupwindow 弹出窗口在控件上方居中,比控件大一倍


        android中菜单在底部时,点击需要向上弹出popupwindow窗口,需要居中,并且比菜单按钮的控件的大小大一倍,综合了一下popupwindow各种设置位置的方法:

// 相对某个控件的位置(正左下方),无偏移
pop.showAsDropDown(View anchor) 
// 相对某个控件的位置,有偏移,xoff 为 X 轴的偏移量,yoff 为 Y 轴的偏移量                          
pop.showAsDropDown(View anchor, int xoff, int yoff)
// 在父容器的什么位置,gravity 为相对位置,如:正中央 Gravity.CENTER、下方 Gravity.BOTTOM、Gravity.RIGHT|Gravity.BOTTOM 右下方等,后面两个参数为 x/y 轴的偏移量。
pop.showAtLocation(View parent, int gravity, int x, int y) 

        参考以上的方法,可以这样设置,使用showAsDropDown方法,让弹出的窗口向左偏移菜单控件的1/2,高度微调为10,如下代码:

		// 创建弹出窗口
		popupMenu = new PopupWindow(view, sourceView.getWidth() * 2,
				LayoutParams.WRAP_CONTENT + 200);

		ColorDrawable cd = new ColorDrawable(R.color.white);//<span style="color: rgb(255, 0, 0); font-size: 24px; font-family: Arial, Helvetica, sans-serif;">sourceView为菜单控件</span>
		popupMenu.setBackgroundDrawable(cd);
		popupMenu.update();
		popupMenu.setInputMethodMode(PopupWindow.INPUT_METHOD_NEEDED);
		popupMenu.setTouchable(true); // 设置popupwindow可点击
		popupMenu.setOutsideTouchable(true); // 设置popupwindow外部可点击
		popupMenu.setFocusable(true); // 获取焦点
		ColorDrawable dw = new ColorDrawable(0x00);
		popupMenu.setBackgroundDrawable(dw);

		popupMenu.setTouchInterceptor(new View.OnTouchListener() {

			@Override
			public boolean onTouch(View v, MotionEvent event) {
				if (event.getAction() == MotionEvent.ACTION_OUTSIDE) {
					popupMenu.dismiss();
					return true;
				}
				return false;
			}
		});

	}

	@Override
	public PopupWindow createPupupWindow() {
		return popupMenu;
	}

	@Override
	public void showPopupMenu() {
		if (popupMenu != null && popupMenu.isShowing()) {
			popupMenu.dismiss();
		} else {
			popupMenu
					<span style="font-size:24px;color:#ff0000;">.showAsDropDown(sourceView, -sourceView.getWidth() / 2, 10);</span>
		}

	}

      以上就可以决定窗口的布局。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值