zoukankan      html  css  js  c++  java
  • Android修改AlertDialog宽和高以及设置AlertDialog的背景

    不知道你们试过了吗,AlertDialog在我们给他设置我们自己的布局的时候他的宽度不论我们怎么设置他都是不变的,要想改变宽和高我们可以动态的去修改他的宽度好高度 
    直接上代码

      // 1. 布局文件转换为View对象
            LayoutInflater inflater = LayoutInflater.from(context);
            RelativeLayout layout = (RelativeLayout) inflater.inflate(R.layout.mydialog_layout, null);
    
    // 2. 新建对话框对象
            final AlertDialog.Builder builder = new AlertDialog.Builder(context,R.style.AlertDialog);
            //通过setView设置我们自己的布局
            builder.setView(layout);
            final AlertDialog dialog =builder.create();
            dialog.show();
            //此处设置位置窗体大小
            dialog.getWindow().setLayout(DensityUtil.dip2px(context,300), LinearLayout.LayoutParams.WRAP_CONTENT);
    • 上面代码通过AlertDialog.Builder的setView()方法设置我们自己的布局
    • 通过builder.create()获取AlertDialog对象,然后通过AlertDialog的etWindow().setLayout(DensityUtil.dip2px(context,300), LinearLayout.LayoutParams.WRAP_CONTENT);设置AlertDialog的宽和高
    • DensityUtil.dip2px是dp转px的工具类
    • 在创建AlertDialog.Builder对象的时候我们有传入两个参数一个是Context另一个就是AlertDialog的样式 注意这个样式使我们自己定义的

    在这里我贴出我自己定义的样式的代码 
    路径res/values/styles

    <style name="AlertDialog" parent="@android:style/Theme.DeviceDefault.Dialog">
         <!--该行代码就是设置AlertDialog的背景-->
          <item name="android:background">@drawable/dialog_bg</item>
    </style>
  • 相关阅读:
    Vim快捷键键位图大全
    Docker快速入门
    针对base64编码和URIEncode的一点研究
    JavaEE初学笔记之Servlet与Tomcat
    【编码】彻底弄懂ASCII、Unicode、UTF-8之间的关系
    React的世界观及与Vue之比较
    彻底搞懂CSS文本、空白换行问题
    Vue实现懒加载的基本思路
    CSS中的px与物理像素、逻辑像素、1px边框问题
    Vue插值文本换行问题
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/9336323.html
Copyright © 2011-2022 走看看