1. 问题描述
PopupWindow 中的 showAsDropDown(View anchor) 用于在指定锚点View下方显示 PopupWindow,在Android 7.0 (api<=23) 以前是没什么问题的,但是在Android 7.x系统上,会在某些情况下出现兼容问题:
如果指定 PopupWindow 的高度为 MATCH_PARENT,调用 showAsDropDown(View anchor) 时,在 7.0 之前,会在锚点 anchor 下边缘到屏幕底部之间显示 PopupWindow;而在 7.0、7.1 系统上的 PopupWindow 会占据整个屏幕(除状态栏之外)。(SDK >= 24时,PopupWindow高度为 match_parent 时,会占据整个屏幕,需要重新设置。)
如果指定 PopupWindow 的高度为 WRAP_CONTENT, 调用 showAsDropDown(View anchor) 时,便不会出现兼容性的问题。
如果指定 PopupWindow 的高度为自定义的值height,调用 showAsDropDown(View anchor)时, 如果 height > 锚点 anchor 下边缘与屏幕底部的距离, 则还是会出现7.0、7.1上显示异常的问题;否则,不会出现该问题。可以看出,情况1和2是情况3的特例。
解决方案
参考:http://tianma.pro/post/1634332613/
如果出现上述分析中的兼容性问题,可以使用 showAtLocation() 方法替代 showAsDropDown() , 示例代码如下。
2. 问题描述
首次进入页面,在指定位置弹出提示语。
处理方案:使用popupwindow展示,设置offX、offY达到指定位置。
出现问题:不用分辨率手机,位置不同。
小屏手机起始位置:
小屏手机设置offX = DensityUtil.dip2px(36)。
大屏手机起始位置:
大屏手机设置offX = DensityUtil.dip2px(36)。
问题分析
设置offX后,其移动的距离,在“百宝箱”之外是符合屏幕适配的【红色箭头的位置,在“家”下面】,而在“百宝箱”内部是不符合的。而百宝箱内部使用recyclerview均分布局。
问题1:背景图.9.png
箭头两端都能拉伸,不能确定箭头的位置。
问题2:平分布局
平分布局View中的元素,与其他View中的元素,位置关系不再保持一致,会随着屏幕分辨率而变化。(1080-30dp)/ 4
解决方案
UI提供箭头距离确定的.9图,并且固定popupwindow的宽度,通过计算得出offX
注意事项:popupwindow的高宽不能在XML中进行设置,因为会被覆盖。
View.inflate(getContext(), R.layout.host_house_can_see_time_pop_rent, null);
//高宽值无效,因为指定没有父布局
new PopupWindow(view, DensityUtil.dip2px(264), LinearLayout.LayoutParams.WRAP_CONTENT); // 生效