MyDialog.java:
package com.weijie.app_user.activity.login; import android.app.Dialog; import android.content.Context; import android.view.Gravity; import android.view.View; import android.view.Window; import android.view.WindowManager; public class MyDialog extends Dialog { private static int default_width = 160; //默认宽度 private static int default_height = 120;//默认高度 public MyDialog(Context context, View layout, int style) { this(context, default_width, default_height, layout, style); } public MyDialog(Context context, int width, int height, View layout, int style) { super(context, style); setContentView(layout); Window window = getWindow(); WindowManager.LayoutParams params = window.getAttributes(); params.width=width; params.height=height; params.gravity = Gravity.CENTER; window.setAttributes(params); } }
cztest_main.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <Button android:id="@+id/mybut" android:text="测试" android:layout_width="fill_parent" android:layout_height="wrap_content"/> </LinearLayout>
CzTestActivity.java:
package com.weijie.app_user.activity.test; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.PopupWindow; import com.weijie.app_user.R; import com.weijie.app_user.activity.login.MyDialog; public class CzTestActivity extends Activity { private Button mybut = null; // 定义按钮 private PopupWindow popWin = null; // 弹出窗口 private View popView = null; // 保存弹出窗口布局 @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); super.setContentView(R.layout.cztest_main); // 调用布局管理器 this.mybut = (Button) super.findViewById(R.id.mybut); // 取得按钮 this.mybut.setOnClickListener(new OnClickListenerImpl()); // 设置事件类 } // 新版本 private class OnClickListenerImpl implements OnClickListener { @Override public void onClick(View view) { View view1 = getLayoutInflater().inflate(R.layout.login_newversion_dialog, null); MyDialog myDialog = new MyDialog(CzTestActivity.this, 300, 200, view1, R.style.self_dialog); // 设置对话框显示的View myDialog.show(); } } // 选择社交平台弹出窗 /* * private class OnClickListenerImpl implements OnClickListener { * * @Override public void onClick(View view) { LayoutInflater inflater = * LayoutInflater.from(CzTestActivity.this); // 取得LayoutInflater对象 * CzTestActivity.this.popView = inflater.inflate( * R.layout.login_social_platform_dialog, null); // 读取布局管理器 * CzTestActivity.this.popWin = new PopupWindow(popView, * LayoutParams.MATCH_PARENT, 380, true); // 实例化PopupWindow // * 设置PopupWindow的弹出和消失效果 * * CzTestActivity.this.popWin .setAnimationStyle(R.style.popupAnimation); * * CzTestActivity.this.popWin.showAtLocation( CzTestActivity.this.mybut, * Gravity.BOTTOM, 0, 0); // 显示弹出窗口 } } */ }
login_newversion_dialog.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="@drawable/rounded_corners_view" android:orientation="vertical" android:fadingEdge="none" style="@android:style/Theme.Dialog"> <LinearLayout android:layout_width="fill_parent" android:layout_height="40dp" android:background="@drawable/round_corner_view_title" android:gravity="center" android:orientation="horizontal" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="提 示" android:textColor="@color/black" android:textSize="20sp" /> </LinearLayout> <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginTop="20dp" android:gravity="center" android:orientation="horizontal" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="发现新版本" android:textColor="#333" android:textSize="18sp" /> </LinearLayout> <!-- 版本提示 --> <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginTop="15dp" android:gravity="center" android:orientation="horizontal" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginRight="10dp" android:text="v3.5.0" android:textColor="#717171" android:textSize="18sp" /> <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/setting_arrow" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="10dp" android:text="v3.5.1" android:textColor="#ff6600" android:textSize="18sp" /> </LinearLayout> <!-- 按钮 --> <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginTop="15dp" android:layout_marginBottom="15dp" android:gravity="center" android:orientation="horizontal" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/textview_style_cancle_gray" android:layout_marginRight="20dp" android:text="取 消" android:textColor="@color/white" android:textSize="18sp" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/textview_style_update_yellow" android:text="更 新" android:textColor="@color/white" android:textSize="18sp" /> </LinearLayout> </LinearLayout>
rounded_corners_view.xml:
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android"> <solid android:color="#ffffff" /> <stroke android:width="1dp" android:color="#797979" /> <corners android:radius="10dp" /> <!-- <padding android:left="5dp" android:top="5dp" android:right="5dp" android:bottom="5dp" /> --> </shape>
round_corner_view_title.xml:
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" > <solid android:color="#DBD9DA" /> <stroke android:width="1dp" android:color="#797979" /> <corners android:bottomLeftRadius="0dp" android:bottomRightRadius="0dp" android:topLeftRadius="10dp" android:topRightRadius="10dp" /> <!-- <padding android:left="5dp" android:top="5dp" android:right="5dp" android:bottom="5dp" /> --> </shape>
<style name="self_dialog" parent="@android:style/Theme.Dialog">
<item name="android:windowFrame">@null</item>
<item name="android:windowIsFloating">true</item>
<item name="android:windowIsTranslucent">true</item>
<item name="android:windowNoTitle">true</item>
<item name="android:background">@android:color/transparent</item>
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:backgroundDimEnabled">true</item>
<item name="android:backgroundDimAmount">0.6</item>
</style>
相关推荐
这是我自己写的圆角dialog,解决android系统自带的dialog太难看的问题
个人做的自定义搜索界面,包括自定义搜索框,边输入边搜索,文字监听,有文字时,出现删除按钮,可删除,还有自定义圆角dialog以及通过FlowLayout流式布局实现历史标签展示,更重要的是有搜索词颜色改变方法,有需要...
android 自定义多选dialog+圆角弹窗 无错乱现象
介绍了Android 去掉自定义dialog的白色边框,有需要的朋友可以参考一下
dialog在Android开发中是非常常用的,但是系统自带的样式,有限,所以我们需要自定义dialog,定义出我们喜欢的样式。
Android仿淘宝自定义半透明圆角Dialog.zip
自定义圆角DialogActivity
项目中多处用到对话框,本篇文章主要介绍了Android实现圆角对话框Dialog的示例代码,有兴趣的可以了解一下。
主要为大家详细介绍了Android自定义Dialog实现通用圆角对话框,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例讲述了Android编程自定义圆角半透明Dialog的方法。分享给大家供大家参考,具体如下: 效果图如下: 只是在实例化的时候使用带样式的构造函数即可 new MyDialog(GameActivity.this, R.style.dialog); 在...
安卓仿苹果自定义Dialog,可以设置圆角半径和颜色样式,最多可以设置三个按钮,取消、确定和中间按钮,不设置内容的按钮会自动隐藏,只显示设置的按钮
android自定义的dailog,圆角,支持手机和平板,拿去可以直接用,但注意下字符,友情提醒
最近做android项目的时候,因为系统自带的dialog实在不美观,所以我自定义了比较美观的dialog。而且有圆角和圆形头像,圆角给人柔和的感觉,dialog顶部是个半圆,所以十分美观。说起dialog,没什么代码量,主要工作...
自定义圆角对话框 类似于新浪微博长按弹出对话框 代码简单易懂 项目所需 所以就分享出来给大家 不足之处请多多包涵哈
自定义的圆角对话框(Dialog)效果,这个是一款非常自定义的漂亮AlertDialog效果的,看了图片就明白了,我个人觉得样式还不错,所以分享给大家,希望对你有用。
改变默认dialog的样式,字体颜色,可加图标,圆角的自定义dialog