当前位置: 首页 > 编程笔记 >

Android仿IOS自定义AlertDialog提示框

谭琛
2023-03-14
本文向大家介绍Android仿IOS自定义AlertDialog提示框,包括了Android仿IOS自定义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仿IOS开关效果,包括了Android自定义view仿IOS开关效果的使用技巧和注意事项,需要的朋友参考一下 本文主要讲解如何在 Android 下实现高仿 iOS 的开关按钮,并非是在 Android 自带的 ToggleButton 上修改,而是使用 API 提供的 onDraw、onMeasure、Canvas 方法,纯手工绘制。基本原理就是在 Ca

  • 本文向大家介绍Android自定义控件仿iOS滑块SwitchButton,包括了Android自定义控件仿iOS滑块SwitchButton的使用技巧和注意事项,需要的朋友参考一下 SwitchButton可以点击的时候切换状态,类似CheckBox 在拖动的时候,也可以根据拖动的距离判断是否切换状态,类似ToggleButton 因此要区别出单击事件和拖动事件 实现效果如图所示: 自定义的Sw

  • 本文向大家介绍Android编程之自定义AlertDialog(退出提示框)用法实例,包括了Android编程之自定义AlertDialog(退出提示框)用法实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android编程自定义AlertDialog(退出提示框)用法,分享给大家供大家参考,具体如下: 有时候我们需要在游戏或应用中用一些符合我们样式的提示框(AlertDialog)

  • 本文向大家介绍iOS自定义推送消息提示框,包括了iOS自定义推送消息提示框的使用技巧和注意事项,需要的朋友参考一下 看到标题你可能会觉得奇怪 推送消息提示框不是系统自己弹出来的吗? 为什么还要自己自定义呢?  因为项目需求是这样的:最近需要做 远程推送通知 和一个客服系统 包括店铺客服和官方客服两个模块 如果有新的消息推送的时候 如果用户当前不在客服界面的时候  要求无论是在app前台 还是app

  • 问题内容: 因此,我看到我们可以使用具有灰色和白色(当setinverse …时)背景色的Alertdialog。 要了解为什么我检查了sdk的themes.xml,检查了它是否导致了可绘制对象,并且在那里我意识到alertdialog背景不是以编程方式完成的,而是通过一些图像完成的。这些图像保证了当我们使用LayoutInflater设置不同的背景色时,对话框的顶部(标题区域)和底部(按钮区域上

  • 本文向大家介绍Android自定义单例AlertDialog详解,包括了Android自定义单例AlertDialog详解的使用技巧和注意事项,需要的朋友参考一下 当Android开发处理错误信息时,经常会以Dialog的形式显示错误信息,但是每次都new一个Dialog,很麻烦,也增加程序的开销,所以今天就分享一种自定义单例AlertDialog 布局文件view_alertdialog.xml