android 设置系统dialog 样式

举报
再见孙悟空_ 发表于 2022/01/13 23:00:37 2022/01/13
【摘要】  1、编写一个文本样式。   DIALOG的标题是一个textview,在sytles.xml中,添加如下代码来设置你自己的文本样式:   ?   <style name="DialogWindowTitle">   <item name="android:textSize">22sp</item> ...

 1、编写一个文本样式。
  DIALOG的标题是一个textview,在sytles.xml中,添加如下代码来设置你自己的文本样式:
  ?

  <style name="DialogWindowTitle">
  <item name="android:textSize">22sp</item>
  <item name="android:textColor">@color/font_dark_grey</item>
  </style>
  2、设置对话框的标题主题。
  
  上面的标题文本并不能直接设置为对话框的标题样式。 我们还需要编写一个表示标题的主题的style,在这里指定标题的文本样式。代码如下:
  
  ?

  <style name="DialogWindowTitle.DeviceDefault">
  <item name="android:maxLines">1</item>
  <item name="android:scrollHorizontally">true</item>
  <item name="android:textAppearance">@style/DialogWindowTitle</item>
  </style>

  3、设置对话框主题。
  
  接下来,我们编写我们的对话框主题,在这里指定标题的主题。由于一些属性并不是public的,所以我们需要继承自原来的某个style,代码如下:
  
  ?

  <!--Dialog主题-->
  <style name="Theme.DeviceDefault.Dialog" parent="@android:style/Theme.DeviceDefault.Light.Dialog">
  <item name="android:windowTitleStyle">@style/DialogWindowTitle.DeviceDefault</item>
  </style>

  4、自定义App的主题。
  
  接下来,我们需要在我们的App theme中指定我们的对话框使用这种主题,所以需要定义一个App theme。同样由于App theme的许多属性并不是public的(比如下面要提到的标题下面的那条蓝线),所以我们要继承自一个原生的style。这里我根据程序需要选择了Theme.Holo.Light.NoActionBar,代码如下:
  
  ?

  <style name="ParkingTheme" parent="@android:style/Theme.Holo.Light.NoActionBar">
  <item name="android:dialogTheme">@style/Theme.DeviceDefault.Dialog</item>
  </style>
  5、指定App主题。
  
  最后一步,我们需要在AndroidManifest.xml文件中,指定我们的app主题。这步很简单,只需要在application标签中指定android:theme的值即可,如下:
  
  ?

  android:theme="@style/ParkingTheme"

  不过这只是指定了Dialog的主题。如果是通过AlertDialog创建出来的对话框,主题还是原来的。所以我们还需要以下步骤。
  
  7、编写AlertDialog主题。
  我们无法直接继承系统主题里的AlertDialog的style。如把parent指定为Theme.DeviceDefault.Dialog.Alert,Theme.Holo.Dialog.Alert,Theme.DeviceDefault.Light.Dialog.Alert或Theme.Holo.Light.Dialog.Alert,都会导致编译不过。所以我们需要继承自Dialog的style。在这里我以Theme.Holo.Light.Dialog为例,代码如下:

  <!--AlderDialog主题-->
  <style name="Theme.DeviceDefault.Dialog.Alert" parent="@android:style/Theme.Holo.Light.Dialog">
  <item name="android:windowBackground">@android:color/transparent</item>
  <item name="android:windowTitleStyle">@style/DialogWindowTitle.DeviceDefault</item>
  <item name="android:windowContentOverlay">@null</item>
  <item name="android:windowMinWidthMajor">@android:dimen/dialog_min_width_major</item>
  <item name="android:windowMinWidthMinor">@android:dimen/dialog_min_width_minor</item>
  </style>

  在这里我参考了原生的alertDialog的style,设定了窗口背景为透明,以及windowContentOverlay为null这两个重要属性,否则你会看到在AlertDialog下面还有一层对话框的背景,或者是对话框的背景遮住了所有内容这样的问题存在。
  

  8、指定AlertDialog的主题。

  我们需要在第4步所说的自定义的AppTheme中,添加一行代码来指定要使用的AlertDialog的style,代码如下:

  ?
   <item name="android:alertDialogTheme">@style/Theme.DeviceDefault.Dialog.Alert</item>

  9、修改标题下面的蓝色线。
  

  如果你修改了对话框的主题颜色,那么标题下面的蓝色的线肯定会让你很郁闷。如果对话框较少,你可以选择隐藏标题,然后自定义一个包含了标题的View来设置为对话框的内容。但是如果你的对话框有许多种,而且本来都是可以调用原来的API就来生成的话,要去定义这么多个带标题的view,这样做下来心里肯定是很纠结的。

  标题下面的蓝色的线,并不是在Dialog或AlertDialog中设置或通过它们的style中定义的。它是定义在各种风格的dialog的layout当中,然后再在AppTheme里面指定dialog的对应属性。遗憾的是,目前我看到这几个相关属性还不是public的,不能自己设置,所以只有通过Java代码来实现了。

  表示这条蓝色的线的叫做titleDivider,我们可以通过getResources()的API来获取它的IP,然后设置颜色。代码如下:

  ?
   public static final void dialogTitleLineColor(Dialog dialog, int color) {
  Context context = dialog.getContext();
  int divierId = context.getResources().getIdentifier("android:id/titleDivider", null, null);
  View divider = dialog.findViewById(divierId);
  divider.setBackgroundColor(color);
  }

  

  这行代码对于自定义的Dialog,可以在setContentView之后调用。但是对于AlertDialog,必须在show()方法被调用之后才可以去调用,否则会报错。

附 修改  标题和线 颜色 方法  里面的color自己定义

//修改默认AlertDialog的标题颜色 和 下面蓝色线的颜色
	 public static void dialogTitleLineColor(Dialog dialog,Context context) {
		 
		 //获取标题textView 并设置颜色
		 try {
			 Field mAlert = AlertDialog.class.getDeclaredField("mAlert");  
			 mAlert.setAccessible(true);  
		     Object alertController = mAlert.get(dialog);  
		     Field mTitleView = alertController.getClass().getDeclaredField("mTitleView");  
		     mTitleView.setAccessible(true);  
		     TextView title = (TextView) mTitleView.get(alertController);
		     title.setTextColor(context.getResources().getColor(R.color.country_standard_defaulg));
		} catch (Exception e) {
			
		}
		 //获取下面线对象view 并设置颜色
		 
		 int divierId = context.getResources().getIdentifier("android:id/titleDivider", null, null);
		 View divider = dialog.findViewById(divierId);
		 divider.setBackgroundColor(context.getResources().getColor(R.color.country_standard_defaulg));
	 }



文章来源: wukong.blog.csdn.net,作者:再见孙悟空_,版权归原作者所有,如需转载,请联系作者。

原文链接:wukong.blog.csdn.net/article/details/51577706

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。