美文网首页
Dialog自定义布局

Dialog自定义布局

作者: BlackNeko | 来源:发表于2016-08-18 18:18 被阅读2597次

因为有很多时候需要弹出一个Dialog,但系统自带的Dialog太丑了,于是写一个自定义Dialog布局的模板。

layout布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:orientation="vertical"
    android:padding="50dp" >

    <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/dialog_bg" >

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:orientation="vertical" >

            <TextView
                android:id="@+id/textView"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="Title" />

            <Button
                android:id="@+id/button"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:text="button" />
        </LinearLayout>
    </FrameLayout>

</LinearLayout>

布局稍微改改就能做成点击右上取消的样子。在<FrameLayout>标签里、<LinearLayout>外边加上一个控件,设置android:layout_gravity="top|right"

FrameLayout的背景

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >
    
    <stroke
        android:width="2dp"
        android:color="#bfe9ff" />
        
    <corners android:radius="10dp" />
    
    <solid android:color="#ffffff" />

</shape>

Dialog的样式

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="simpleDialogStyle" parent="@android:style/Theme.Dialog">
        <item name="android:windowBackground">@android:color/transparent</item>
        <item name="android:windowFrame">@null</item>
        <item name="android:windowNoTitle">true</item>
    </style>
</resources>

创建Dialog

int mWindowWidth, mWindowHeight;
Dialog dialog = new Dialog(this, R.style.simpleDialogStyle);
View view = LayoutInflater.from(this).inflate(R.layout.simple_dialog, null);
DisplayMetrics displayMetrics = this.getResources().getDisplayMetrics();
mWindowWidth = displayMetrics.widthPixels;
mWindowHeight = displayMetrics.heightPixels;
dialog.setContentView(view, new MarginLayoutParams(mWindowWidth,
        MarginLayoutParams.MATCH_PARENT));
dialog.show();

宽度设置为手机屏幕的宽度,高度为控件高度之和,因为没有父layout,所以没有需要自定义View,重写onDraw()方法,才能使用MarginLayoutParams.MATCH_PARENT属性

相关文章

  • 自定义Dialog

    自定义Dialog的主题 自定义Dialog的布局文件 继承Dialog 并在onCreate方法中将布局设置给D...

  • Android_自定义Dialog底部弹出动画

    效果图如下 点击Button调用代码 Dialog的自定义布局 Dialog的自定义布局Share样式,drawa...

  • Android圆角对话框Dialog

    需求:模仿iOS样式Dialog对话框。 自定义Dialog 核心代码: Dialog样式: Dialog布局文件...

  • 实现图片Dialog中带ViewPager

    效果图 实现思路 自定义Dialog,为Dialog添加自定义布局,自定义PagerAdapter以及PageTr...

  • 自定义分享dialog

    自定义dialog布局 布局内容adapter 设置圆角 自定义圆角view 使用 自定义属性

  • 自定义Dialog

    仿IOS自定义的Dialog: 1、Util帮助类创建dialog 2、布局文件 :loading_dialog....

  • 自定义progressdialog

    1:继承Dialog,加载布局 2:布局设置 3:style设置,透明以后才可以自定义dialog大小 4:应用

  • Android 让Dialog实现背景透明

    1、实现自定义Dialog 布局 dialog_main_sign.xml 2、代码 注意: dialo...

  • 自定义Dialog

    自定义Dialog可以设置两个自定义布局 自定义标题布局setCustomTitle(),方法参数为View类对象...

  • 自定义Dialog

    自定义Dialog类 样式 布局 window动画 enter exit

网友评论

      本文标题:Dialog自定义布局

      本文链接:https://www.haomeiwen.com/subject/afgvsttx.html