展会信息港展会大全

自定义一个类继承自Dialog类 实现浮动层
来源:互联网   发布日期:2015-10-03 11:31:25   浏览:2147次  

导读:自定义一个类继承自Dialog类,然后在构造方法中,定义这个dialog的布局和一些初始化信息。public class MenuDialog extends Dialog {public MenuDialog(Context context, boolean cancelable, ......

自定义一个类继承自Dialog类,然后在构造方法中,定义这个dialog的布局和一些初始化信息。

public class MenuDialog extends Dialog {

public MenuDialog(Context context, boolean cancelable,

OnCancelListener cancelListener) {

super(context, cancelable, cancelListener);

// TODO Auto-generated constructor stub

}

public MenuDialog(Context context, int theme) {

super(context, theme);

// TODO Auto-generated constructor stub

}

public MenuDialog(Context context) {

//dialog的视图风格

super(context, R.style.Theme_Transparent);

//设置布局文件

setContentView(R.layout.menu_dialog);

//setTitle("Custom Dialog");

//单击dialog之外的地方,可以dismiss掉dialog。

setCanceledOnTouchOutside(true);

// 设置window属性

//LayoutParams a = getWindow().getAttributes();

//getWindow().addFlags(WindowManager.LayoutParams.FLAG_DIM_BEHIND);

//a.gravity = Gravity.TOP;

//a.dimAmount = 1.0f; // 添加背景遮盖

//getWindow().setAttributes(a);

//在下面这种情况下,后台的activity不会被遮盖,也就是只会遮盖此dialog大小的部分

LayoutParams a = getWindow().getAttributes();

a.gravity = Gravity.TOP;

a.dimAmount = 0.0f; // 去背景遮盖

getWindow().setAttributes(a);

//为你的对话框初始化数据

initMenu();

}

然后再需要此dialog的地方,实例化这个dialog就行了。

另附此对话框的主题:

<style name="Theme.Transparent" parent="android:Theme">

<item name="android:windowBackground">@drawable/dialog_box_2</item>//此对话框的背景

<item name="android:windowIsTranslucent">true</item>//对话框是否透明

<item name="android:windowContentOverlay">@null</item>//对话框是否有遮盖

<item name="android:windowNoTitle">true</item>//对话框无标题

<item name="android:windowIsFloating">true</item>//对话框是否浮动

<item name="android:backgroundDimEnabled">false</item>

</style>

赞助本站

人工智能实验室

相关热词: 浮动层

AiLab云推荐
推荐内容
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港