Android仿IOS自定义AlertDialog提示框

 更新时间:2017年03月23日 15:11:49   作者:蒽香之气  
本篇文章主要介绍了Android仿IOS自定义AlertDialog对话框,主要介绍了圆角AlertDialog对话框,具有一定的参考价值,有兴趣的可以了解一下。

本文介绍的仿IOS对话框的实现,先来看一下效果图


具体代码如下:

public class AlertDialog {
 private Context context;
 private Dialog dialog;
 private LinearLayout lLayout_bg;
 private TextView txt_title;
 private TextView txt_msg;
 private Button btn_neg;
 private Button btn_pos;
 private ImageView img_line;
 private Display display;
 private boolean showTitle = false;
 private boolean showMsg = false;
 private boolean showPosBtn = false;
 private boolean showNegBtn = false;

 public AlertDialog(Context context) {
  this.context = context;
  WindowManager windowManager = (WindowManager) context
    .getSystemService(Context.WINDOW_SERVICE);
  display = windowManager.getDefaultDisplay();
 }

 public AlertDialog builder() {
  View view = LayoutInflater.from(context).inflate(
    R.layout.view_alertdialog, null);

  lLayout_bg = (LinearLayout) view.findViewById(R.id.lLayout_bg);
  txt_title = (TextView) view.findViewById(R.id.txt_title);
  txt_title.setVisibility(View.GONE);
  txt_msg = (TextView) view.findViewById(R.id.txt_msg);
  txt_msg.setVisibility(View.GONE);
  btn_neg = (Button) view.findViewById(R.id.btn_neg);
  btn_neg.setVisibility(View.GONE);
  btn_pos = (Button) view.findViewById(R.id.btn_pos);
  btn_pos.setVisibility(View.GONE);
  img_line = (ImageView) view.findViewById(R.id.img_line);
  img_line.setVisibility(View.GONE);

  dialog = new Dialog(context, R.style.AlertDialogStyle);
  dialog.setContentView(view);

  lLayout_bg.setLayoutParams(new FrameLayout.LayoutParams((int) (display
    .getWidth() * 0.80), LayoutParams.WRAP_CONTENT));

  return this;
 }

 public AlertDialog setTitle(String title) {
  showTitle = true;
  if ("".equals(title)) {
   txt_title.setText("标题");
  } else {
   txt_title.setText(title);
  }
  return this;
 }

 public AlertDialog setMsg(String msg) {
  showMsg = true;
  if ("".equals(msg)) {
   txt_msg.setText("内容");
  } else {
   txt_msg.setText(msg);
  }
  return this;
 }

 public AlertDialog setCancelable(boolean cancel) {
  dialog.setCancelable(cancel);
  return this;
 }

 public AlertDialog setPositiveButton(String text,
   final OnClickListener listener) {
  showPosBtn = true;
  if ("".equals(text)) {
   btn_pos.setText("确定");
  } else {
   btn_pos.setText(text);
  }
  btn_pos.setOnClickListener(new OnClickListener() {
   @Override
   public void onClick(View v) {
    listener.onClick(v);
    dialog.dismiss();
   }
  });
  return this;
 }

 public AlertDialog setNegativeButton(String text,
   final OnClickListener listener) {
  showNegBtn = true;
  if ("".equals(text)) {
   btn_neg.setText("取消");
  } else {
   btn_neg.setText(text);
  }
  btn_neg.setOnClickListener(new OnClickListener() {
   @Override
   public void onClick(View v) {
    listener.onClick(v);
    dialog.dismiss();
   }
  });
  return this;
 }

 private void setLayout() {
  if (!showTitle && !showMsg) {
   txt_title.setText("提示");
   txt_title.setVisibility(View.VISIBLE);
  }

  if (showTitle) {
   txt_title.setVisibility(View.VISIBLE);
  }

  if (showMsg) {
   txt_msg.setVisibility(View.VISIBLE);
  }

  if (!showPosBtn && !showNegBtn) {
   btn_pos.setText("确定");
   btn_pos.setVisibility(View.VISIBLE);
//   btn_pos.setBackgroundResource(R.drawable.alertdialog_single_selector);
   btn_pos.setOnClickListener(new OnClickListener() {
    @Override
    public void onClick(View v) {
     dialog.dismiss();
    }
   });
  }

  if (showPosBtn && showNegBtn) {
   btn_pos.setVisibility(View.VISIBLE);
//   btn_pos.setBackgroundResource(R.drawable.alertdialog_right_selector);
   btn_neg.setVisibility(View.VISIBLE);
//   btn_neg.setBackgroundResource(R.drawable.alertdialog_left_selector);
   img_line.setVisibility(View.VISIBLE);
  }

  if (showPosBtn && !showNegBtn) {
   btn_pos.setVisibility(View.VISIBLE);
//   btn_pos.setBackgroundResource(R.drawable.alertdialog_single_selector);
  }

  if (!showPosBtn && showNegBtn) {
   btn_neg.setVisibility(View.VISIBLE);
//   btn_neg.setBackgroundResource(R.drawable.alertdialog_single_selector);
  }
 }

 public void show() {
  setLayout();
  dialog.show();
 }
}

布局文件view_alertdialog.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@+id/lLayout_bg"
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:background="@drawable/alert_bg"
 android:orientation="vertical" >

 <TextView
  android:id="@+id/txt_title"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_marginLeft="15dp"
  android:layout_marginRight="15dp"
  android:layout_marginTop="15dp"
  android:gravity="center"
  android:textColor="@color/black"
  android:textSize="18sp"
  android:text="提示"
  android:textStyle="bold" />

 <TextView
  android:id="@+id/txt_msg"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:layout_marginLeft="15dp"
  android:layout_marginRight="15dp"
  android:layout_marginTop="32dp"
  android:gravity="center"
  android:text="提示信息"
  android:textColor="@color/black"
  android:textSize="16sp" />

 <ImageView
  android:layout_width="match_parent"
  android:layout_height="0.5dp"
  android:layout_marginTop="25dp"
  android:background="@color/alertdialog_line" />

 <LinearLayout
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="horizontal" >

  <Button
   android:id="@+id/btn_neg"
   android:layout_width="wrap_content"
   android:layout_height="43dp"
   android:layout_weight="1"
   android:background="@drawable/alertdialog_left_selector"
   android:gravity="center"
   android:textColor="@color/actionsheet_blue"
   android:textSize="16sp" 
   />

  <ImageView
   android:id="@+id/img_line"
   android:layout_width="0.5dp"
   android:layout_height="43dp"
   android:background="@color/alertdialog_line" />

  <Button
   android:id="@+id/btn_pos"
   android:layout_width="wrap_content"
   android:layout_height="43dp"
   android:layout_weight="1"
   android:background="@drawable/alertdialog_right_selector"
   android:gravity="center"
   android:textColor="@color/actionsheet_blue"
   android:textSize="16sp"
   android:textStyle="bold"
   />
 </LinearLayout>

</LinearLayout>

alertdialog_left_selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

 <item android:drawable="@drawable/alert_btn_left_pressed" android:state_pressed="true"/>
 <item android:drawable="@drawable/trans_bg"/>

</selector>

alertdialog_right_selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

 <item android:drawable="@drawable/alert_btn_right_pressed" android:state_pressed="true"/>
 <item android:drawable="@drawable/trans_bg"/>

</selector>

alertdialog_single_selector.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

 <item android:drawable="@drawable/alert_btn_single_pressed" android:state_pressed="true"/>
 <item android:drawable="@drawable/trans_bg"/>

</selector>
<style name="AlertDialogStyle" parent="@android:style/Theme.Dialog">
  <item name="android:windowBackground">@android:color/transparent</item>
  <item name="android:windowContentOverlay">@null</item>
  <item name="android:windowIsFloating">true</item>
  <item name="android:windowFrame">@null</item>
  <item name="android:backgroundDimEnabled">true</item>
  <item name="android:windowNoTitle">true</item>
  <item name="android:windowIsTranslucent">true</item>
 </style>

用到的.9图片





调用方式:

  new AlertDialog(this).builder().setMsg(msg)
  .setPositiveButton("确定", new OnClickListener() {
   @Override
   public void onClick(View v) {

   }
  }).setNegativeButton("取消", new OnClickListener() {

   @Override
   public void onClick(View arg0) {
    // TODO Auto-generated method stub
   }
  }).show();

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android自定义View弧线进度控件

    Android自定义View弧线进度控件

    这篇文章主要为大家详细介绍了Android自定义View弧线进度控件,点击开始按钮时,逐渐的出现进度,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • 深入理解Android中的xmlns:tools属性

    深入理解Android中的xmlns:tools属性

    关于xmlns:tools属性的介绍网上有很多,小编觉得有必要整理一篇介绍较为详细的内容给大家,下面这篇文章就很深入的介绍了关于Android中的xmlns:tools属性,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-12-12
  • Android如何获取视频首帧图片

    Android如何获取视频首帧图片

    这篇文章主要为大家详细介绍了Android如何获取视频首帧图片的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • Android RadioButton 图片位置与大小实例详解

    Android RadioButton 图片位置与大小实例详解

    这篇文章主要介绍了Android RadioButton 图片位置与大小实例详解的相关资料,这里提供实例代码及实现效果图,需要的朋友可以参考下
    2016-11-11
  • 详解利用Flutter中的Canvas绘制有趣的图形

    详解利用Flutter中的Canvas绘制有趣的图形

    本文将利用Flutter中的Canvas绘制三个有趣的图形:使用等边三角形组合成彩虹伞面、五角星和彩虹,快来跟随小编一起动手尝试一下吧
    2022-03-03
  • Android+Flutter实现文字跑马灯特效

    Android+Flutter实现文字跑马灯特效

    跑马灯常常被运用在很多领域, 例如商场的电子条幅、大楼的宣传广告位、地铁的广告位。今天我们来说一下flutter 怎么通过绘制来实现跑马灯效果!,希望对大家有所帮助
    2022-11-11
  • Kotlin自定义View系列教程之标尺控件(选择身高、体重等)的实现

    Kotlin自定义View系列教程之标尺控件(选择身高、体重等)的实现

    这篇文章主要给大家介绍了关于Kotlin自定义View系列教程之标尺控件(选择身高、体重等)实现的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
    2018-07-07
  • Android模拟器对应的电脑快捷键说明

    Android模拟器对应的电脑快捷键说明

    Android模拟器对应的电脑快捷键说明,需要的朋友可以参考一下
    2013-06-06
  • 悬浮对话框Android代码实现

    悬浮对话框Android代码实现

    这篇文章主要为大家详细介绍了悬浮对话框Android代码实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • Android使用ContentProvider实现跨进程通讯示例详解

    Android使用ContentProvider实现跨进程通讯示例详解

    这篇文章主要为大家介绍了Android使用ContentProvider实现跨进程通讯示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03

最新评论