Android Appcompat样式使用自定义Dialog

自定义Dialog在项目中使用到很多,其中遇到的坑也很多,来看下使用Appcompat样式的dialog怎么处理:

1、使用样式文件
<style name="PhotoDialog" parent="@style/Theme.AppCompat.Light.Dialog.Alert">
        <!--是否去除标题 -->
        <item name="windowNoTitle">true</item>
        <!--是否去除边框-->
        <item name="android:windowFrame">@null</item>
        <!--是否浮现在activity之上-->
        <item name="android:windowIsFloating">true</item>
        <!--是否模糊-->
        <item name="android:backgroundDimEnabled">true</item>
        <!-- 背景透明 -->
        <item name="android:background">#00000000</item>
        <item name="android:windowBackground">@android:color/transparent</item>
       <!-- 没有windowActionBar-->
        <item name="windowActionBar">false</item>
        <item name="android:windowContentOverlay">@null</item>
        <!-- <item name="android:backgroundDimEnabled">false</item> -->
    </style>
2、编写自己的Dialog:
  ## 这里有两种方法实现Dialog
  ## 第一种是使用自己的Dialog来继承自系统的Dialog
  ## 第二种使用Activity来实现自己的Dialog
我使用了第二种的方式来实现,具体的实现方式可以自己谷歌。
3、遇到的坑:
  • 背景全透明,就连自己写的布局也是透明样式
    解决的方法:是将父布局使用透明、子布局使用自己设计稿中的颜色

  • 布局文件在界面最上方
    解决方法:使用gravity来实现权重

  • 最重要的一点是使用了android:windowNoTitle 的样式为true了之后界面
    还是显示了标题,这是使用了AppcompatActivity之后要求使用的样式,于
    是把自己的样式也继承了 @style/Theme.AppCompat.Light.Dialog.Alert

    • 解决方法:
<item name="windowNoTitle">true</item>  
<!-- 而不是使用下面的 -->
*<item name="android:windowNoTitle">true</item>*
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用自定义样式来创建Android Studio中的对话框,可以按照以下步骤操作: 1. 创建一个新的XML文件来定义自定义样式,比如dialog_custom.xml。 2. 在该文件中定义您想要的样式,例如: ``` <?xml version="1.0" encoding="utf-8"?> <resources> <style name="CustomDialogStyle" parent="Theme.AppCompat.Light.Dialog.Alert"> <item name="android:windowNoTitle">true</item> <item name="android:windowBackground">@color/white</item> <item name="android:textColor">@color/black</item> </style> </resources> ``` 这里我们定义了一个名为CustomDialogStyle的样式,它继承了Theme.AppCompat.Light.Dialog.Alert,指定了对话框没有标题,背景颜色为白色,文本颜色为黑色。 3. 在代码中创建对话框时,使用样式: ``` AlertDialog.Builder builder = new AlertDialog.Builder(this, R.style.CustomDialogStyle); builder.setMessage("This is a custom dialog"); builder.setPositiveButton("OK", new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) { // do something } }); builder.setNegativeButton("Cancel", new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog, int which) { // do something } }); builder.show(); ``` 这个例子中,我们使用了AlertDialog.Builder来创建对话框,并通过第二个参数指定了我们定义的自定义样式。setMessage()和setPositiveButton()等方法用于设置对话框的内容和按钮。 4. 运行您的应用程序并查看自定义对话框的效果。 希望这些步骤能够帮助您在Android Studio中创建自定义对话框。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值