Android如何自定义升级对话框示例详解

所属分类: 软件编程 / Android 阅读数: 27
收藏 0 赞 0 分享

前言

本文主要给大家介绍了关于Android自定义升级对话框的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

实现的效果如下所示


其实这也只是一个DialogFragment 而已,重点只是在于界面的设计

想要使用做出这样一个DialogFragment ,需要自定义一个View,然后将该View传入到该Dialog中

先定义布局,一个TextView用于标题,一个TextView用于升级内容阐述,一个ImageView,一个确认升级的按钮

<?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="match_parent"
 android:orientation="vertical">

 <TextView
 android:id="@+id/tv_title"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_marginTop="20dp"
 android:gravity="center"
 android:textColor="#0474dc"
 android:textSize="22sp"
 android:textStyle="bold" />

 <TextView
 android:id="@+id/tv_description"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_marginTop="15dp"
 android:gravity="center"
 android:textColor="#0474dc"
 android:textSize="18sp" />

 <ImageView
 android:layout_width="70dp"
 android:layout_height="70dp"
 android:layout_gravity="center"
 android:layout_marginBottom="20dp"
 android:layout_marginTop="20dp"
 android:src="@drawable/upgrade" />

 <Button
 android:id="@+id/btn_upgrade"
 style="@style/blueButtonStyle"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:layout_marginBottom="20dp"
 android:layout_marginEnd="20dp"
 android:layout_marginStart="20dp"
 android:gravity="center"
 android:text="立即更新" />

</LinearLayout>

当中,按钮需要用到自定义Style

 <!--用于按钮的蓝色背景风格-->
 <style name="blueButtonStyle" parent="Widget.AppCompat.Button.Borderless">
 <item name="android:background">@drawable/button_blue_background</item>
 <item name="android:textAppearance">@style/blueButtonTextStyle</item>
 </style>
 <!--用于蓝色风格按钮的文本风格-->
 <style name="blueButtonTextStyle">
 <item name="android:textColor">@android:color/white</item>
 <item name="android:textSize">17sp</item>
 </style>

建立 DialogFragment 的子类

/**
 * 作者: 叶应是叶
 * 时间: 2017/3/23 12:36
 * 描述:
 */
public class VersionDialogFragment extends DialogFragment {

 private static final String TITLE = "title";

 private static final String DESCRIPTION = "description";

 private View.OnClickListener positiveCallback;

 private String title;

 private String description;

 public static VersionDialogFragment getInstance(String title, String description) {
  Bundle bundle = new Bundle();
  bundle.putString(TITLE, title);
  bundle.putString(DESCRIPTION, description);
  VersionDialogFragment versionDialogFragment = new VersionDialogFragment();
  versionDialogFragment.setArguments(bundle);
  return versionDialogFragment;
 }

 @Override
 public void onCreate(@Nullable Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  Bundle bundle = getArguments();
  title = bundle.getString(TITLE);
  description = bundle.getString(DESCRIPTION);
 }

 public void show(FragmentManager fragmentManager, View.OnClickListener positiveCallback) {
  this.positiveCallback = positiveCallback;
  show(fragmentManager, "VersionDialogFragment");
 }

 @NonNull
 @Override
 public Dialog onCreateDialog(Bundle savedInstanceState) {
  AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
  LayoutInflater inflater = getActivity().getLayoutInflater();
  final View view = inflater.inflate(R.layout.version_dialog, null);
  TextView tv_title = (TextView) view.findViewById(R.id.tv_title);
  TextView tv_description = (TextView) view.findViewById(R.id.tv_description);
  Button btn_upgrade = (Button) view.findViewById(R.id.btn_upgrade);
  tv_title.setText(title);
  tv_description.setText(description);
  btn_upgrade.setOnClickListener(positiveCallback);
  builder.setView(view);
  return builder.create();
 }

}

然后再到 MainActivity 中调用Dialog

public void showDialog(View view) {
  final VersionDialogFragment dialogFragment = VersionDialogFragment.getInstance("2.0.1新版本发布啦", "更多功能等你体验");
  dialogFragment.show(getSupportFragmentManager(), new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    Toast.makeText(MainActivity.this, "进行更新操作吧", Toast.LENGTH_SHORT).show();
    dialogFragment.dismiss();
   }
  });
 }

此时界面是这样的


可以看到 Dialog 中有较大的空白区,显得有点虚浮

这里可以选择在 VersionDialogFragment 的 onStart() 方法中指定 Dialog 所占屏幕宽度的比例

 @Override
 public void onStart() {
  super.onStart();
  Dialog dialog = getDialog();
  if (dialog != null) {
   DisplayMetrics dm = new DisplayMetrics();
   getActivity().getWindowManager().getDefaultDisplay().getMetrics(dm);
   if (dialog.getWindow() != null) {
    dialog.getWindow().setLayout((int) (dm.widthPixels * 0.7), ViewGroup.LayoutParams.WRAP_CONTENT);
   }
  }
 }

这里设置占据屏幕宽度的百分之七十

效果图如下所示


此时 Dialog 的四个角还都是直的,这里再来将之修改为圆角

在drawable文件夹下新建一个root.xml文件,作为Dialog使用到的布局的根Layout的背景

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
 android:shape="rectangle">
 <corners android:radius="20dp" />
 <solid android:color="#ffffff" />
</shape>
 @Override
 public void onStart() {
  super.onStart();
  Dialog dialog = getDialog();
  if (dialog != null) {
   DisplayMetrics dm = new DisplayMetrics();
   getActivity().getWindowManager().getDefaultDisplay().getMetrics(dm);
   if (dialog.getWindow() != null) {
    dialog.getWindow().setLayout((int) (dm.widthPixels * 0.8), ViewGroup.LayoutParams.WRAP_CONTENT);
   }
  }
 }

然后再修改onStart()方法,为Dialog的Window设置透明背景色

 @Override
 public void onStart() {
  super.onStart();
  Dialog dialog = getDialog();
  if (dialog != null) {
   DisplayMetrics dm = new DisplayMetrics();
   getActivity().getWindowManager().getDefaultDisplay().getMetrics(dm);
   if (dialog.getWindow() != null) {
    dialog.getWindow().setLayout((int) (dm.widthPixels * 0.7), ViewGroup.LayoutParams.WRAP_CONTENT);
    dialog.getWindow().setBackgroundDrawableResource(android.R.color.transparent);
   }
  }
 }

这样,总的效果就都完成了

这里提供示例代码下载:Android 自定义升级对话框

以上就是这篇文章的全部内容了,希望本文的内容对各位Android开发者们的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

更多精彩内容其他人还在看

Android中加入名片扫描功能实例代码

这篇文章主要介绍了Android中加入名片扫描功能实例代码的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Android仿微信发表说说实现拍照、多图上传功能

这篇文章主要为大家详细介绍了Android仿微信发表说说实现拍照、多图上传功能,使用Retrofit2.0技术,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

设置Android系统永不锁屏永不休眠的方法

在进行Android系统开发的时候,有些特定的情况需要设置系统永不锁屏,永不休眠。本篇文章给大家介绍Android 永不锁屏,开机不锁屏,删除设置中休眠时间选项,需要的朋友一起学习吧
收藏 0 赞 0 分享

Android Retrofit 2.0框架上传图片解决方案

这篇文章主要介绍了Android Retrofit 2.0框架上传一张与多张图片解决方案,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android自定义等待对话框

这篇文章主要为大家详细介绍了Android自定义等待对话框的实现方法,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

Android中Window添加View的底层原理

这篇文章主要介绍了Android中Window添加View的底层原理,需要的朋友可以参考下
收藏 0 赞 0 分享

Android调用系统默认浏览器访问的方法

这篇文章主要介绍了Android调用系统默认浏览器访问的方法的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Android开发退出程序的方法汇总

Android程序有很多Activity,比如说主窗口A,调用了子窗口B,子窗口B又调用子窗口C,back返回子窗口B后,在B中如何关闭整个Android应用程序呢? 下面脚本之家小编就给大家介绍android开发退出程序的几种方法,感兴趣的朋友参考下吧
收藏 0 赞 0 分享

Android程序开发中单选按钮(RadioGroup)的使用详解

在android程序开发中,无论是单选按钮还是多选按钮都非常的常见,接下来通过本文给大家介绍Android程序开发中单选按钮(RadioGroup)的使用,需要的朋友参考下吧
收藏 0 赞 0 分享

Android实现仿网易今日头条等自定义频道listview 或者grideview等item上移到另一个view中

这篇文章主要介绍了Android实现仿网易今日头条等自定义频道listview 或者grideview等item上移到另一个view中 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多