自定义AlertDialog(圆角+退出动画+自定义布局)

2024-08-31 23:58

本文主要是介绍自定义AlertDialog(圆角+退出动画+自定义布局),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

图片省略了不上传了。。。

首先看activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent" ><Buttonandroid:id="@+id/button"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"android:text="点击我,弹出AlertDialog" /></RelativeLayout>
MainActivity.java

package com.godinsec.alertdialog;import com.godinsec.alertdialog.ShowDeleDialog.onBtnClickListener;import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Toast;public class MainActivity extends Activity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);findViewById(R.id.button).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {new ShowDeleDialog(MainActivity.this, new onBtnClickListener(){@Overridepublic void onSure() {Toast.makeText(MainActivity.this, "进行确认操作", 0).show();}@Overridepublic void onExit() {Toast.makeText(MainActivity.this, "进行取消操作", 0).show();}}, "确定", "取消", "提示", "AlertDialog的内容").show();}});}}

接下来看自定义alertDialog

dele_allcontacts_dialog.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="fill_parent"android:layout_height="fill_parent" ><RelativeLayoutandroid:id="@+id/re_tip_dialog"android:layout_width="300dp"android:layout_height="120dp"android:layout_centerInParent="true"android:background="@drawable/rounded_search_text"><TextViewandroid:id="@+id/appTitle"android:layout_width="wrap_content"android:layout_height="wrap_content" android:layout_marginLeft="10dp"android:layout_marginTop="10dp"android:text="标题"/><TextViewandroid:id="@+id/tips"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_below="@id/appTitle"android:layout_alignLeft="@id/appTitle"android:text="AlertDialog的内容"android:layout_marginTop="20dp"/><TextViewandroid:id="@+id/sure"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignParentRight="true"android:text="确认"android:layout_below="@id/tips"android:layout_marginTop="20dp" /><TextViewandroid:id="@+id/cancel"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_alignBottom="@id/sure"android:text="取消"android:layout_marginRight="30dp"android:layout_toLeftOf="@id/sure" /></RelativeLayout></RelativeLayout>
rounded_search_text.xml(圆角)

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle" ><solid android:color="#FF7F24" /><cornersandroid:bottomLeftRadius="4dp"android:bottomRightRadius="4dp"android:topLeftRadius="4dp"android:topRightRadius="4dp" /></shape>
ShowDeleDialog.java

package com.godinsec.alertdialog;import android.app.Dialog;
import android.content.Context;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.view.animation.Animation;
import android.view.animation.Animation.AnimationListener;
import android.view.animation.ScaleAnimation;
import android.widget.RelativeLayout;
import android.widget.TextView;public class ShowDeleDialog extends Dialog implementsandroid.view.View.OnClickListener {private onBtnClickListener onBtnClickListener;private Context context;private String sure;private String cancle;private String appTitle;private String tips;private TextView tv_dele_sure;private TextView tv_dele_cancle;private TextView tv_appTitle;private TextView tv_tips;private RelativeLayout re_tip_dialog;public ShowDeleDialog(Context context,onBtnClickListener onBtnClickListener, String sure, String cancle,String appTitle, String tips) {super(context);this.onBtnClickListener = onBtnClickListener;this.context = context;this.appTitle = appTitle;this.tips = tips;this.sure = sure;this.cancle = cancle;}@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);// 去除默认的头部标题requestWindowFeature(Window.FEATURE_NO_TITLE);setContentView(R.layout.dele_allcontacts_dialog);tv_dele_sure = (TextView) findViewById(R.id.sure);tv_dele_cancle = (TextView) findViewById(R.id.cancel);tv_appTitle = (TextView) findViewById(R.id.appTitle);tv_tips = (TextView) findViewById(R.id.tips);re_tip_dialog = (RelativeLayout) findViewById(R.id.re_tip_dialog);tv_dele_cancle.setOnClickListener(this);tv_dele_sure.setOnClickListener(this);//进入动画是伪代码
ScaleAnimation scaleAnimation = new ScaleAnimation(1.0f, 1.0f,  
0.0f, 1.0f, Animation.RELATIVE_TO_SELF,  
0.5f, Animation.RELATIVE_TO_SELF,  
0.5f);  
scaleAnimation.setDuration(200);  
re_tip_dialog.startAnimation(scaleAnimation);
Window window = this.getWindow();WindowManager.LayoutParams params = this.getWindow().getAttributes();// 去除四角黑色背景window.setBackgroundDrawable(new BitmapDrawable());// 设置周围的暗色系数params.dimAmount = 0.5f;window.setAttributes(params);// 为各个textview赋值tv_dele_sure.setText(sure);tv_dele_cancle.setText(cancle);tv_appTitle.setText(appTitle);tv_tips.setText(tips);}public interface onBtnClickListener {public void onSure();public void onExit();}@Overridepublic void onClick(View v) {switch (v.getId()) {case R.id.cancel:onBtnClickListener.onExit();alertDialogExitAnim();break;case R.id.sure:onBtnClickListener.onSure();alertDialogExitAnim();break;default:break;}}private void alertDialogExitAnim() {ScaleAnimation scaleAnimation = new ScaleAnimation(1.0f, 0.0f,1.0f, 0.0f, Animation.ABSOLUTE,re_tip_dialog.getWidth() / 2, Animation.ABSOLUTE,re_tip_dialog.getHeight() / 2);scaleAnimation.setDuration(1000);re_tip_dialog.startAnimation(scaleAnimation);scaleAnimation.setAnimationListener(new AnimationListener() {@Overridepublic void onAnimationStart(Animation animation) {}@Overridepublic void onAnimationRepeat(Animation animation) {}@Overridepublic void onAnimationEnd(Animation animation) {ShowDeleDialog.this.dismiss();}});}}





这篇关于自定义AlertDialog(圆角+退出动画+自定义布局)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125366

相关文章

如何自定义一个log适配器starter

《如何自定义一个log适配器starter》:本文主要介绍如何自定义一个log适配器starter的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录需求Starter 项目目录结构pom.XML 配置LogInitializer实现MDCInterceptor

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

Kotlin Compose Button 实现长按监听并实现动画效果(完整代码)

《KotlinComposeButton实现长按监听并实现动画效果(完整代码)》想要实现长按按钮开始录音,松开发送的功能,因此为了实现这些功能就需要自己写一个Button来解决问题,下面小编给大... 目录Button 实现原理1. Surface 的作用(关键)2. InteractionSource3.

redis在spring boot中异常退出的问题解决方案

《redis在springboot中异常退出的问题解决方案》:本文主要介绍redis在springboot中异常退出的问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴... 目录问题:解决 问题根源️ 解决方案1. 异步处理 + 提前ACK(关键步骤)2. 调整Redis消费者组

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的