在带屏烟机项目中,遇到了自定义Dialog的使用场景
在之前的dialog的使用过程中遇到了一些问题,比如圆角的背景,但是又不能使用背景图片,或者使用了背景图片也不能圆角的问题.问题还真多.
这次遇到的问题是自定义布局,出来之后上面有一块空白.高宽度定义问题
首先看下设计图:
明显是要使用自定义的Dialog
好的,写好XML,运行预览
出现了问题
1.虽然在XML 中写好了高宽度,但是完全是不起作用的,直接给我全屏了.
2.顶部有部分空白?不知道哪里来的.
经过各种Google,发现高宽度必须要通过 window 对象的layoutparam 来修改
顶部空白是因为Dialog中默认会有Title,开始得到的解决方案是自定义继承AlertDialog,但是这个代价有点大哦,后来才找到正确的解决方案
解决方案
Window dialogWindow = dialog.getWindow(); WindowManager.LayoutParams lp = dialogWindow.getAttributes(); lp.width = Utils.dip2px(context, realWidth); // 宽度 lp.height = Utils.dip2px(context, realHeight); // 高度 dialogWindow.setAttributes(lp);(必须要加上这句才行)
这里需要注意的是lp.width 和lp.height 就是高宽度,这里接收的是px 值,不是dp,不是dp,不是dp,重要的事情说三遍,记住代码里面只人px ,这里我们知道了dp值,可以通过工具类转换出真正的px 值
Dialog dialog = new Dialog(context); dialog.requestWindowFeature(Window.FEATURE_NO_TITLE); dialog.setContentView(view);
在setContentView 之前,设置 dialog.requestWindowFeature(Window.FEATURE_NO_TITLE);
或者给dialog 设置style
3.另外说下最开始提到的问题的解决方案(圆角背景等等)
圆角背景首先需要让linerlayout(或者其他布局)圆角,我们可以自定义shape ,使用xml 画圆角,之后,(重点)我们需要自定义style ,可参照上图,设置透明的背景,这样就可以实现圆角的背景(非常漂亮哦)
4.还有个奇葩问题是,有些时候底部布局的margin和pading 都不会起作用(怀疑是自定义Style 引起的),这时候,可以在底部放置一个固定高度的View 即可
在项目中,这样的dialog 还是很多的,所以想到可以制作工具类.以下是原创工具类
传入context ,自定义的View,dp 宽度,dp 高度,dialog 是否可以取消,取消的回调就可以了,如果不需要取消的回调,直接传入null 即可,这样就可以简易的使用自定义View 的dialog 啦
使用方法如下: